GraphicsMagick ChangeLog - 2019
2019-12-31 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/gradient.c (ReadGRADIENTImage): QueryColorDatabase() only throws a warning so allow the warning to propagate to the user rather than failing to report a useful message at all.
2019-12-30 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/gradient.c (GradientImage): OpenMP portability requires that loop variable be signed.
2019-12-30 Fojtik Jaroslav <JaFojtik@seznam.cz>
magick/gradient.c: Visual studio does not compile file without this fix.
2019-12-30 Fojtik Jaroslav <JaFojtik@seznam.cz>
VisualMagickconfigureconfigure.cpp Add option for speed optimisation to achieve better performance.
2019-12-29 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/version.h.in: Bump copyright years.
magick/image.c (DisplayImages): Fix return status. Was returning inverted return status.
coders/gradient.c (ReadGRADIENTImage): Support the "gradient:direction" definition to produce produce additional gradient vector directions corresponding to South, North, West, East, NorthWest, NorthEast, SouthWest, and SouthEast. This support is similar to a useful feature added in ImageMagick 6.9.2.5 although there is no claim that the results are identical, even if the resulting images appear to be visually indistinguishable.
magick/gradient.c (GradientImage): Add support for using the image 'gravity' attribute to produce additional gradient vector directions corresponding to SouthGravity (the previously-existing default), NorthGravity, WestGravity, EastGravity, NorthWestGravity, NorthEastGravity, SouthWestGravity, and SouthEastGravity. Gradient images are updated to be PseudoClass (color-mapped), if possible.
2019-12-28 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/gradient.c (GradientImage): Output PseudoClass images if we can.
coders/pcx.c (WritePCXImage): Fix heap overflow in PCX writer when bytes per line value overflows its 16-bit storage unit. Fixes SourceForge bug #619 "heap-buffer-overflow in WritePCXImage" reported by Suhwan Song.
magick/gradient.c (GradientImage): Gradient levels were still not spot-on. Now they are. Unfortunately, this necessitated re-generating reference test images based on gradient since the gradient output has changed a little bit more than the test error margins allow.
2019-12-25 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (DrawImage): Test gradient image resource limits using the proper API.
magick/resource.c (ResourceInfinity): Fix definition of ResourceInfinity. Due to parenthesis in the wrong place, the defined value was -1 rather than the maximum range value. The effect of this is that GetMagickResource() would return -1 rather than the maximum range value for the return type as documented. Regression was added on Saturday, March 09, 2019 in the 1.3.32 release via changeset 15927:a5318823758c.
tests/rwfile.c (main): Allow Ghostscript supported formats to be a bit lossy.
tests/rwblob.c (main): Allow Ghostscript supported formats to be a bit lossy.
magick/gradient.c (GradientImage): Compute blending alpha with double precision for more precision.
2019-12-24 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
NEWS.txt: Updates in preparation for 1.3.34 release.
2019-12-22 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
NEWS.txt: Update with changes since the last GM release.
coders/png.c (png_read_raw_profile): Use size_t type to store profile length and 'nibbles'. Use safer way to test for profile buffer overflow. (ReadOnePNGImage): Use size_t type to store 'ping_rowbytes', 'length', and 'row_offset'. Check png_pixels allocation for arithemetic overflow when computing the required allocation size.
coders/tiff.c (WriteNewsProfile): Use size_t type to store profile length.
coders/pict.c (WritePICTImage): Avoid 'alloc-size-larger-than' warning from GCC when allocating row_bytes.
2019-12-21 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
tiff/libtiff/tiffconf.h: Add standard/common libtiff 'SUPPORT' options which are used in full-fledged Autoconf/Cmake libtiff builds but were missing from the Visual C template file. In particular, WebP is now supported and JBIG is somewhat supported.
VisualMagick/jbig/libjbig/LIBRARY.txt (EXCLUDE): Remove tstcodec85.c from JBIG library build.
VisualMagick/configure/configure.cpp: Add JBIG library to include path when building libraries. Add WebP as a dependency when building libtiff.
2019-12-16 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/nt_base.h ("C"): Assume that float versions of functions became available in Visual Studio 2008.
2019-12-15 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/log.c (InitializeLogInfo): Using the compiled-in defaults, always log to stderr by default, even under Microsoft Windows. The logging output may then be diverted to 'win32eventlog' as soon as a log.mgk file is loaded if that is desired. This should not be much of a problem because loading a log.mgk file is the first thing that the library attempts to do. This change is made due to users and developers being baffled at not seeing any log output due to the log output going to the (very unfriendly) Windows application log.
webp: libwebp is updated to the 1.0.3 release.
2019-12-15 Fojtik Jaroslav <JaFojtik@seznam.cz>
magick/nt_base.c Fix user only installation of Ghostscript.
2019-12-14 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
rungm.sh.in (DIRSEP): DIRSEP should always use Unix conventions for Autotools-based builds.
magick/module.h ("C"): Eliminiate redundant and conflicting ListModuleInfo() prototype.
coders/miff.c (ReadMIFFImage): Eliminate warnings in trace statements.
coders/dib.c (DecodeImage): Eliminate warnings in trace statements.
coders/bmp.c (DecodeImage): Eliminate warnings in trace statements.
magick/studio.h (SupportMagickModules): Fix the preprocessor logic controlling SupportMagickModules, which became broken for GCC MinGW-based builds starting in the 1.3.29 release when a "static" module loader was implemented. Due to an error in the preprocessor logic, only the "modules" based build was working for MinGW. Much thanks to Giovanni Remigi for making us aware of this issue.
2019-12-12 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/pict.c (WritePICTImage): Throw a writer exception if the PICT width limit is exceeded. Fixes SourceForge issue 617 "heap-buffer-overflow in function EncodeImage of coders/pict.c".
2019-12-08 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
jbig: jbigkit is updated to 2.1 release.
libxml: libxml2 is updated to 2.9.10 release.
bzlib: bzip is updated to 1.0.8 release.
zlib: zlib is updated to 1.2.11 release.
png: libpng is updated to 1.6.37 release.
2019-12-07 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
lcms: lcms2 is updated to 2.9 release.
tiff: libtiff is updated to 4.1.0 release.
2019-11-24 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (DrawPatternPath): Don't leak memory if fill_pattern or stroke_pattern of cloned draw_info are not null. Fixes oss-fuzz issue 18948 "graphicsmagick:coder_MVG_fuzzer: Indirect-leak in CloneImage". (PrimitiveInfoRealloc): Clear freshly-allocated PrimitiveInfo memory.
2019-11-23 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/attribute.c (GenerateEXIFAttribute): Fix oss-fuzz issue 17986 "graphicsmagick:coder_JPG_fuzzer: Heap-buffer-overflow in GenerateEXIFAttribute". This problem likely only happens in 32-bit builds.
2019-11-17 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/png.c (ReadMNGImage): Only magnify the image if the requested magnification methods are supported.
2019-11-16 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/compress.c (HuffmanDecodeImage): Fix signed overflow on range check which leads to heap overflow in 32-bit applications. Requires a relatively large file input compared with typical fuzzer files (greater than a megabyte) to trigger. Problem reported to the graphicsmagick-security mail address by Justin Tripp on 2019-11-13. (Ascii85Tuple): Fix thread safety issue by requiring caller to pass in tuple buffer as an argument and having callers allocate tuple buffer on the stack.
2019-11-10 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/bit_stream.c: Add restrict declarations to slightly improve performance and decrease code size.
TclMagick/pkgIndex.tcl: Incorporate recommendations from third problem noted in SourceForge issue #420 "TclMagick issues and patch". This is supposed to help support using an uninstalled GraphicsMagick and allow the installation path to contain a space.
wand/magick_wand.c (MagickClearException): Destroy any existing exception info before re-initializing the exception info or else there will be a memory leak.
TclMagick/generic/libttkcommon.c (myMagickError): Clear exception from the Wand after it has been reported. Addresses the fourth problem noted by SourceForge issue #420 "TclMagick issues and patch". However, MagickClearException() already clears an exception in the Wand, so a new function is not needed.
TclMagick/unix/m4/tcl.m4: Change hard-coded INSTALL path to point to config/install-sh. Re-generated/updated Autotools stuff by executing the genconf.sh script. Addresses the first problem noted by SourceForge issue #420 "TclMagick issues and patch".
2019-11-02 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/pixel_cache.c (SetNexus): Eliminate warning about possibly uninitialized variable from primordial GCC 3.4.3.
magick/render.c (ConvertPrimitiveToPath): Eliminate warning that IsClosedSubPath might be used uninitialized.
magick/common.h ("MAGICK_FALLTHROUGH"): Added a MAGICK_FALLTHROUGH macro to support the GCC/Clang fallthrough attribute when the time comes again that it would be useful.
2019-10-19 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/pcx.c (ReadPCXImage): Verify that pixel region is not negative. Assure that opacity channel is initialized to opaqueOpacity. Update DirectClass representation while PseudoClass representation is updated. Improve read performance with uncompressed PCX.
2019-10-16 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/xpm.c (ReadXPMImage): Image properties are expected to appear within the first 512 bytes of the XPM file header. fixes oss-fuzz 18267 "graphicsmagick:coder_PICON_fuzzer: Timeout in coder_PICON_fuzzer".
2019-10-14 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
configure.ac: Fix tcmalloc configuration report.
2019-10-13 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/wpg.c (ReadWPGImage): Implement subimage/subrange support.
coders/mat.c (ReadMATImage, ReadMATImageV4): Implement subimage/subrange support. Should resolve oss-fuzz 14999 "graphicsmagick/coder_MAT_fuzzer: Out-of-memory in graphicsmagick_coder_MAT_fuzzer".
coders/tiff.c (TIFFMapBlob): Fix compile problem if LOG_TIFF_BLOB_IO is defined.
coders/wpg.c (ExtractPostscript): Improve performance. Avoid temporary files if possible. Avoid additional memory allocations if possible. Should address oss-fuzz issue 18173 "graphicsmagick:enhance_fuzzer: Timeout in enhance_fuzzer" and oss-fuzz issue 17714 "graphicsmagick:coder_WPG_fuzzer: Timeout in coder_WPG_fuzzer".
2019-10-12 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/pnm.c (PNMInteger): Place a generous arbitrary limit on the amount of PNM comment text to avoid denial of service opportunity. Fixes oss-fuzz 18162 "Timeout · coder_PNM_fuzzer".
2019-10-08 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/dps.c (ReadDPSImage): Fix memory leak when OpenBlob() reports failure. Same as ImageMagick CVE CVE-2019-16709.
2019-09-27 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/attribute.c (GenerateEXIFAttribute): Skip unsupported/invalid format 0. Fixes oss-fuzz issue 17597 "graphicsmagick:coder_SFW_fuzzer: Heap-buffer-overflow in GenerateEXIFAttribute".
2019-09-19 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
fuzzing/oss-fuzz-build.sh: Change by Alex Gaynor so that the correct oss-fuzz fuzzing engine should be used.
2019-09-18 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/static.c (OpenModule): Static module loader should use upper-cased magick string when searching for a module alias. Fixes SourceForge issue #613 "static module loader is still case-sensitive".
2019-09-16 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
configure.ac: Report status of zstd (FaceBook Zstandard) compression in configuration summary.
2019-09-15 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (TraceArcPath): Substitute a lineto command when tracing arc is impossible. Fixes oss-fuzz 10765 "graphicsmagick/coder_MVG_fuzzer: Divide-by-zero in TraceArcPath".
2019-09-14 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/png.c (png_read_raw_profile): Fix validation of raw profile length. Fixes oss-fuzz 16906 "graphicsmagick:coder_ICO_fuzzer: Out-of-memory in graphicsmagick_coder_ICO_fuzzer".
coders/wpg.c (ReallocColormap): Avoid dereferencing a null pointer if image->colormap is null. Fixes oss-fuzz 17004 "graphicsmagick:coder_WPG_fuzzer: Null-dereference READ in ReallocColormap".
2019-09-13 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/memory.c (MagickRealloc): Add a note that the behavior of this function is as described for BSD reallocf(3), which is now appearing in Linux's GNU libc and elsewhere.
2019-09-09 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
www/OpenMP.rst: Document the significant OpenMP speed-up which may be obtained by using an alternate memory allocation library. Currently 'tcmalloc', 'mtmalloc', and 'umem' are supported as options.
www/INSTALL-unix.rst: Document new --with-tcmalloc option to enable using Google gperftools tcmalloc library.
configure.ac: Add support for using Google gperftools tcmalloc library via the --with-tcmalloc option.
scripts/rst2htmldeco.py: Port to Python 3 syntax and require at least Python 2.6.
scripts/relpath.py: Port to Python 3 syntax and require at least Python 2.6.
scripts/html_fragments.py: Port to Python 3 syntax and require at least Python 2.6.
scripts/format_c_api_doc.py: Port to Python 3 syntax and require at least Python 2.6.
2019-08-27 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
doc/GraphicsMagick.imdoc: Document gm utility exit status codes.
2019-08-25 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (PRIMITIVE_INFO_POINTS_MAX): SIZE_MAX apparently rounds up by one when cast to a double on 64-bit systems. Due to this, and in order to set more rational implementation limits, add a PRIMITIVE_INFO_POINTS_MAX definition which computes and constrains the maximum number of PrimitiveInfo entries allowed.
2019-08-24 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/attribute.c (GenerateEXIFAttribute): Check that we are not being directed to read an IFD that we are already parsing and quit in order to avoid a loop. Addresses oss-fuzz 15753 "graphicsmagick/coder_JPEG_fuzzer: Timeout in graphicsmagick_coder_JPEG_fuzzer" and 16068 "graphicsmagick/coder_SFW_fuzzer: Timeout in graphicsmagick_coder_SFW_fuzzer".
tests/{constitute.c, drawtest.c, rwblob.c, rwfile.c}: Eliminate irritating GCC 9 "__builtin_strncpy' output may be truncated" warnings due to copying MaxTextExtent-1 characters. Instead request copying all of the characters and also assure that string is still null terminated.
doc/environment.imdoc: Update documentation pertaining to HOME and MAGICK_DEBUG environment variables.
2019-08-23 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/log.c (DestroyLogInfo): Only output text to terminate an XML format log file if XML format is active.
2019-08-22 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (ExtractTokensBetweenPushPop): Previous fix for non-terminal loop was broken by a last-minute untested edit. Finally addresses oss-fuzz 15318 "graphicsmagick/coder_MVG_fuzzer: Timeout in graphicsmagick_coder_MVG_fuzzer".
2019-08-17 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
fuzzing/utils.cc (MemoryResource): Lessen the memory limit used for oss-fuzz testing in order to provide more headroom and margin for error.
magick/render.c (TraceBezier): Detect arithmetic overflow and return errors via normal error path rather than exiting. Fixes oss-fuzz 16450 "graphicsmagick:coder_MVG_fuzzer: Unexpected-exit in DefaultFatalErrorHandler". (PrimitiveInfoRealloc): Implement more paranoid code related to primitive allocation.
2019-08-16 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (DrawStrokePolygon): Handle case where TraceStrokePolygon() returns NULL. Addresses oss-fuzz 15516 "graphicsmagick/coder_MVG_fuzzer: ASSERT: primitive_info != (PrimitiveInfo *) NULL". (DrawDashPolygon): Handle case where DrawStrokePolygon() returns MagickFail. Also needed to address oss-fuzz 15516, since otherwise test-cases run for a very long time. (ExtractTokensBetweenPushPop): Fix non-terminal parsing loop. Addresses oss-fuzz 15318 "graphicsmagick/coder_MVG_fuzzer: Timeout in graphicsmagick_coder_MVG_fuzzer".
2019-08-15 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/memory.h (MagickMallocAlignedArray): Add function attributes for added value and to quench GCC 9 warning with special build options enabled.
magick/deprecate.h (AcquireMemory): Add more function attributes to quench GCC 9 warning with special build options enabled.
magick/attribute.c (GenerateEXIFAttribute): Fix compilation warning in 32-bit build.
coders/dpx.c (AttributeToString): Eliminate annoying warnings from GCC 9, although the code was correct.
coders/msl.c (MSLStartElement): Fix defective opacity percentage code revealed by GCC 9 warning.
2019-08-14 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/png.c (ReadMNGImage): Skip coalescing layers if there is only one layer. Fixes oss-fuzz 16274 "graphicsmagick/coder_MNG_fuzzer: Unexpected-exit in DefaultFatalErrorHandler".
2019-08-12 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/png.c (ReadPNGImage): Post-processing to convert the image type in the PNG reader based on a specified magick prefix string is now disabled. This can (and should) be done after the image has been returned. Fixes oss-fuzz 16386 "graphicsmagick:coder_PNG8_fuzzer: Timeout in graphicsmagick_coder_PNG8_fuzzer".
2019-07-20 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
NEWS.txt: Updates in preparation for 1.3.33 release.
2019-07-19 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
NEWS.txt: Updated NEWS to reflect updates since last release.
2019-07-12 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/png.c (WriteOnePNGImage): Fix saving to palette when image has an alpha channel but no color is marked as transparent. Patch submitted by Przemysław Sobala via SourceForge patch #61 "WriteOnePNGImage(): Fix saving to palette when image has an alpha channel but no color is marked as transparent".
doc/options.imdoc (characters): Fix -format documentation to reflect that '%r' returns the image type. Patch submitted by Przemysław Sobala via SourceForge patch #60 "Fix documentation typo".
2019-07-07 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/tempfile.c (AcquireTemporaryFileDescriptor): Fix compilation under Cygwin. Patch by Marco Atzeri and submitted via email to the graphicsmagick-help mailing list on Fri, 5 Jul 2019.
2019-06-23 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/attribute.c (GenerateEXIFAttribute): Added range checks and tracing. Fixes oss-fuzz 14998 "graphicsmagick/coder_JPEG_fuzzer: Heap-buffer-overflow in Read32s". This is a tiny read overflow.
coders/miff.c (ReadMIFFImage): Similar fix as to mpc.c
coders/mpc.c (ReadMPCImage): Fix faulty signed overflow logic for profiles[i].length which still allowed overflow. Fixes oss-fuzz issue 15190 "graphicsmagick/coder_MPC_fuzzer: Out-of-memory in graphicsmagick_coder_MPC_fuzzer".
doc/options.imdoc: Add notes about security hazards due to commands which support a '@filename' syntax.
www/security.rst: Add notes about security hazards due to commands which support a '@filename' syntax.
2019-06-22 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (DrawImage): Assure that 'token' is initialized. Fixes oss-fuzz issue 14897 "graphicsmagick/coder_MVG_fuzzer: Use-of-uninitialized-value in DrawImage".
magick/animate.c (MagickXAnimateImages): Fix memory leak of scene_info.pixels.
magick/display.c (MagickXDisplayImage): Fix heap overwrite of windows->image.name and windows->image.icon_name buffers. It appears that the code assumed that CloneString() would always allocated a string at least MaxTextExtent in size. I assume that this issue has existed for a very long time since CloneString() was re-written many years ago.
coders/caption.c (ReadCAPTIONImage): The CAPTION reader did not appear to work at all any more. Now it works again, but still not very well.
magick/command.c: Re-implement '@' file inclusion support for -comment, -draw, -format, and -label which was removed for the 1.3.32 release. Note that arguments from untrusted sources will still need to be sanitized to detect attempts to subvert this feature to access file data, but this feature has always been supported by GraphicsMagick and it originated early in the development of ImageMagick.
2019-06-17 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/utility.c (MagickStrlCat, MagickStrlCpy): Add debug checks enabled by MAGICK_STRL_CHECK.
magick/montage.c (MontageImages): Fix wrong length argument to strlcat() when building montage directory, which could allow heap overwrite.
coders/png.c (RegisterPNGImage): Pass correct size value to strlcat(). Under Apple's OS X (and possibly other targets) strlcat() writes bytes beyond what it needs to (but within the range it is allowed to) causing a crash due to the wrong limit value. Fixes SourceForge issue #609 gm identify foo.png crashes on macOS (v 1.3.32).
www/Changes.rst: Update ChangeLog links due to new year, and 1.3.32 release.
2019-06-16 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/bmp.c (WriteBMPImage): Detect arithmetic overflow of image_size. Add more tracing. Reduce compilation warnings. (EncodeImage): Reduce compilation warnings. (WriteBMPImage): Assure that chromaticity uses double-precision for multiply before casting to unsigned integer.
coders/wpg.c (ReallocColormap): Reduce compilation warnings.
coders/braille.c (WriteBRAILLEImage): Reduce compilation warnings.
coders/dib.c (WriteDIBImage): Detect arithmetic overflow of image_size. Reduce compilation warnings. (EncodeImage): Reduce compilation warnings.
coders/locale.c (WriteLOCALEImage): Reduce compilation warnings.
2019-06-15 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
Makefile.am (dist-zstd): Use the maximum possible compression level (22) when creating a Zstd-compressed tarball to get close to lzip/xz compression levels.
coders/tiff.c (ReadTIFFImage): Fix typo in initialization of 'tile' pointer variable.
version.sh: Updates in preparation for 1.3.32 release.
2019-06-14 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
Makefile.am (release): Add a release target to make it easier to produce and sign the release files. Add a zstd-compressed output tarball just because we can.
2019-06-12 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (DrawImage): Fix typo when initializing number_coordinates. Somehow GCC and clang let this typo slip by.
2019-06-11 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/dib.c (ReadDIBImage): Preserve PseudoClass opaque representation if ICO mask is opaque, otherwise return a DirectClass image.
2019-06-10 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (DrawImage): Detect an error in TracePath() and quit rather than forging on.
2019-06-09 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (DrawImage): Terminate drawing if DrawCompositeMask() reports failure. Fixes oss-fuzz 12373 "graphicsmagick/coder_MVG_fuzzer: Timeout in graphicsmagick_coder_MVG_fuzzer". (TracePath): Terminate path parsing upon first parsing error.
2019-06-08 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/txt.c (ReadTXTImage): Use real a new-line character as line delimiter rather than 'n' string.
magick/annotate.c (AnnotateImage): No longer implicitly call TranslateText() since this is not suitable for most use-cases and causes additional performance impact. The API user can perform such translations in advance on the text string using TranslateText() if need be. No longer call StringToList() to split strings into an array of strings since this can lead to unexpected results, and a custom-splitter is more efficient.
2019-06-06 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (DrawImage): Only support '@filename' syntax to read drawing primitive from a file if we are not already drawing.
magick/utility.c (TranslateTextEx): Remove support for reading from a file using '@filename' syntax due to security concerns. Problem was reported to us by "Battle Furry" via the GraphicsMagick security mail alias on June 6, 2019.
2019-06-03 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/utility.c (SetClientFilename): Reduce initialized data some more.
2019-06-02 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/nt_base.c: Search for n019003l.pfb (the "Helvetica"-like font) rather than fonts.dir since fonts.dir is not present in all URW font collections.
NEWS.txt: Update news.
2019-06-01 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/logo.c: Tidy logo image definitions, and logo image output.
2019-05-23 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/mat.c: Make more data const.
2019-05-22 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/animate.c: Reduce initialized static allocations.
magick/display.c: Reduce initialized static allocations.
magick/widget.c (MagickSplitNDLTextToList): Add static implementation function.
2019-05-20 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/webp.c (RegisterWEBPImage): Use sprintf to format version since snprintf is not available in old Visual Studio.
2019-05-19 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/dcm.c: Make more data const.
www/INSTALL-unix.rst: Add documentation for how to install URW fonts from various package management systems.
2019-05-18 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
www/authors.rst: Add authorship attribution to Samuel Thibault for contributing support for the Braille image format.
coders/braille.c: Add support for Braille image format by Samuel Thibault. Patch submitted via SourceForge patch #59 "Add braille image format support.
2019-05-17 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/tempfile.c: Make more data const.
magick/signature.c: Make more data const.
magick/quantize.c: Make more data const.
magick/attribute.c: Make more data const.
coders/png.c: Make more data const.
coders/mpeg.c: Make more data const.
coders/wmf.c: Make more data const.
coders/tile.c: Make more data const.
2019-05-16 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/enum_strings.c: Make more data const.
2019-05-15 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/magick.c: Make more data const.
magick/type.c (GetTypeInfoByFamily): Make more data const.
magick/unix_port.c (MagickGetMMUPageSize): Decrease initialized data.
magick/utility.c (GetPageGeometry): Make more data const.
coders/pdf.c (WritePDFImage): Allocate working buffer on stack and pass as argument to EscapeParenthesis() to eliminate a thread safety problem and also reduce BSS size.
coders/webp.c (RegisterWEBPImage): Fix compiler warning.
coders/jbig.c (RegisterJBIGImage): Make more data const.
coders/pict.c (DecodeImage): Allocate output buffer used by ExpandBuffer() on the stack rather than as static data private to ExpandBuffer(). Eliminates a thread safety problem and also reduces BSS size.
coders/webp.c (RegisterWEBPImage): Reduce BSS size.
2019-05-14 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/jp2.c: Make more data const.
coders/wmf.c: Make more data const.
coders/ps.c (WritePSImage): Make more data const.
coders/ps2.c (WritePS2Image): Make more data const.
2019-05-13 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/static.c: Revert to previous 'name' storage. Callback functions in structure block being properly const.
coders/xpm.c: Make more data const.
coders/pnm.c: Make more data const.
coders/palm.c: Make more data const.
coders/meta.c: Make more data const.
coders/dcraw.c: Make more data const.
magick/command.c: Fix compilation problem when HasX11 is not defined.
2019-05-12 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/command.c: Make more data const.
2019-05-11 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/webp.c (RegisterWEBPImage): Make more data const.
coders/svg.c (RegisterSVGImage): Reduce BSS size.
coders/miff.c (RegisterMIFFImage): Fix version reporting.
coders/ttf.c (RegisterTTFImage): Fixed reporting of FreeType version.
coders/tiff.c (RegisterTIFFImage): Reduce BSS size.
coders/sfw.c (ReadSFWImage): Make SFW static data completely const.
coders/ps3.c: Make PS3 static data completely const.
coders/pict.c: Make PICT static data completely const.
magick/error.c (ThrowException, ThrowLoggedException): Handle the case where some passed character strings refer to existing exception character strings. Fixes SourceForge issue #603 "heap-use-after-free in function ThrowLoggedException of magick/error.c". (CatchException): Restructure so there is one return point.
coders/miff.c (ImportRLEPixels): Fix heap overflow caused by a typo in the code. Also fix undefined behavior caused by large left shifts of an unsigned char. Fixes SourceForge issue #608 "heap-buffer-overflow in ImportRLEPixels of coders/miff.c.
2019-05-08 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/bmp.c (ReadBMPImage): Fix subrange/scene handling in 'ping' mode so it is like the other formats. Only the first frame was being enumerated while in 'ping' mode.
2019-05-07 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
NEWS.txt: Update news.
magick/utility.c (ExpandFilenames): Only expand '@filename' to a list of arguments read from 'filename' if the path '@filename' does not exist. This fix is made based on an email posting to the 'graphicsmagick-help' mailing list at SourceForge by "Test User" on Tue, 7 May 2019.
2019-05-05 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/colorspace.c: Reorder initialization of colorspace tables for a possible performance improvement.
magick/fx.c (WaveImage): Use float for sin map.
configure.ac: Test for float versions of math functions.
magick/gem.c (GenerateDifferentialNoise): Use float versions of math functions when available.
2019-05-02 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
www/INSTALL-unix.rst: Expanded configure documentation for --with-modules. Added specific configure documentation for --with-umem and --with-mtmalloc, which may be useful on Solaris-derived systems.
2019-04-23 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/command.c (VersionCommand): Show OpenMP specification version corresponding to version enumeration.
magick/locale.c (GetLocaleMessageFromTag): Eliminate clang warning about comparison with a constant value.
magick/log.c (InitializeLogInfo): Initialize LogInfo log_configured.
2019-04-21 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/magic.c (struct): Ajust StaticMagic definition to be more const-friendly.
magick/color_lookup.c (struct): Adjust StaticColors definition to be more const-friendly.
magick/attribute.c: Ajust tag_table definition to be more const-friendly.
magick/log.c: Allocate LogInfo from heap as we used to do.
magick/locale.c (GetLocaleMessageFromTag): Adaptations to locale coder output changes.
coders/locale.c (WriteLOCALEImage): Adjust locale coder output to be more const.
2019-04-20 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/color_lookup.c: Make built-in color tables fully const.
magick/animate.c: Use MagickXTextViewWidgetNDL() to display help text.
magick/display.c: Use MagickXTextViewWidgetNDL() to display help text.
magick/widget.c (MagickXTextViewWidgetNDL): New private function to display multi-line null-delimited text in an X11 widget.
coders/xwd.c (ReadXWDImage): Added even more XWD header validation logic. Addresses problems noted by email from Hongxu Chen to the graphicsmagick-security mail alias on Fri, 19 Apr 2019 and Sat, 20 Apr 2019 and entitled "Multiple crashes (FPE and invalid read) when processing XWD files".
2019-04-17 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/xwd.c (ReadXWDImage): Added even more XWD header validation logic. Addresses problems noted by email from Hongxu Chen to the graphicsmagick-security mail alias on Wed, 17 Apr 2019 and entitled "Multiple crashes (FPE and invalid read) when processing XWD files". Also addresses additional issues noted that an attacker could request to allocate an arbitrary amount of memory based on ncolors and the claimed header size.
2019-04-14 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/xwd.c (ReadXWDImage): Add more XWD header validation logic. Addresses problems noted by email from Hongxu Chen to the graphicsmagick-security mail alias on Sun, 14 Apr 2019 and entitled "Multiple crashes (FPE and invalid read) when processing XWD files".
2019-04-13 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/pdb.c (WritePDBImage): Assure that input scanline is cleared in order to cover up some decoder bug. May fix 14215 "graphicsmagick/coder_PDB_fuzzer: Use-of-uninitialized-value in WritePDBImage", which I have not been able to reproduce.
magick/render.c (DrawPrimitive): Check primitive point x/y values for NaN. (DrawImage): Fix oss-fuzz issue 14173 "graphicsmagick/coder_MVG_fuzzer: Integer-overflow in DrawImage".
magick/pixel_cache.c (SetNexus): Fix oss-fuzz issue 14208 "graphicsmagick/coder_MVG_fuzzer: Integer-overflow in SetNexus".
2019-04-11 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/display.c: Add even more const declarations.
coders/mat.c (WriteMATLABImage): Add completely missing error handling. Fixes SourceForge issue #604 "heap-buffer-overflow in function WriteMATLABImage of coders/mat.c".
2019-04-10 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/pdb.c (WritePDBImage): Fix SourceForge issue #605 "heap-buffer-overflow in function WritePDBImage of coders/pdb.c".
magick/widget.c: Add many const declarations.
magick/display.c: Incorporate and eliminate display.h. Add many const declarations.
magick/animate.c: Incorporate and eliminate animate.h. Add many const declarations.
2019-04-08 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/wmf.c (ReadWMFImage): Reject WMF files with an empty bounding box. Fixes SourceForge issue #606 "Division by Zero in coders/wmf.c".
2019-04-07 Fojtik Jaroslav <JaFojtik@seznam.cz>
magick/nt_base.c Fix a problem of finding ghostscript fonts. Variable "font_dir" was useless and thus removed. No need to copy text multiple times. Use const char gs_font_dir[] instead of pointer.
2019-04-07 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/xwd.c (ReadXWDImage): Perform more header validations and a file size validation in order to reject files with bogus headers. (WriteXWDImage): Fix SourceForge issue #599 "heap_buffer_overflow_WRITE in function WriteXWDImage of coders/xwd.c".
2019-04-05 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/svg.c (SVGStartElement): Fix stack buffer overflow while parsing quoted font family value. Fixes SourceForge issue #600 "stack-buffer-overflow in function SVGStartElement of coders/svg.c".
coders/miff.c (ReadMIFFImage): Detect end of file while reading RLE packets. Fixes SourceForge issue #598 "heap-buffer-overflow in function ReadMIFFImage of coders/miff.c".
2019-04-03 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/xwd.c (ReadXWDImage): Fix heap buffer overflow while reading DirectClass XWD file. Fixes SourceForge issue #597 "heap-buffer-overflow in function ReadXWDImage of coders/xwd.c".
2019-04-02 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/png.c (ReadMNGImage): Fix small buffer overflow (one PixelPacket) of image colormap. Fixes SourceForge issue #596 "heap-buffer-overflow in function CloneImage of magick/image.c".
magick/colormap.c (ReallocateImageColormap): New function to reallocate an image colormap.
coders/logo.c: Make more static data const.
magick/module_aliases.h: Make more static data const.
magick/static.c: Make more static data const.
2019-04-01 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/log.c (LogMagickEventList): Log elapsed time with microsecond precision.
2019-03-31 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/mpc.c (ReadMPCImage): Deal with a profile length of zero, or an irrationally large profile length. Fixes SourceForge issue #601 "memory leak in function ReadMPCImage of coders/mpc.c ".
magick/xwindow.c (MagickXGetWindowInfo): Deal with the unlikely case that the memory allocation for window->segment_info fails. Fixes SourceForge #595 "use allocate memory before null check" as pertains to magick/xwindow.c.
magick/segment.c (Classify): Add check for memory allocation failure when allocating cluster array. Fixes SourceForge #595 "use allocate memory before null check" as pertains to magick/segment.c.
coders/pdb.c (ReadPDBImage): Fix use of allocated memory before null check. Fixes SourceForge #595 "use allocate memory before null check" as pertains to coders/pdb.c.
2019-03-30 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/pixel_cache.c (AllocateThreadViewSet): Simplify the image view model by adding NexusInfo to the View structure (rather than referencing it via a pointer) to lessen the number of required per-thread allocations and to improve locality of reference.
2019-03-22 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/wpg.c (WPG1_Palette): Change to a static declaration.
coders/dcm.c: dicom_info array is now fully in the data segment.
2019-03-18 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
configure.ac: Add support for using the Solaris mtmalloc library. This is primarily for testing or as an alternative to Solaris umem. Stop using posix_memalign() until it is uniformly more mature and reliably quick.
2019-03-17 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/pixel_cache.c (SetNexus): Smallest staging-area allocation is cache line size so declare it as such.
magick/fx.c: Functions in the fx module which return a new Image should return a null Image if an exception was thrown. Also, assure that user has an opportunity to see the exception which was thrown.
magick/error.c (ThrowLoggedException): Throwing an exception is now thread-safe.
magick/pixel_cache-private.h: Moved pixel cache private definitions to private header.
2019-03-10 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/pixel_cache.c (SetNexus): Pass x, y, columns, and rows rather than a pointer to RectangleInfo. This should be easier to inline on modern CPUs.
2019-03-09 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/pixel_cache.c (SetNexus): Cache resource limits in CacheInfo rather than repeatedly calling into the resource code in order to lessen the overhead of performing resource limit checks on the pixel cache views.
magick/resource.c (AcquireMagickResource): Use a lock for each resource in order to lessen contention. Return a maximum 64-bit integer value if the resource has not been limited. Previously returned -1 in this case but this was not documented.
2019-03-07 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/import.c (ImportViewPixelArea): If range between max and min is less than MagickEpsilon, produce a black image rather than throwing an exception.
coders/mat.c (ReadMATImage): Fix memory leak on unexpected end of file. Fixes oss-fuzz 13556 "graphicsmagick/coder_MAT_fuzzer: Direct-leak in ReadMATImage". (Credit to OSS-Fuzz)
2019-03-06 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/mat.c (ReadMATImage): Quit if image scanlines are not fully populated due to exception. Fixes oss-fuzz 13530 "graphicsmagick/coder_MAT_fuzzer: Use-of-uninitialized-value in InsertComplexFloatRow". (Credit to OSS-Fuzz)
2019-03-04 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/txt.c (ReadTXTImage): Don't start new line if x_max < x_min. Avoids calling SetImagePixels() with a width of zero. Related to oss-fuzz 13521 "graphicsmagick/coder_TEXT_fuzzer: Floating-point-exception in SetNexus". (Credit to OSS-Fuzz)
magick/pixel_cache.c (SetNexus): Report error for empty region rather than crashing due to divide by zero exception. This is a new bug due to yesterday's changes. Fixes oss-fuzz 13521 "graphicsmagick/coder_TEXT_fuzzer: Floating-point-exception in SetNexus". (Credit to OSS-Fuzz)
2019-03-03 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
design/pixel-cache.dot: Update design dot diagram to remove IsNexusInCore and add CompositeCacheNexus.
magick/pixel_cache.c (SetNexus): Apply resource limits to pixel nexus allocations using the same limits (total pixels, width, height, memory) as applied to the whole image since some requests are directly influenced by the input file. Add yet more tests for arithmetic overflow. Whole source module is re-arranged so that static functions are in order of dependency so that forward prototype declarations are no longer needed. Fixes oss-fuzz 13210 "graphicsmagick/coder_MVG_fuzzer: Integer-overflow in SetNexus". (Credit to OSS-Fuzz)
2019-03-02 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/pixel_cache.c (OpenCache): Use unsigned 64-bit value to store CacheInfo offset and length as well as for the total pixels calculation. Add some more arithmetic overflow detections.
coders/topol.c (ReadTOPOLImage): Report a corrupt image exception "Unexpected end-of-file" if reader encounters end of file while reading header rows. Addresses oss-fuzz 7981 "graphicsmagick/coder_TOPOL_fuzzer: Use-of-uninitialized-value in InsertRow". (Credit to OSS-Fuzz)
coders/mat.c (ReadMATImage): Report a corrupt image exception "Unexpected end-of-file" if reader encounters end of file while reading scanlines. Also added some helpful traces. Hopefully addresses oss-fuzz 13445 "graphicsmagick/coder_MAT_fuzzer: Use-of-uninitialized-value in IsGrayImage". (Credit to OSS-Fuzz)
2019-02-26 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/image.h ("C"): Include as "magick/image-private.h" as the other headers are. ("C"): Include "magick/image-private.h" inside the protective MAGICK_IMPLEMENTATION guard, as it should have been. This error broke the oss-fuzz build.
2019-02-24 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/image-private.h (_ImageExtra): Put ImageExtra definition in a private header file so that its definition may be accessed directly by library internals. Add some accessor macros to provide access and update code to use them.
coders/wpg.c (ReallocColormap): Make sure that there is not a heap overwrite if the number of colors has been reduced. Thanks to Jaroslav Fojtik for giving me a heads up about this.
2019-02-23 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/monitor.c (MagickMonitorActive): Add new private function to test if a progress monitor is active. Update all progress monitor code in loops to use this information, while also updating code to hopefully address concerns expressed by Hongxu Chen about data races on the graphicsmagick-bugs mailing list starting on February 6, 2019.
2019-02-21 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/mpc.c (ReadMPCImage): Tally directory length to avoid death by strlen().
coders/miff.c (ReadMIFFImage): Tally directory length to avoid death by strlen(). Fixes oss-fuzz 13190 "graphicsmagick/coder_MIFF_fuzzer: Timeout in graphicsmagick_coder_MIFF_fuzzer". (Credit to OSS-Fuzz)
2019-02-17 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/svg.c (ReadSVGImage): Don't call xmlCleanupParser() in module code since this may cause other libxml users to fail.
coders/msl.c (ProcessMSLScript): Don't call xmlCleanupParser() in module code since this may cause other libxml users to fail.
magick/render.c (DrawDashPolygon): (DrawDashPolygon): Don't read beyond end of dash pattern array. This is a second instance of issue identified by SourceForge issue #591. Fixes oss-fuzz 13160 "graphicsmagick/coder_MVG_fuzzer: Heap-buffer-overflow in DrawDashPolygon". The earlier attempt to fix this problem today broke dash patterns entirely. (Credit to OSS-Fuzz)
magick/annotate.c (RenderFreetype): Eliminate memory leak of GlyphInfo.image (type FT_Glyph) while rendering some FreeType fonts such as the one we use now in the Magick++ test suite.
2019-02-16 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/render.c (DrawDashPolygon): Avoid reading one beyond length of dash pattern array, which is terminated by value 0.0. Fixes SourceForge issue #591 "Heap buffer overflow in DrawDashPolygon when parsing SVG images". (DrawPrimitive): Add arithmetic overflow checks when converting computed coordinates from 'double' to 'long'. (DrawImage): Don't destroy draw_info in graphic_context when draw_info has not been allocated yet. Problem reported via email by Sami Supperi on Thu, 14 Feb 2019.
coders/jpeg.c (ReadJPEGImage): JPEG files are observed to provide compression ratios as high as 2500 so allow for that. Also, the test for "Unreasonable dimensions" delivered yesterday was flawed since magick_rows and magick_columns are only set if a desired image size was provided. Fixes SourceForge issue 592 "Non-malicious JPEG file fails with "Unreasonable dimensions"".
coders/tiff.c (ReadTIFFImage): Only disassociate alpha channel for images where photometic is PHOTOMETRIC_RGB. Fixes oss-fuzz 13115 "graphicsmagick/coder_PTIF_fuzzer: Use-of-uninitialized-value in DisassociateAlphaRegion". (Credit to OSS-Fuzz)
2019-02-15 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/jpeg.c (ReadJPEGImage): Base test for "Unreasonable dimensions" on original JPEG dimensions and not the scaled dimensions. Fixes SourceForge issue 593 "gm convert: Insufficient image data in file when hinting input image".
2019-02-13 Troy Patteson <troyp@ieee.org>
PerlMagick/Magick.xs (Mogrify): Add decorate argument to Annotate.
PerlMagick/Magick.xs (Mogrify): Remove reference to undefined Annotate argument.
2019-02-12 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/tiff.c (ReadTIFFImage): For planar TIFF, make sure that pixels are initialized in case some planes are missing. Fixes oss-fuzz 13046 "graphicsmagick/coder_PTIF_fuzzer: Use-of-uninitialized-value in DisassociateAlphaRegion". (Credit to OSS-Fuzz)
2019-02-11 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/pdf.c (WritePDFImage): Make sure to free 'xref' before returning. Similar to ImageMagick CVE-2019-7397 "In ImageMagick before 7.0.8-25, several memory leaks exist in WritePDFImage in coders/pdf.c.". Thanks to Petr Gajdos for bringing this issue to our attention.
2019-02-10 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/wpg.c (ReadWPGImage): Use a different way to reallocate the colormap which preserves existing content, but also updates image->colors and assures that added palette entries are initialized.
coders/png.c (ReadMNGImage): Bound maximum loop iterations by subrange as a primitive means of limiting resource consumption. This should finally resolve oss-fuzz 12738 "graphicsmagick/enhance_fuzzer: Out-of-memory in graphicsmagick_enhance_fuzzer". (Credit to OSS-Fuzz)
coders/tiff.c (ReadTIFFImage): Assure that opacity channel is initialized in the RGBAStrippedMethod case. Convert 'CorruptImageError' encountered while testing for more frames to 'CorruptImageWarning' so we return the frames already read. Second try at fixing oss-fuzz 11896 "graphicsmagick/coder_PTIF_fuzzer: Use-of-uninitialized-value in VerticalFilter".
coders/dpx.c (AttributeToString): Eliminate clang "-Wstring-plus-int" warning observed in oss-fuzz build.
coders/cineon.c (AttributeToString): Eliminate clang "-Wstring-plus-int" warning observed in oss-fuzz build.
2019-02-09 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/pict.c (DecodeImage): Avoide a one-byte over-read of pixels heap allocation. The cause of the over-read is not yet understood. Fixes oss-fuzz 12019 "graphicsmagick/coder_PICT_fuzzer: Heap-buffer-overflow in ExpandBuffer". (Credit to OSS-Fuzz)
coders/wpg.c (ReadWPGImage): Assure that all colormap entries are initialized. Fixes oss-fuzz 12614 "graphicsmagick/enhance_fuzzer: Use-of-uninitialized-value in EnhanceImage". (Credit to OSS-Fuzz)
coders/tiff.c (ReadTIFFImage): Make sure that image is in DirectClass mode and ignore any claimed colormap when the image is read using the RGBAStrippedMethod, RGBATiledMethod, or RGBAPuntMethod cases. Fixes oss-fuzz 12195 "graphicsmagick/coder_PTIF_fuzzer: Use-of-uninitialized-value in ExportGrayQuantumType". (Credit to OSS-Fuzz)
coders/miff.c (ReadMIFFImage): Improve pixel buffer calculations to defend against overflow. Assure that zlib and bzlib decode the expected number of bytes for a pixel row. Fixes oss-fuzz issue 12448 "graphicsmagick/coder_MIFF_fuzzer: Use-of-uninitialized-value in RGBTransformPackets". (Credit to OSS-Fuzz)
2019-02-08 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/png.c (ReadMNGImage): Quit processing and report error upon failure to insert MNG background layer. Fixes oss-fuzz 12738 "graphicsmagick/enhance_fuzzer: Out-of-memory in graphicsmagick_enhance_fuzzer". (Credit to OSS-Fuzz)
2019-02-03 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/dib.c (ReadDIBImage, WriteDIBImage): Improve buffer-size calculations to guard against buffer overflows. The reader version was not as complete as it should have been, whereas the writer version did not guard against arithmetic overflow at all.
coders/bmp.c (ReadBMPImage, WriteBMPImage): Improve buffer-size calculations to guard against buffer overflows. This is a follow-on fix to the previous fix submitted for SourceForge issue #582 "heap-buffer-overflow in ReadBMPImage of bmp.c" which is now also identified as CVE-2018-20185.
www/Hg.rst: Updates to reflect current usage and availability.
www/authors.rst: Promote Troy Patteson to the active contributor category.
2019-02-01 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/version.h.in: Rotate ChangeLog and update copyright statements for the new year.
2019-01-30 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
coders/webp.c (WriteWEBPImage): Patch by Przemysław Sobala to support WebP 'use_sharp_yuv' option ("if needed, use sharp (and slow) RGB->YUV conversion") via -define webp:use-sharp-yuv=true.
2019-01-05 Bob Friesenhahn <bfriesen@simple.dallas.tx.us>
magick/pixel_cache.c (SetNexus): Merge IsNexusInCore() implementation code into SetNexus() and add check for if cache_info->pixels is null. Fixes SourceForge issue #588 "Bug in IsNexusInCore()".
configure.ac (DcrawExtraOptions): Request TIFF output from dcraw if build supports TIFF format in order to obtain more metadata. This allows obtaining some metadata from standard TIFF tags (e.g. camera make, model, and dcraw version), and any attached ICC profile, but not specifically EXIF data since we don't support extracting EXIF data from TIFF yet. Inspired by SourceForge issue 589 "Identify lack of data (no Exif) in RAW formats".