diff options
Diffstat (limited to 'media-gfx/pngcrush')
-rw-r--r-- | media-gfx/pngcrush/Manifest | 3 | ||||
-rw-r--r-- | media-gfx/pngcrush/files/pngcrush-1.6.7-modified_debian_patchset_1.patch | 6072 | ||||
-rw-r--r-- | media-gfx/pngcrush/pngcrush-1.6.7.ebuild | 35 |
3 files changed, 0 insertions, 6110 deletions
diff --git a/media-gfx/pngcrush/Manifest b/media-gfx/pngcrush/Manifest index a8a50ffea516..18baf207a173 100644 --- a/media-gfx/pngcrush/Manifest +++ b/media-gfx/pngcrush/Manifest @@ -1,8 +1,5 @@ AUX pngcrush-1.6.10-makefile_and_missing_definitions.patch 2446 RMD160 18978c36dc64b8b90f1e23d597ac6f589bdac394 SHA1 f5055658b2ddb900fa4e1211728b30b52ccf7303 SHA256 a48005421df2e2c389357ec11fdb7aa6580c96cfa736701654dd87270b20720f -AUX pngcrush-1.6.7-modified_debian_patchset_1.patch 241476 RMD160 ee5e86e6235effbfbbdd4dada83576ba2ab91cca SHA1 b6918854e71ca14384bc01c22ec58a2637c20e29 SHA256 d5d64ac6487f1bdaf3cfd4ac25cf3e052680c88a6c1b567a4b3c888ca91a4219 DIST pngcrush-1.6.10-nolib.tar.bz2 42633 RMD160 92466d6bde526e77f826b4ec7589f132c525ea39 SHA1 4b3d6450d776e53408960fba9de7661b3e3e99cc SHA256 05dd4de676ec516a9d4c2c8cfd5a201e30e292916779a42db230c62e5ae32892 -DIST pngcrush_1.6.7.orig.tar.gz 50623 RMD160 0a8089595ee997b1daedd1e0f85448018b3f94a8 SHA1 13f9f518d253798c3c3694e5ec682361d31f0136 SHA256 4a4457dd9bb3036fdcc6edfe538ffca6a6834c5e08a33d301598171ed89b7f69 EBUILD pngcrush-1.6.10.ebuild 793 RMD160 4357dded345fbcf6ad720fa4717c7b18bdfa38d1 SHA1 34fdc2b5ea92f50a8ce966481e3c3bece37b89ab SHA256 14e3d799949f6c064549adfaa9d0f433b8838468e048738cbb1389f1dfa68964 -EBUILD pngcrush-1.6.7.ebuild 860 RMD160 39f88ee331164fdf2ba16cecd5449d7d17435757 SHA1 e377a26d20ca45bd476ad70716a7e8edf5888385 SHA256 b7e32123e3834d157bba3c80a58b86fd256fde57e6416c7d084f1d7667e3a37f MISC ChangeLog 4820 RMD160 af71ef3350f3ad6f13c9daf7de7cf30a40f434c0 SHA1 722e7bdfb3678c5886cb2ac2e3b18a210675f2d9 SHA256 e20994431864c8bbb884fe5db62c5c608f099971e67ea8db34e5363a83f2a4d9 MISC metadata.xml 161 RMD160 60f70b15d67f0e6aafc59833b2f0a30e30b51765 SHA1 1c35398222ef7ed670c31965e42cca77fe4b1da6 SHA256 e8daadc5e27e3ef1148993b5b48d96e93bc36d798a1f416693f7f8c84be427e1 diff --git a/media-gfx/pngcrush/files/pngcrush-1.6.7-modified_debian_patchset_1.patch b/media-gfx/pngcrush/files/pngcrush-1.6.7-modified_debian_patchset_1.patch deleted file mode 100644 index eaa2328afa1d..000000000000 --- a/media-gfx/pngcrush/files/pngcrush-1.6.7-modified_debian_patchset_1.patch +++ /dev/null @@ -1,6072 +0,0 @@ -diff -ruN pngcrush-1.6.7-nolib.orig/Makefile pngcrush-1.6.7-nolib/Makefile ---- pngcrush-1.6.7-nolib.orig/Makefile 1970-01-01 02:00:00.000000000 +0200 -+++ pngcrush-1.6.7-nolib/Makefile 2008-07-30 23:01:16.000000000 +0300 -@@ -0,0 +1,69 @@ -+# Sample makefile for pngcrush using gcc and GNU make. -+# Glenn Randers-Pehrson -+# Last modified: 19 February 2005 -+# Kapil Hari Paranjape -+# Last modified: 12 June 2008 -+# -+# Invoke this makefile from a shell prompt in the usual way; for example: -+# -+# make -f Makefile -+# -+# This makefile builds a dynamically linked executable. -+ -+# macros -------------------------------------------------------------------- -+ -+GAS_VERSION := $(shell as --version | sed -n -e's/GNU assembler (.*) //p') -+ -+PNGINC = /usr/include -+ -+CC ?= gcc -+RM = rm -f -+ -+CFLAGS += -I. -Wall -+ -+O = .o -+E = -+ -+# additional defines -+DEFINES = -DPNG_USE_PNGGCCRD -DPNG_iCCP_SUPPORTED \ -+ -DPNG_iTXt_SUPPORTED -DPNG_USE_GLOBAL_ARRAYS \ -+ -DGAS_VERSION="\"${GAS_VERSION}\"" \ -+ -+PNGCRUSH = pngcrush -+ -+LIBS = -lpng -lz -+ -+OBJS = pngcrush$(O) -+ -+EXES = $(PNGCRUSH)$(E) -+ -+ -+# implicit make rules ------------------------------------------------------- -+ -+.c$(O): png.h cexcept.h $(ZHDR) -+ $(CC) -c $(CFLAGS) $(DEFINES) $< -+ -+ -+# dependencies -------------------------------------------------------------- -+ -+all: $(EXES) -+ -+png.h: -+ ln -s $(PNGINC)/png.h png.h -+ -+pngcrush$(O): pngcrush.c cexcept.h -+ $(CC) -c $(CFLAGS) $(DEFINES) $< -+ -+$(PNGCRUSH)$(E): $(OBJS) -+ $(CC) $(LDFLAGS) -o $@ $(OBJS) $(LIBS) -+ -+# maintenance --------------------------------------------------------------- -+ -+clean: -+ $(RM) $(EXES) $(OBJS) png.h -+ -+install: -+ mkdir -p $(DESTDIR)/usr/bin/ -+ cp $(PNGCRUSH)$(E) $(DESTDIR)/usr/bin/ -+ chmod 0755 $(DESTDIR)/usr/bin/$(PNGCRUSH)$(E) -+ -diff -ruN pngcrush-1.6.7-nolib.orig/pngcrush.c pngcrush-1.6.7-nolib/pngcrush.c ---- pngcrush-1.6.7-nolib.orig/pngcrush.c 2008-06-13 04:50:52.000000000 +0300 -+++ pngcrush-1.6.7-nolib/pngcrush.c 2008-07-30 22:54:19.000000000 +0300 -@@ -303,6 +303,11 @@ - ((png_uint_32) 116 )) - #endif - -+PNG_EXPORT_VAR (const png_byte FARDATA) png_IHDR[5]; -+PNG_EXPORT_VAR (const png_byte FARDATA) png_IDAT[5]; -+PNG_EXPORT_VAR (const png_byte FARDATA) png_IEND[5]; -+PNG_EXPORT_VAR (const png_byte FARDATA) png_iCCP[5]; -+ - #define PNG_FLAG_CRC_CRITICAL_USE 0x0400 - #define PNG_FLAG_CRC_CRITICAL_IGNORE 0x0800 - #define PNG_FLAG_CRC_ANCILLARY_USE 0x0100 -@@ -1569,13 +1574,6 @@ - do_color_count = do_color_count; /* silence compiler warning */ - #endif - -- if (strcmp(png_libpng_ver, PNG_LIBPNG_VER_STRING)) { -- fprintf(STDERR, -- "Warning: versions are different between png.h and png.c\n"); -- fprintf(STDERR, " png.h version: %s\n", PNG_LIBPNG_VER_STRING); -- fprintf(STDERR, " png.c version: %s\n\n", png_libpng_ver); -- } -- - t_start = (TIME_T) clock(); - - strncpy(prog_string, argv[0], STR_BUF_SIZE); -@@ -2035,7 +2033,7 @@ - if (!strncmp(argv[i], "-zi", 3)) { - text_compression[text_inputs] = - PNG_ITXT_COMPRESSION_zTXt; -- names += 2; -+ /* names += 2; */ - } else - #endif - if (!strncmp(argv[i], "-z", 2)) -@@ -2048,7 +2046,7 @@ - else { - text_compression[text_inputs] = - PNG_ITXT_COMPRESSION_NONE; -- names += 2; -+ /* names += 2; */ - } - #endif - names += 3; -@@ -2062,6 +2060,10 @@ - text_lang[text_inputs * 80] = '\0'; - text_lang_key[text_inputs * 80] = '\0'; - } else { -+ i += 2; -+ BUMP_I; -+ i -= 3; -+ names += 2; - strcpy(&text_lang[text_inputs * 80], argv[++i]); - /* libpng-1.0.5j and later */ - strcpy(&text_lang_key[text_inputs * 80], argv[++i]); -@@ -4698,7 +4700,7 @@ - - for (;;) { - #ifndef PNG_UINT_IDAT --#ifdef PNG_USE_LOCAL_ARRAYS -+#if defined(PNG_USE_LOCAL_ARRAYS) || defined(PNGCRUSH_USE_LOCAL_ARRAYS) - PNG_IDAT; - PNG_IEND; - PNG_IHDR; -@@ -5452,6 +5454,12 @@ - PNGCRUSH_VERSION, progname, PNG_LIBPNG_VER_STRING, - png_get_header_version(NULL), ZLIB_VERSION); - -+ if (strcmp(png_libpng_ver, PNG_LIBPNG_VER_STRING)) { -+ fprintf(STDERR, "|| Warning: versions are different between png.h and png.c\n"); -+ fprintf(STDERR, "|| png.h version: %s\n", PNG_LIBPNG_VER_STRING); -+ fprintf(STDERR, "|| png.c version: %s\n\n", png_libpng_ver); -+ } -+ - #if defined(__GNUC__) - fprintf(STDERR, - " | It was compiled with gcc version %s", __VERSION__); -diff -ruN pngcrush-1.6.7-nolib.orig/pngcrush.c.orig pngcrush-1.6.7-nolib/pngcrush.c.orig ---- pngcrush-1.6.7-nolib.orig/pngcrush.c.orig 1970-01-01 02:00:00.000000000 +0200 -+++ pngcrush-1.6.7-nolib/pngcrush.c.orig 2008-07-30 22:54:14.000000000 +0300 -@@ -0,0 +1,5915 @@ -+/* pngcrush.c - recompresses png files -+ * Copyright (C) 1998-2002,2006-2008 Glenn Randers-Pehrson (glennrp@users.sf.net) -+ * Copyright (C) 2005 Greg Roelofs -+ * -+ * The most recent version of pngcrush can be found at SourceForge in -+ * http://pmt.sf.net/pngcrush/ -+ * -+ * This program reads in a PNG image, and writes it out again, with the -+ * optimum filter_method and zlib_level. It uses brute force (trying -+ * filter_method none, and libpng adaptive filtering, with compression -+ * levels 3 and 9). It does the most time-consuming method last in case -+ * it turns out to be the best. -+ * -+ * Optionally, it can remove unwanted chunks or add gAMA, sRGB, bKGD, -+ * tEXt/zTXt, and tRNS chunks. It will remove some chunks such as gAMA, -+ * cHRM, pHYs, and oFFs when their data fields contain all zero, which is a -+ * mistake. -+ * -+ * Uses libpng and zlib. This program was based upon libpng's pngtest.c. -+ * -+ * Thanks to Greg Roelofs for various bug fixes, suggestions, and -+ * occasionally creating Linux executables. -+ * -+ * Thanks to Stephan Levavej for some helpful suggestions about gcc compiler -+ * options and for a suggestion to increase the Z_MEM_LEVEL from default. -+ * -+ */ -+ -+#define PNGCRUSH_VERSION "1.6.6" -+ -+/* -+#define PNGCRUSH_COUNT_COLORS -+*/ -+ -+/* -+ * COPYRIGHT NOTICE, DISCLAIMER, AND LICENSE: -+ * -+ * If you have modified this source, you may insert additional notices -+ * immediately after this sentence. -+ * -+ * Copyright (C) 1998-2002,2006-2008 Glenn Randers-Pehrson (glennrp@users.sf.net) -+ * Copyright (C) 2005 Greg Roelofs -+ * -+ * The pngcrush computer program is supplied "AS IS". The Author disclaims all -+ * warranties, expressed or implied, including, without limitation, the -+ * warranties of merchantability and of fitness for any purpose. The -+ * Author assumes no liability for direct, indirect, incidental, special, -+ * exemplary, or consequential damages, which may result from the use of -+ * the computer program, even if advised of the possibility of such damage. -+ * There is no warranty against interference with your enjoyment of the -+ * computer program or against infringement. There is no warranty that my -+ * efforts or the computer program will fulfill any of your particular purposes -+ * or needs. This computer program is provided with all faults, and the entire -+ * risk of satisfactory quality, performance, accuracy, and effort is with -+ * the user. -+ * -+ * Permission is hereby irrevocably granted to everyone to use, copy, modify, -+ * and distribute this source code, or portions hereof, or executable programs -+ * compiled from it, for any purpose, without payment of any fee, subject to -+ * the following restrictions: -+ * -+ * 1. The origin of this source code must not be misrepresented. -+ * -+ * 2. Altered versions must be plainly marked as such and must not be -+ * misrepresented as being the original source. -+ * -+ * 3. This Copyright notice, disclaimer, and license may not be removed -+ * or altered from any source or altered source distribution. -+ */ -+ -+/* To do: -+ * -+ * Reset CINFO to reflect decoder's required window size (instead of -+ * libz-1.1.3 encoder's required window size, which is 262 bytes larger). -+ * See discussion about zlib in png-list archives for April 2001. -+ * -+ * Add a "pcRu" ancillary chunk that keeps track of the best method, -+ * methods already tried, and whether "loco crushing" was effective. -+ * -+ * Try both transformed and untransformed colors when "-loco" is used. -+ * -+ * Check for unused alpha channel and ok-to-reduce-depth. -+ * Take care that sBIT and bKGD data aren't lost when reducing images -+ * from truecolor to grayscale. -+ * -+ * Rearrange palette to put most-used color first and transparent color -+ * second (see ImageMagick 5.1.1 and later). -+ * -+ * Finish pplt (partial palette) feature. -+ * -+ * add "-time" directive -+ * -+ * Allow in-place file replacement or as a filter, as in -+ * "pngcrush -overwrite file.png" -+ * "pngcreator | pngcrush > output.png" -+ * -+ * Use an alternate write function for the trial passes, that -+ * simply counts bytes rather than actually writing to a file, to save wear -+ * and tear on disk drives. -+ * -+ * Remove text-handling and color-handling features and put -+ * those in a separate program or programs, to avoid unnecessary -+ * recompressing. -+ * -+ * Move the Photoshop-fixing stuff into a separate program. -+ * -+ * GRR: More generally (superset of previous 3 items): split into separate -+ * "edit" and "crush" programs (or functions). Former is fully libpng- -+ * aware, much like current pngcrush; latter makes little or no use of -+ * libpng (maybe IDAT-compression parts only?), instead handling virtually -+ * all chunks as opaque binary blocks that are copied to output file _once_, -+ * with IDATs alone replaced (either by best in-memory result or by original -+ * _data_ resplit into bigger IDATs, if pngcrush can't match/beat). "edit" -+ * version should be similar to current code but more efficient: make -+ * _one_ pass through args list, creating table of PNG_UINTs for removal; -+ * then make initial pass through PNG image, creating (in-order) table of -+ * all chunks (and byte offsets?) and marking each as "keep" or "remove" -+ * according to args table. Can start with static table of ~20-30 slots, -+ * then double size & copy if run out of room: still O(n) algorithm. -+ */ -+ -+#include "png.h" -+ -+/* internal libpng macros */ -+ -+ -+#ifdef PNG_LIBPNG_VER -+#define PNGCRUSH_LIBPNG_VER PNG_LIBPNG_VER -+#else -+/* This must agree with PNG_LIBPNG_VER; you have to define it manually -+ here if you are using libpng-1.0.6h or earlier */ -+#define PNGCRUSH_LIBPNG_VER 10007 -+#endif -+ -+/* Changed in version 0.99 */ -+#if PNGCRUSH_LIBPNG_VER < 99 -+#undef PNG_CONST -+#ifndef PNG_NO_CONST -+# define PNG_CONST const -+#else -+# define PNG_CONST -+#endif -+#endif -+ -+#define PNG_IDAT const png_byte png_IDAT[5] = { 73, 68, 65, 84, '\0'} -+#define PNG_IHDR const png_byte png_IHDR[5] = { 73, 72, 68, 82, '\0'} -+#define PNG_dSIG const png_byte png_dSIG[5] = {100, 83, 73, 71, '\0'} -+#define PNG_iCCP const png_byte png_iCCP[5] = {105, 67, 67, 80, '\0'} -+#define PNG_IEND const png_byte png_IEND[5] = { 73, 69, 78, 68, '\0'} -+ -+/* GRR 20050220: added these, which apparently aren't defined anywhere else */ -+#ifndef PNG_UINT_IHDR -+# define PNG_UINT_IHDR (((png_uint_32) 73<<24) | \ -+ ((png_uint_32) 72<<16) | \ -+ ((png_uint_32) 68<< 8) | \ -+ ((png_uint_32) 82 )) -+#endif -+ -+#ifndef PNG_UINT_IDAT -+# define PNG_UINT_IDAT (((png_uint_32) 73<<24) | \ -+ ((png_uint_32) 68<<16) | \ -+ ((png_uint_32) 65<< 8) | \ -+ ((png_uint_32) 84 )) -+#endif -+ -+#ifndef PNG_UINT_IEND -+# define PNG_UINT_IEND (((png_uint_32) 73<<24) | \ -+ ((png_uint_32) 69<<16) | \ -+ ((png_uint_32) 78<< 8) | \ -+ ((png_uint_32) 68 )) -+#endif -+ -+#ifndef PNG_UINT_PLTE -+# define PNG_UINT_PLTE (((png_uint_32) 80<<24) | \ -+ ((png_uint_32) 76<<16) | \ -+ ((png_uint_32) 84<< 8) | \ -+ ((png_uint_32) 69 )) -+#endif -+ -+#ifndef PNG_UINT_bKGD -+# define PNG_UINT_bKGD (((png_uint_32) 98<<24) | \ -+ ((png_uint_32) 75<<16) | \ -+ ((png_uint_32) 71<< 8) | \ -+ ((png_uint_32) 68 )) -+#endif -+ -+#ifndef PNG_UINT_cHRM -+# define PNG_UINT_cHRM (((png_uint_32) 99<<24) | \ -+ ((png_uint_32) 72<<16) | \ -+ ((png_uint_32) 82<< 8) | \ -+ ((png_uint_32) 77 )) -+#endif -+ -+#ifndef PNG_UINT_dSIG -+# define PNG_UINT_dSIG (((png_uint_32) 100<<24) | \ -+ ((png_uint_32) 83<<16) | \ -+ ((png_uint_32) 73<< 8) | \ -+ ((png_uint_32) 71 )) -+#endif -+ -+#ifndef PNG_UINT_gAMA -+# define PNG_UINT_gAMA (((png_uint_32) 103<<24) | \ -+ ((png_uint_32) 65<<16) | \ -+ ((png_uint_32) 77<< 8) | \ -+ ((png_uint_32) 65 )) -+#endif -+ -+#ifndef PNG_UINT_hIST -+# define PNG_UINT_hIST (((png_uint_32) 104<<24) | \ -+ ((png_uint_32) 73<<16) | \ -+ ((png_uint_32) 83<< 8) | \ -+ ((png_uint_32) 84 )) -+#endif -+ -+#ifndef PNG_UINT_iCCP -+# define PNG_UINT_iCCP (((png_uint_32) 105<<24) | \ -+ ((png_uint_32) 67<<16) | \ -+ ((png_uint_32) 67<< 8) | \ -+ ((png_uint_32) 80 )) -+#endif -+ -+#ifndef PNG_UINT_iTXt -+# define PNG_UINT_iTXt (((png_uint_32) 105<<24) | \ -+ ((png_uint_32) 84<<16) | \ -+ ((png_uint_32) 88<< 8) | \ -+ ((png_uint_32) 116 )) -+#endif -+ -+#ifndef PNG_UINT_oFFs -+# define PNG_UINT_oFFs (((png_uint_32) 111<<24) | \ -+ ((png_uint_32) 70<<16) | \ -+ ((png_uint_32) 70<< 8) | \ -+ ((png_uint_32) 115 )) -+#endif -+ -+#ifndef PNG_UINT_pCAL -+# define PNG_UINT_pCAL (((png_uint_32) 112<<24) | \ -+ ((png_uint_32) 67<<16) | \ -+ ((png_uint_32) 65<< 8) | \ -+ ((png_uint_32) 76 )) -+#endif -+ -+#ifndef PNG_UINT_pHYs -+# define PNG_UINT_pHYs (((png_uint_32) 112<<24) | \ -+ ((png_uint_32) 72<<16) | \ -+ ((png_uint_32) 89<< 8) | \ -+ ((png_uint_32) 115 )) -+#endif -+ -+#ifndef PNG_UINT_sBIT -+# define PNG_UINT_sBIT (((png_uint_32) 115<<24) | \ -+ ((png_uint_32) 66<<16) | \ -+ ((png_uint_32) 73<< 8) | \ -+ ((png_uint_32) 84 )) -+#endif -+ -+#ifndef PNG_UINT_sCAL -+# define PNG_UINT_sCAL (((png_uint_32) 115<<24) | \ -+ ((png_uint_32) 67<<16) | \ -+ ((png_uint_32) 65<< 8) | \ -+ ((png_uint_32) 76 )) -+#endif -+ -+#ifndef PNG_UINT_sPLT -+# define PNG_UINT_sPLT (((png_uint_32) 115<<24) | \ -+ ((png_uint_32) 80<<16) | \ -+ ((png_uint_32) 76<< 8) | \ -+ ((png_uint_32) 84 )) -+#endif -+ -+#ifndef PNG_UINT_sRGB -+# define PNG_UINT_sRGB (((png_uint_32) 115<<24) | \ -+ ((png_uint_32) 82<<16) | \ -+ ((png_uint_32) 71<< 8) | \ -+ ((png_uint_32) 66 )) -+#endif -+ -+#ifndef PNG_UINT_tEXt -+# define PNG_UINT_tEXt (((png_uint_32) 116<<24) | \ -+ ((png_uint_32) 69<<16) | \ -+ ((png_uint_32) 88<< 8) | \ -+ ((png_uint_32) 116 )) -+#endif -+ -+#ifndef PNG_UINT_tIME -+# define PNG_UINT_tIME (((png_uint_32) 116<<24) | \ -+ ((png_uint_32) 73<<16) | \ -+ ((png_uint_32) 77<< 8) | \ -+ ((png_uint_32) 69 )) -+#endif -+ -+#ifndef PNG_UINT_tRNS -+# define PNG_UINT_tRNS (((png_uint_32) 116<<24) | \ -+ ((png_uint_32) 82<<16) | \ -+ ((png_uint_32) 78<< 8) | \ -+ ((png_uint_32) 83 )) -+#endif -+ -+#ifndef PNG_UINT_zTXt -+# define PNG_UINT_zTXt (((png_uint_32) 122<<24) | \ -+ ((png_uint_32) 84<<16) | \ -+ ((png_uint_32) 88<< 8) | \ -+ ((png_uint_32) 116 )) -+#endif -+ -+PNG_EXPORT_VAR (const png_byte FARDATA) png_IHDR[5]; -+PNG_EXPORT_VAR (const png_byte FARDATA) png_IDAT[5]; -+PNG_EXPORT_VAR (const png_byte FARDATA) png_IEND[5]; -+PNG_EXPORT_VAR (const png_byte FARDATA) png_iCCP[5]; -+ -+#define PNG_FLAG_CRC_CRITICAL_USE 0x0400 -+#define PNG_FLAG_CRC_CRITICAL_IGNORE 0x0800 -+#define PNG_FLAG_CRC_ANCILLARY_USE 0x0100 -+#define PNG_FLAG_CRC_ANCILLARY_NOWARN 0x0200 -+#define PNG_FLAG_CRC_CRITICAL_USE 0x0400 -+#define PNG_FLAG_CRC_CRITICAL_IGNORE 0x0800 -+#define PNG_FLAG_CRC_ANCILLARY_MASK (PNG_FLAG_CRC_ANCILLARY_USE | \ -+ PNG_FLAG_CRC_ANCILLARY_NOWARN) -+#define PNG_PACK 0x0004 -+#define PNG_DITHER 0x0040 -+#define PNG_BACKGROUND 0x0080 -+#define PNG_16_TO_8 0x0400 -+#define PNG_RGBA 0x0800 -+#define PNG_EXPAND 0x1000 -+#define PNG_GAMMA 0x2000 -+#define PNG_GRAY_TO_RGB 0x4000 -+#define PNG_FILLER 0x8000L -+#define PNG_USER_TRANSFORM 0x100000L -+#define PNG_RGB_TO_GRAY 0x600000L /* two bits, RGB_TO_GRAY_ERR|WARN */ -+ -+/* we don't need some of the extra libpng transformations -+ * so they are ifdef'ed out in pngcrush.h, which is included by -+ * libpng's pngconf.h which is included by png.h */ -+ -+/* defined so I can write to a file on gui/windowing platforms */ -+/* #define STDERR stderr */ -+#define STDERR stdout /* for DOS */ -+ -+#ifndef PNGCRUSH_LIBPNG_VER -+# define PNGCRUSH_LIBPNG_VER PNG_LIBPNG_VER -+#endif -+ -+#ifdef PNG_MNG_FEATURES_SUPPORTED -+# define PNGCRUSH_LOCO -+#endif -+ -+#ifndef PNG_UINT_31_MAX -+#define PNG_UINT_31_MAX ((png_uint_32)0x7fffffffL) -+#endif -+ -+/* These macros were renamed in libpng-1.2.6 */ -+#ifndef PNG_HANDLE_CHUNK_ALWAYS -+#define PNG_HANDLE_CHUNK_ALWAYS HANDLE_CHUNK_ALWAYS -+#define PNG_HANDLE_CHUNK_NEVER HANDLE_CHUNK_NEVER -+#define PNG_HANDLE_CHUNK_IF_SAFE HANDLE_CHUNK_IF_SAFE -+#endif -+ -+#if defined(__DJGPP__) -+# if ((__DJGPP__ == 2) && (__DJGPP_MINOR__ == 0)) -+# include <libc/dosio.h> /* for _USE_LFN, djgpp 2.0 only */ -+# endif -+# define SLASH "\\" -+# define DOT "." -+#else -+# ifdef __riscos -+# define SLASH "." -+# define DOT "/" -+# else -+# define SLASH "/" -+# define DOT "." -+# endif -+#endif -+ -+#ifndef GAS_VERSION -+# define GAS_VERSION "2.9.5(?)" /* used only in help/usage screen */ -+#endif -+ -+#if !defined(__TURBOC__) && !defined(_MSC_VER) && !defined(_MBCS) && \ -+ !defined(__riscos) -+# include <unistd.h> -+#endif -+ -+#ifndef __riscos -+# include <sys/types.h> -+# include <sys/stat.h> -+# include <utime.h> -+#endif -+ -+#include <stdio.h> -+#include <stdlib.h> -+#include <time.h> -+#include <assert.h> -+ -+#if defined(_MBCS) || defined(WIN32) || defined(__WIN32__) -+# include <direct.h> -+#endif -+ -+#define DEFAULT_MODE 0 -+#define DIRECTORY_MODE 1 -+#define EXTENSION_MODE 2 -+#define DIREX_MODE 3 -+#define FOPEN(file, how) fopen(file, how) -+#define FCLOSE(file) {fclose(file); file=NULL;--number_of_open_files;}; -+ -+#define P0 if(first_trial && verbose > 0)printf -+#define P1 if(verbose > 1)printf -+#define P2 if(verbose > 2)printf -+ -+#define STRNGIFY_STAGE1(x) #x -+#define STRNGIFY(x) STRNGIFY_STAGE1(x) -+ -+#define STR_BUF_SIZE 256 -+#define MAX_IDAT_SIZE 524288L -+#define MAX_METHODS 200 -+#define MAX_METHODSP1 (MAX_METHODS+1) -+#define DEFAULT_METHODS 10 -+#define FAKE_PAUSE_STRING "P" -+ -+#ifdef Z_RLE -+# define NUM_STRATEGIES 4 -+#else -+# define NUM_STRATEGIES 3 -+#endif -+ -+#ifdef __TURBOC__ -+# include <mem.h> -+#endif -+ -+#ifndef CLOCKS_PER_SEC -+#define CLOCKS_PER_SEC 1000 -+#endif -+ -+#if CLOCKS_PER_SEC <= 100 -+# define TIME_T long -+#else -+# define TIME_T float -+#endif -+ -+struct options_help { -+ int verbosity; /* if verbose >= this value, then print line */ -+ const char *textline; /* static string with newline chopped off */ -+}; -+ -+/* input and output filenames */ -+static PNG_CONST char *progname; -+static PNG_CONST char *inname = "pngtest" DOT "png"; -+static PNG_CONST char *outname = "pngout" DOT "png"; -+static PNG_CONST char *mngname = "mngout" DOT "mng"; -+static PNG_CONST char *directory_name = "pngcrush" DOT "bak"; -+static PNG_CONST char *extension = "_C" DOT "png"; -+ -+static png_uint_32 width, height; -+static png_uint_32 measured_idat_length; -+static int found_gAMA = 0; -+static int found_cHRM = 0; -+static int found_any_chunk = 0; -+static int image_is_immutable = 0; -+static int pngcrush_must_exit = 0; -+static int all_chunks_are_safe = 0; -+static int number_of_open_files; -+static int do_pplt = 0; -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+static png_uint_32 max_rows_at_a_time = 1; -+static png_uint_32 rows_at_a_time; -+#endif -+char pplt_string[1024]; -+char *ip, *op, *dot; -+char in_string[STR_BUF_SIZE]; -+char prog_string[STR_BUF_SIZE]; -+char out_string[STR_BUF_SIZE]; -+char in_extension[STR_BUF_SIZE]; -+static int text_inputs = 0; -+int text_where[10]; /* 0: no text; 1: before PLTE; 2: after PLTE */ -+int text_compression[10]; /* -1: uncompressed tEXt; 0: compressed zTXt -+ 1: uncompressed iTXt; 2: compressed iTXt */ -+char text_text[20480]; /* It would be nice to png_malloc this, but we -+ * don't have a png_ptr yet when we need it. */ -+char text_keyword[800]; -+ -+/* PNG_iTXt_SUPPORTED */ -+char text_lang[800]; -+char text_lang_key[800]; -+ -+/* PNG_iCCP_SUPPORTED */ -+int iccp_length = 0; -+char *iccp_text; -+char *iccp_file; -+char iccp_name[80]; -+ -+int best; -+ -+char buffer[256]; -+ -+/* Set up the "cexcept" Try/Throw/Catch exception handler. */ -+#include "cexcept.h" -+define_exception_type(const char *); -+extern struct exception_context the_exception_context[1]; -+struct exception_context the_exception_context[1]; -+png_const_charp msg; -+ -+static png_uint_32 total_input_length = 0; -+static png_uint_32 total_output_length = 0; -+static int pngcrush_mode = DEFAULT_MODE; -+static int resolution = 0; -+static int remove_chunks = 0; -+static int output_color_type; -+static int output_bit_depth; -+static int force_output_color_type = 8; -+static int force_output_bit_depth = 0; -+static int input_color_type; -+static int input_bit_depth; -+static int trial; -+static int first_trial = 0; -+static int verbose = 1; -+static int fix = 0; -+static int things_have_changed = 0; -+static int global_things_have_changed = 0; -+static int default_compression_window = 15; -+static int force_compression_window = 0; -+static int compression_mem_level = 9; -+static int final_method = 0; -+static int brute_force = 0; -+static int brute_force_level = 0; -+static int brute_force_filter = 0; -+static int brute_force_strategy = 0; -+static int brute_force_levels[10] = { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 }; -+static int brute_force_filters[6] = { 1, 1, 1, 1, 1, 1 }; -+#ifdef Z_RLE -+static int brute_force_strategies[NUM_STRATEGIES] = { 1, 1, 1, 1 }; -+#else -+static int brute_force_strategies[NUM_STRATEGIES] = { 1, 1, 1 }; -+#endif -+static int method = 10; -+static int pauses = 0; -+static int nosave = 0; -+static int nofilecheck = 0; -+#ifdef PNGCRUSH_LOCO -+static int new_mng = 0; -+#endif -+static png_bytep row_buf; -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+static png_bytepp row_pointers; -+#endif -+static int z_strategy; -+static int best_of_three; -+static int methods_specified = 0; -+static int intent = -1; -+static int plte_len = -1; -+#ifdef PNG_FIXED_POINT_SUPPORTED -+static int specified_gamma = 0; -+static int image_specified_gamma = 0; -+static int force_specified_gamma = 0; -+#else -+static double specified_gamma = 0.0; -+static double image_specified_gamma = 0; -+static double force_specified_gamma = 0.0; -+#endif -+static int double_gamma = 0; -+ -+static int names; -+ -+static int have_trns = 0; -+static png_uint_16 trns_index = 0; -+static png_uint_16 trns_red = 0; -+static png_uint_16 trns_green = 0; -+static png_uint_16 trns_blue = 0; -+static png_uint_16 trns_gray = 0; -+ -+static png_byte trns_array[256]; -+static png_byte trans_in[256]; -+static png_uint_16 num_trans_in; -+ -+static int have_bkgd = 0; -+static png_uint_16 bkgd_red = 0; -+static png_uint_16 bkgd_green = 0; -+static png_uint_16 bkgd_blue = 0; -+ -+static png_colorp palette; -+static int num_palette; -+ -+#ifdef REORDER_PALETTE -+static png_byte palette_reorder[256]; -+#endif -+ -+static png_structp read_ptr, write_ptr, mng_ptr; -+static png_infop read_info_ptr, write_info_ptr; -+static png_infop end_info_ptr; -+static png_infop write_end_info_ptr; -+static FILE *fpin, *fpout, *mng_out; -+png_uint_32 measure_idats(FILE * fpin); -+#ifdef PNGCRUSH_LOCO -+static int do_loco = 0; -+static int input_format = 0; /* 0: PNG 1: MNG */ -+static int output_format = 0; -+#endif -+static int do_color_count; -+static int reduction_ok = 0; -+#ifdef PNGCRUSH_COUNT_COLORS -+int count_colors(FILE * fpin); -+static int num_rgba, reduce_to_gray, it_is_opaque; -+#endif -+png_uint_32 png_measure_idat(png_structp png_ptr); -+ -+static png_uint_32 idat_length[MAX_METHODSP1]; -+static int filter_type, zlib_level; -+static png_bytep png_row_filters = NULL; -+static float t_start, t_stop, t_decode, t_encode, t_misc; -+ -+static png_uint_32 max_idat_size = MAX_IDAT_SIZE; /* increases the IDAT size */ -+static png_uint_32 crushed_idat_size = 0x3ffffffL; -+static int already_crushed = 0; -+int ia; -+ -+ -+/* prototypes */ -+static void png_cexcept_error(png_structp png_ptr, png_const_charp msg); -+ -+void PNGAPI png_default_read_data(png_structp png_ptr, png_bytep data, -+ png_size_t length); -+ -+void png_read_transform_info(png_structp png_ptr, png_infop info_ptr); -+ -+void PNGAPI png_default_write_data(png_structp png_ptr, png_bytep data, -+ png_size_t length); -+ -+void png_reset_crc(png_structp png_ptr); -+void png_calculate_crc(png_structp png_ptr, png_bytep ptr, png_size_t length); -+void png_crc_read(png_structp png_ptr, png_bytep buf, png_size_t length); -+int png_crc_error(png_structp png_ptr); -+int png_crc_finish(png_structp png_ptr, png_uint_32 skip); -+ -+png_uint_32 png_get_uint_31(png_structp png_ptr, png_bytep buf); -+png_uint_32 png_get_uint_32(png_bytep buf); -+void png_save_uint_32(png_bytep buf, png_uint_32 i); -+ -+#ifdef PNG_USER_MEM_SUPPORTED -+png_voidp png_debug_malloc(png_structp png_ptr, png_uint_32 size); -+void png_debug_free(png_structp png_ptr, png_voidp ptr); -+#endif -+ -+void png_crush_pause(void); -+ -+#ifdef __riscos -+static int fileexists(const char *name) -+static int filesize(const char *name) -+static int mkdir(const char *name, int ignored) -+static void setfiletype(const char *name) -+#endif -+ -+int keep_unknown_chunk(png_const_charp name, char *argv[]); -+int keep_chunk(png_const_charp name, char *argv[]); -+void show_result(void); -+png_uint_32 measure_idats(FILE * fpin); -+png_uint_32 png_measure_idat(png_structp png_ptr); -+ -+#ifdef PNGCRUSH_COUNT_COLORS -+int count_colors(FILE * fpin); -+#endif -+void print_version_info(void); -+void print_usage(int retval); -+ -+ -+#if (!defined(PNGCRUSH_H)) -+/* ============================================================ -+ * We aren't using the bundled libpng functions, so we must -+ * reproduce the libpng routines that aren't exported by libpng -+ * ============================================================ -+ */ -+ -+#ifndef PNG_READ_BIG_ENDIAN_SUPPORTED -+/* Grab an unsigned 32-bit integer from a buffer in big-endian format. */ -+png_uint_32 /* PRIVATE */ -+png_get_uint_32(png_bytep buf) -+{ -+ png_uint_32 i = ((png_uint_32)(*buf) << 24) + -+ ((png_uint_32)(*(buf + 1)) << 16) + -+ ((png_uint_32)(*(buf + 2)) << 8) + -+ (png_uint_32)(*(buf + 3)); -+ -+ return (i); -+} -+#else -+# define png_get_uint_32(buf) ( *((png_uint_32p) (buf))) -+#endif -+png_uint_32 /* PRIVATE */ -+png_get_uint_31(png_structp png_ptr, png_bytep buf) -+{ -+ png_uint_32 i = png_get_uint_32(buf); -+ if (i > PNG_UINT_31_MAX) -+ png_error(png_ptr, "PNG unsigned integer out of range.\n"); -+ return (i); -+} -+void /* PRIVATE */ -+png_save_uint_32(png_bytep buf, png_uint_32 i) -+{ -+ buf[0] = (png_byte)((i >> 24) & 0xff); -+ buf[1] = (png_byte)((i >> 16) & 0xff); -+ buf[2] = (png_byte)((i >> 8) & 0xff); -+ buf[3] = (png_byte)(i & 0xff); -+} -+ -+/* Reset the CRC variable to 32 bits of 1's. Care must be taken -+ * in case CRC is > 32 bits to leave the top bits 0. -+ */ -+void /* PRIVATE */ -+png_reset_crc(png_structp png_ptr) -+{ -+ png_ptr->crc = crc32(0, Z_NULL, 0); -+} -+/* Calculate the CRC over a section of data. We can only pass as -+ * much data to this routine as the largest single buffer size. We -+ * also check that this data will actually be used before going to the -+ * trouble of calculating it. -+ */ -+void /* PRIVATE */ -+png_calculate_crc(png_structp png_ptr, png_bytep ptr, png_size_t length) -+{ -+ int need_crc = 1; -+ -+ if (png_ptr->chunk_name[0] & 0x20) /* ancillary */ -+ { -+ if ((png_ptr->flags & PNG_FLAG_CRC_ANCILLARY_MASK) == -+ (PNG_FLAG_CRC_ANCILLARY_USE | PNG_FLAG_CRC_ANCILLARY_NOWARN)) -+ need_crc = 0; -+ } -+ else /* critical */ -+ { -+ if (png_ptr->flags & PNG_FLAG_CRC_CRITICAL_IGNORE) -+ need_crc = 0; -+ } -+ -+ if (need_crc) -+ png_ptr->crc = crc32(png_ptr->crc, ptr, (uInt)length); -+} -+ -+/* Read data, and (optionally) run it through the CRC. */ -+void /* PRIVATE */ -+png_crc_read(png_structp png_ptr, png_bytep buf, png_size_t length) -+{ -+ png_default_read_data(png_ptr, buf, length); -+ png_calculate_crc(png_ptr, buf, length); -+} -+ -+/* Compare the CRC stored in the PNG file with that calculated by libpng from -+ the data it has read thus far. */ -+int /* PRIVATE */ -+png_crc_error(png_structp png_ptr) -+{ -+ png_byte crc_bytes[4]; -+ png_uint_32 crc; -+ int need_crc = 1; -+ -+ if (png_ptr->chunk_name[0] & 0x20) /* ancillary */ -+ { -+ if ((png_ptr->flags & PNG_FLAG_CRC_ANCILLARY_MASK) == -+ (PNG_FLAG_CRC_ANCILLARY_USE | PNG_FLAG_CRC_ANCILLARY_NOWARN)) -+ need_crc = 0; -+ } -+ else /* critical */ -+ { -+ if (png_ptr->flags & PNG_FLAG_CRC_CRITICAL_IGNORE) -+ need_crc = 0; -+ } -+ -+ png_default_read_data(png_ptr, crc_bytes, 4); -+ -+ if (need_crc) -+ { -+ crc = png_get_uint_32(crc_bytes); -+ return ((int)(crc != png_ptr->crc)); -+ } -+ else -+ return (0); -+} -+ -+/* Optionally skip data and then check the CRC. Depending on whether we -+ are reading a ancillary or critical chunk, and how the program has set -+ things up, we may calculate the CRC on the data and print a message. -+ Returns '1' if there was a CRC error, '0' otherwise. */ -+int /* PRIVATE */ -+png_crc_finish(png_structp png_ptr, png_uint_32 skip) -+{ -+ png_size_t i; -+ png_size_t istop = png_ptr->zbuf_size; -+ -+ for (i = (png_size_t)skip; i > istop; i -= istop) -+ { -+ png_crc_read(png_ptr, png_ptr->zbuf, png_ptr->zbuf_size); -+ } -+ if (i) -+ { -+ png_crc_read(png_ptr, png_ptr->zbuf, i); -+ } -+ -+ if (png_crc_error(png_ptr)) -+ { -+ if (((png_ptr->chunk_name[0] & 0x20) && /* Ancillary */ -+ !(png_ptr->flags & PNG_FLAG_CRC_ANCILLARY_NOWARN)) || -+ (!(png_ptr->chunk_name[0] & 0x20) && /* Critical */ -+ (png_ptr->flags & PNG_FLAG_CRC_CRITICAL_USE))) -+ { -+ png_chunk_warning(png_ptr, "CRC error"); -+ } -+ else -+ { -+ png_chunk_error(png_ptr, "CRC error"); -+ } -+ return (1); -+ } -+ -+ return (0); -+} -+ -+/* Modify the info structure to reflect the transformations. The -+ * info should be updated so a PNG file could be written with it, -+ * assuming the transformations result in valid PNG data. -+ */ -+void /* PRIVATE */ -+png_read_transform_info(png_structp png_ptr, png_infop info_ptr) -+{ -+ png_debug(1, "in png_read_transform_info\n"); -+#if defined(PNG_READ_EXPAND_SUPPORTED) -+ if (png_ptr->transformations & PNG_EXPAND) -+ { -+ if (info_ptr->color_type == PNG_COLOR_TYPE_PALETTE) -+ { -+ if (png_ptr->num_trans) -+ info_ptr->color_type = PNG_COLOR_TYPE_RGB_ALPHA; -+ else -+ info_ptr->color_type = PNG_COLOR_TYPE_RGB; -+ info_ptr->bit_depth = 8; -+ info_ptr->num_trans = 0; -+ } -+ else -+ { -+ if (png_ptr->num_trans) -+ info_ptr->color_type |= PNG_COLOR_MASK_ALPHA; -+ if (info_ptr->bit_depth < 8) -+ info_ptr->bit_depth = 8; -+ info_ptr->num_trans = 0; -+ } -+ } -+#endif -+ -+#if defined(PNG_READ_BACKGROUND_SUPPORTED) -+ if (png_ptr->transformations & PNG_BACKGROUND) -+ { -+ info_ptr->color_type &= ~PNG_COLOR_MASK_ALPHA; -+ info_ptr->num_trans = 0; -+ info_ptr->background = png_ptr->background; -+ } -+#endif -+ -+#if defined(PNG_READ_GAMMA_SUPPORTED) -+ if (png_ptr->transformations & PNG_GAMMA) -+ { -+#ifdef PNG_FLOATING_POINT_SUPPORTED -+ info_ptr->gamma = png_ptr->gamma; -+#endif -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ info_ptr->int_gamma = png_ptr->int_gamma; -+#endif -+ } -+#endif -+ -+#if defined(PNG_READ_16_TO_8_SUPPORTED) -+ if ((png_ptr->transformations & PNG_16_TO_8) && (info_ptr->bit_depth == 16)) -+ info_ptr->bit_depth = 8; -+#endif -+ -+#if defined(PNG_READ_DITHER_SUPPORTED) -+ if (png_ptr->transformations & PNG_DITHER) -+ { -+ if (((info_ptr->color_type == PNG_COLOR_TYPE_RGB) || -+ (info_ptr->color_type == PNG_COLOR_TYPE_RGB_ALPHA)) && -+ png_ptr->palette_lookup && info_ptr->bit_depth == 8) -+ { -+ info_ptr->color_type = PNG_COLOR_TYPE_PALETTE; -+ } -+ } -+#endif -+ -+#if defined(PNG_READ_PACK_SUPPORTED) -+ if ((png_ptr->transformations & PNG_PACK) && (info_ptr->bit_depth < 8)) -+ info_ptr->bit_depth = 8; -+#endif -+ -+#if defined(PNG_READ_GRAY_TO_RGB_SUPPORTED) -+ if (png_ptr->transformations & PNG_GRAY_TO_RGB) -+ info_ptr->color_type |= PNG_COLOR_MASK_COLOR; -+#endif -+ -+#if defined(PNG_READ_RGB_TO_GRAY_SUPPORTED) -+ if (png_ptr->transformations & PNG_RGB_TO_GRAY) -+ info_ptr->color_type &= ~PNG_COLOR_MASK_COLOR; -+#endif -+ -+ if (info_ptr->color_type == PNG_COLOR_TYPE_PALETTE) -+ info_ptr->channels = 1; -+ else if (info_ptr->color_type & PNG_COLOR_MASK_COLOR) -+ info_ptr->channels = 3; -+ else -+ info_ptr->channels = 1; -+ -+#ifndef PNG_FLAG_ADD_ALPHA -+#define PNG_FLAG_ADD_ALPHA 0x200000L /* Added to libpng-1.2.8 */ -+#endif -+#ifndef PNG_FLAG_STRIP_ALPHA -+#define PNG_FLAG_STRIP_ALPHA 0x400000L /* Added to libpng-1.2.8 */ -+#endif -+#ifndef PNG_ADD_ALPHA -+#define PNG_ADD_ALPHA 0x1000000L /* Added to libpng-1.2.7 */ -+#endif -+ -+#if defined(PNG_READ_STRIP_ALPHA_SUPPORTED) -+ if (png_ptr->flags & PNG_FLAG_STRIP_ALPHA) -+ info_ptr->color_type &= ~PNG_COLOR_MASK_ALPHA; -+#endif -+ -+ if (info_ptr->color_type & PNG_COLOR_MASK_ALPHA) -+ info_ptr->channels++; -+ -+#if defined(PNG_READ_FILLER_SUPPORTED) -+ /* STRIP_ALPHA and FILLER allowed: MASK_ALPHA bit stripped above */ -+ if ((png_ptr->transformations & PNG_FILLER) && -+ ((info_ptr->color_type == PNG_COLOR_TYPE_RGB) || -+ (info_ptr->color_type == PNG_COLOR_TYPE_GRAY))) -+ { -+ info_ptr->channels++; -+ /* if adding a true alpha channel not just filler */ -+#if !defined(PNG_1_0_X) -+ if (png_ptr->transformations & PNG_ADD_ALPHA) -+ info_ptr->color_type |= PNG_COLOR_MASK_ALPHA; -+#endif -+ } -+#endif -+ -+#if defined(PNG_USER_TRANSFORM_PTR_SUPPORTED) && \ -+defined(PNG_READ_USER_TRANSFORM_SUPPORTED) -+ if(png_ptr->transformations & PNG_USER_TRANSFORM) -+ { -+ if(info_ptr->bit_depth < png_ptr->user_transform_depth) -+ info_ptr->bit_depth = png_ptr->user_transform_depth; -+ if(info_ptr->channels < png_ptr->user_transform_channels) -+ info_ptr->channels = png_ptr->user_transform_channels; -+ } -+#endif -+ -+ info_ptr->pixel_depth = (png_byte)(info_ptr->channels * -+ info_ptr->bit_depth); -+ -+#ifndef PNG_ROWBYTES -+/* Added to libpng-1.2.6 JB */ -+#define PNG_ROWBYTES(pixel_bits, width) \ -+ ((pixel_bits) >= 8 ? \ -+ ((width) * (((png_uint_32)(pixel_bits)) >> 3)) : \ -+ (( ((width) * ((png_uint_32)(pixel_bits))) + 7) >> 3) ) -+#endif -+ info_ptr->rowbytes = PNG_ROWBYTES(info_ptr->pixel_depth,info_ptr->width); -+ -+#if !defined(PNG_READ_EXPAND_SUPPORTED) -+ if(png_ptr) -+ return; -+#endif -+} -+ -+#if !defined(PNG_NO_STDIO) -+/* This is the function that does the actual reading of data. If you are -+ not reading from a standard C stream, you should create a replacement -+ read_data function and use it at run time with png_set_read_fn(), rather -+ than changing the library. */ -+#ifndef USE_FAR_KEYWORD -+void PNGAPI -+png_default_read_data(png_structp png_ptr, png_bytep data, png_size_t length) -+{ -+ png_size_t check; -+ -+ /* fread() returns 0 on error, so it is OK to store this in a png_size_t -+ * instead of an int, which is what fread() actually returns. -+ */ -+#if defined(_WIN32_WCE) -+ if ( !ReadFile((HANDLE)(png_ptr->io_ptr), data, length, &check, NULL) ) -+ check = 0; -+#else -+ check = (png_size_t)fread(data, (png_size_t)1, length, -+ (png_FILE_p)png_ptr->io_ptr); -+#endif -+ -+ if (check != length) -+ png_error(png_ptr, "Read Error"); -+} -+#else -+/* this is the model-independent version. Since the standard I/O library -+ can't handle far buffers in the medium and small models, we have to copy -+ the data. -+*/ -+ -+#define NEAR_BUF_SIZE 1024 -+#define MIN(a,b) (a <= b ? a : b) -+ -+static void /* PRIVATE */ -+png_default_read_data(png_structp png_ptr, png_bytep data, png_size_t length) -+{ -+ int check; -+ png_byte *n_data; -+ png_FILE_p io_ptr; -+ -+ /* Check if data really is near. If so, use usual code. */ -+ n_data = (png_byte *)CVT_PTR_NOCHECK(data); -+ io_ptr = (png_FILE_p)CVT_PTR(png_ptr->io_ptr); -+ if ((png_bytep)n_data == data) -+ { -+#if defined(_WIN32_WCE) -+ if ( !ReadFile((HANDLE)(png_ptr->io_ptr), data, length, &check, NULL) ) -+ check = 0; -+#else -+ check = fread(n_data, 1, length, io_ptr); -+#endif -+ } -+ else -+ { -+ png_byte buf[NEAR_BUF_SIZE]; -+ png_size_t read, remaining, err; -+ check = 0; -+ remaining = length; -+ do -+ { -+ read = MIN(NEAR_BUF_SIZE, remaining); -+#if defined(_WIN32_WCE) -+ if ( !ReadFile((HANDLE)(io_ptr), buf, read, &err, NULL) ) -+ err = 0; -+#else -+ err = fread(buf, (png_size_t)1, read, io_ptr); -+#endif -+ png_memcpy(data, buf, read); /* copy far buffer to near buffer */ -+ if(err != read) -+ break; -+ else -+ check += err; -+ data += read; -+ remaining -= read; -+ } -+ while (remaining != 0); -+ } -+ if ((png_uint_32)check != (png_uint_32)length) -+ png_error(png_ptr, "read Error"); -+} -+#endif -+#endif -+#if !defined(PNG_NO_STDIO) -+/* This is the function that does the actual writing of data. If you are -+ not writing to a standard C stream, you should create a replacement -+ write_data function and use it at run time with png_set_write_fn(), rather -+ than changing the library. */ -+#ifndef USE_FAR_KEYWORD -+void PNGAPI -+png_default_write_data(png_structp png_ptr, png_bytep data, png_size_t length) -+{ -+ png_uint_32 check; -+ -+#if defined(_WIN32_WCE) -+ if ( !WriteFile((HANDLE)(png_ptr->io_ptr), data, length, &check, NULL) ) -+ check = 0; -+#else -+ check = fwrite(data, 1, length, (png_FILE_p)(png_ptr->io_ptr)); -+#endif -+ if (check != length) -+ png_error(png_ptr, "Write Error"); -+} -+#else -+/* this is the model-independent version. Since the standard I/O library -+ can't handle far buffers in the medium and small models, we have to copy -+ the data. -+*/ -+ -+#define NEAR_BUF_SIZE 1024 -+#define MIN(a,b) (a <= b ? a : b) -+ -+void PNGAPI -+png_default_write_data(png_structp png_ptr, png_bytep data, png_size_t length) -+{ -+ png_uint_32 check; -+ png_byte *near_data; /* Needs to be "png_byte *" instead of "png_bytep" */ -+ png_FILE_p io_ptr; -+ -+ /* Check if data really is near. If so, use usual code. */ -+ near_data = (png_byte *)CVT_PTR_NOCHECK(data); -+ io_ptr = (png_FILE_p)CVT_PTR(png_ptr->io_ptr); -+ if ((png_bytep)near_data == data) -+ { -+#if defined(_WIN32_WCE) -+ if ( !WriteFile(io_ptr, near_data, length, &check, NULL) ) -+ check = 0; -+#else -+ check = fwrite(near_data, 1, length, io_ptr); -+#endif -+ } -+ else -+ { -+ png_byte buf[NEAR_BUF_SIZE]; -+ png_size_t written, remaining, err; -+ check = 0; -+ remaining = length; -+ do -+ { -+ written = MIN(NEAR_BUF_SIZE, remaining); -+ png_memcpy(buf, data, written); /* copy far buffer to near buffer */ -+#if defined(_WIN32_WCE) -+ if ( !WriteFile(io_ptr, buf, written, &err, NULL) ) -+ err = 0; -+#else -+ err = fwrite(buf, 1, written, io_ptr); -+#endif -+ if (err != written) -+ break; -+ else -+ check += err; -+ data += written; -+ remaining -= written; -+ } -+ while (remaining != 0); -+ } -+ if (check != length) -+ png_error(png_ptr, "Write Error"); -+} -+ -+#endif -+#endif -+ -+#endif /* !defined(PNGCRUSH_H) */ -+ -+ -+ -+/* cexcept interface */ -+ -+static void png_cexcept_error(png_structp png_ptr, png_const_charp msg) -+{ -+ if (png_ptr); -+#if (defined(PNGCRUSH_H)) -+ if (!strcmp(msg, "Too many IDAT's found")) { -+#ifndef PNG_NO_CONSOLE_IO -+ fprintf(stderr, "\nIn %s, correcting ", inname); -+#else -+ png_warning(png_ptr, msg); -+#endif -+ } else -+#endif /* defined(PNGCRUSH_H) */ -+ { -+ Throw msg; -+ } -+} -+ -+ -+ -+ -+/* START of code to validate memory allocation and deallocation */ -+#ifdef PNG_USER_MEM_SUPPORTED -+ -+/* Allocate memory. For reasonable files, size should never exceed -+ 64K. However, zlib may allocate more then 64K if you don't tell -+ it not to. See zconf.h and png.h for more information. zlib does -+ need to allocate exactly 64K, so whatever you call here must -+ have the ability to do that. -+ -+ This piece of code can be compiled to validate max 64K allocations -+ by setting MAXSEG_64K in zlib zconf.h *or* PNG_MAX_MALLOC_64K. */ -+typedef struct memory_information { -+ png_uint_32 size; -+ png_voidp pointer; -+ struct memory_information FAR *next; -+} memory_information; -+typedef memory_information FAR *memory_infop; -+ -+static memory_infop pinformation = NULL; -+static int current_allocation = 0; -+static int maximum_allocation = 0; -+ -+ -+ -+ -+png_voidp png_debug_malloc(png_structp png_ptr, png_uint_32 size) -+{ -+ -+ /* png_malloc has already tested for NULL; png_create_struct calls -+ png_debug_malloc directly (with png_ptr == NULL prior to libpng-1.2.0 -+ which is OK since we are not using a user mem_ptr) */ -+ -+ if (size == 0) -+ return (png_voidp) (NULL); -+ -+ /* This calls the library allocator twice, once to get the requested -+ buffer and once to get a new free list entry. */ -+ { -+ memory_infop pinfo = png_malloc_default(png_ptr, sizeof *pinfo); -+ pinfo->size = size; -+ current_allocation += size; -+ if (current_allocation > maximum_allocation) -+ maximum_allocation = current_allocation; -+ pinfo->pointer = png_malloc_default(png_ptr, size); -+ pinfo->next = pinformation; -+ pinformation = pinfo; -+ /* Make sure the caller isn't assuming zeroed memory. */ -+ png_memset(pinfo->pointer, 0xdd, pinfo->size); -+ if (verbose > 2) -+ fprintf(STDERR, "Pointer %lux allocated %lu bytes\n", -+ (unsigned long) pinfo->pointer, (unsigned long)size); -+ return (png_voidp) (pinfo->pointer); -+ } -+} -+ -+ -+ -+ -+/* Free a pointer. It is removed from the list at the same time. */ -+void png_debug_free(png_structp png_ptr, png_voidp ptr) -+{ -+ if (png_ptr == NULL) -+ fprintf(STDERR, "NULL pointer to png_debug_free.\n"); -+ if (ptr == 0) { -+#if 0 /* This happens all the time. */ -+ fprintf(STDERR, "WARNING: freeing NULL pointer\n"); -+#endif -+ return; -+ } -+ -+ /* Unlink the element from the list. */ -+ { -+ memory_infop FAR *ppinfo = &pinformation; -+ for (;;) { -+ memory_infop pinfo = *ppinfo; -+ if (pinfo->pointer == ptr) { -+ *ppinfo = pinfo->next; -+ current_allocation -= pinfo->size; -+ if (current_allocation < 0) -+ fprintf(STDERR, "Duplicate free of memory\n"); -+ /* We must free the list element too, but first kill -+ the memory that is to be freed. */ -+ memset(ptr, 0x55, pinfo->size); -+ if (verbose > 2) -+ fprintf(STDERR, "Pointer %lux freed %lu bytes\n", -+ (unsigned long) ptr, (unsigned long)pinfo->size); -+ png_free_default(png_ptr, pinfo); -+ break; -+ } -+ if (pinfo->next == NULL) { -+ fprintf(STDERR, "Pointer %lux not found\n", -+ (unsigned long) ptr); -+ break; -+ } -+ ppinfo = &pinfo->next; -+ } -+ } -+ -+ /* Finally free the data. */ -+ png_free_default(png_ptr, ptr); -+} -+ -+#endif /* PNG_USER_MEM_SUPPORTED */ -+/* END of code to test memory allocation/deallocation */ -+ -+ -+ -+ -+void png_crush_pause(void) -+{ -+ if (pauses > 0) { -+ char keystroke; -+ fprintf(STDERR, "Press [ENTER] key to continue.\n"); -+ keystroke = (char) getc(stdin); -+ keystroke = keystroke; /* stifle compiler warning */ -+ } -+} -+ -+ -+ -+ -+#ifndef __riscos -+# define setfiletype(x) -+ -+#else /* defined(__riscos) */ -+# include <kernel.h> -+ -+/* The riscos/acorn support was contributed by Darren Salt. */ -+static int fileexists(const char *name) -+{ -+# ifdef __acorn -+ int ret; -+ return _swix(8, 3 | 1 << 31, 17, name, &ret) ? 0 : ret; -+# else -+ _kernel_swi_regs r; -+ r.r[0] = 17; -+ r.r[1] = (int) name; -+ return _kernel_swi(8, &r, &r) ? 0 : r.r[0]; -+# endif -+} -+ -+ -+static int filesize(const char *name) -+{ -+# ifdef __acorn -+ int ret; -+ return _swix(8, 3 | 1 << 27, 17, name, &ret) ? 0 : ret; -+# else -+ _kernel_swi_regs r; -+ r.r[0] = 17; -+ r.r[1] = (int) name; -+ return _kernel_swi(8, &r, &r) ? 0 : r.r[4]; -+# endif -+} -+ -+ -+static int mkdir(const char *name, int ignored) -+{ -+# ifdef __acorn -+ _swi(8, 0x13, 8, name, 0); -+ return 0; -+# else -+ _kernel_swi_regs r; -+ r.r[0] = 8; -+ r.r[1] = (int) name; -+ r.r[4] = r.r[3] = r.r[2] = 0; -+ return (int) _kernel_swi(8 | 1 << 31, &r, &r); -+# endif -+} -+ -+ -+static void setfiletype(const char *name) -+{ -+# ifdef __acorn -+ _swi(8, 7, 18, name, 0xB60); -+# else -+ _kernel_swi_regs r; -+ r.r[0] = 18; -+ r.r[1] = (int) name; -+ r.r[2] = 0xB60; -+ _kernel_swi(8 | 1 << 31, &r, &r); -+# endif -+} -+ -+#endif /* ?defined(__riscos) */ -+ -+ -+ -+ -+/* GRR: basically boolean; first arg is chunk name-string (e.g., "tIME" or -+ * "alla"); second is always full argv[] command line -+ * - remove_chunks is argv index of *last* -rem arg on command line -+ * (would be more efficient to build table at time of cmdline processing!) -+ * (i.e., build removal_list with names or unique IDs or whatever--skip -+ * excessive string-processing on every single one) -+ * - reprocesses command line _every_ time called, looking for -rem opts... -+ * - just like keep_chunk() except that latter sets things_have_changed -+ * variable and debug stmts say "Removed chunk" (but caller actually does -+ * so, by choosing not to copy chunk to new file) -+ * - for any given chunk name, "name" must either match exact command-line -+ * arg (e.g., -rem fOOb), OR it must match one of the official PNG chunk -+ * names explicitly listed below AND command-line arg either used all- -+ * lowercase form or one of "all[ab]" options -+ */ -+int keep_unknown_chunk(png_const_charp name, char *argv[]) -+{ -+ int i; -+ if (remove_chunks == 0) -+ return 1; /* no -rem options, so always keeping */ -+ for (i = 1; i <= remove_chunks; i++) { -+ if (!strncmp(argv[i], "-rem", 4)) { -+ int allb = 0; -+ i++; -+ if (!strncmp(argv[i], "all", 3)) { -+ allb++; /* all but gamma, but not doing gamma here */ -+ } -+ if (!strncmp(argv[i], name, 4) /* exact chunk-name match in args */ -+ /* ...or exact match for one of known set, plus args included -+ * either "alla", "allb", or all-lowercase form of "name" */ -+ || (!strncmp(name, "cHRM", 4) -+ && (!strncmp(argv[i], "chrm", 4) || allb)) -+ || (!strncmp(name, "dSIG", 4) -+ && (!strncmp(argv[i], "dsig", 4) || allb)) -+ || (!strncmp(name, "gIFg", 4) -+ && (!strncmp(argv[i], "gifg", 4) || allb)) -+ || (!strncmp(name, "gIFt", 4) -+ && (!strncmp(argv[i], "gift", 4) || allb)) -+ || (!strncmp(name, "gIFx", 4) -+ && (!strncmp(argv[i], "gifx", 4) || allb)) -+ || (!strncmp(name, "hIST", 4) -+ && (!strncmp(argv[i], "hist", 4) || allb)) -+ || (!strncmp(name, "iCCP", 4) -+ && (!strncmp(argv[i], "iccp", 4) || allb)) -+ || (!strncmp(name, "pCAL", 4) -+ && (!strncmp(argv[i], "pcal", 4) || allb)) -+ || (!strncmp(name, "sCAL", 4) -+ && (!strncmp(argv[i], "scal", 4) || allb)) -+ || (!strncmp(name, "sPLT", 4) -+ && (!strncmp(argv[i], "splt", 4) || allb)) -+ || (!strncmp(name, "tIME", 4) -+ && (!strncmp(argv[i], "time", 4) || allb))) -+ { -+ return 0; -+ } -+ } -+ } -+ return 1; -+} -+ -+ -+ -+ -+int keep_chunk(png_const_charp name, char *argv[]) -+{ -+ int i; -+ if (verbose > 2 && first_trial) -+ fprintf(STDERR, " Read the %s chunk.\n", name); -+ if (remove_chunks == 0) -+ return 1; -+ if (verbose > 1 && first_trial) -+ fprintf(STDERR, " Check for removal of the %s chunk.\n", name); -+ for (i = 1; i <= remove_chunks; i++) { -+ if (!strncmp(argv[i], "-rem", 4)) { -+ int alla = 0; -+ int allb = 0; -+ int allt = 0; -+ i++; -+ if (!strncmp(argv[i], "all", 3)) { -+ allt++; /* all forms of text chunk are ancillary */ -+ allb++; /* all ancillaries but gamma... */ -+ if (!strncmp(argv[i], "alla", 4)) -+ alla++; /* ...no, all ancillaries, period */ -+ } else if (!strncmp(argv[i], "text", 4)) -+ allt++; /* all forms of text chunk */ -+ if (!strncmp(argv[i], name, 4) /* exact chunk-name match in args -+ * ...or exact match for one of known set, plus args included -+ * either "alla", "allb", or all-lowercase form of "name": */ -+ || (!strncmp(name, "PLTE", 4) -+ && (!strncmp(argv[i], "plte", 4) )) -+ || (!strncmp(name, "bKGD", 4) -+ && (!strncmp(argv[i], "bkgd", 4) || allb)) -+ || (!strncmp(name, "cHRM", 4) -+ && (!strncmp(argv[i], "chrm", 4) || allb)) -+ || (!strncmp(name, "dSIG", 4) -+ && (!strncmp(argv[i], "dsig", 4) || allb)) -+ || (!strncmp(name, "gAMA", 4) -+ && (!strncmp(argv[i], "gama", 4) || alla)) -+ || (!strncmp(name, "gIFg", 4) -+ && (!strncmp(argv[i], "gifg", 4) || allb)) -+ || (!strncmp(name, "gIFt", 4) -+ && (!strncmp(argv[i], "gift", 4) || allb)) -+ || (!strncmp(name, "gIFx", 4) -+ && (!strncmp(argv[i], "gifx", 4) || allb)) -+ || (!strncmp(name, "hIST", 4) -+ && (!strncmp(argv[i], "hist", 4) || allb)) -+ || (!strncmp(name, "iCCP", 4) -+ && (!strncmp(argv[i], "iccp", 4) || allb)) -+ || (!strncmp(name, "iTXt", 4) -+ && (!strncmp(argv[i], "itxt", 4) || allt)) -+ || (!strncmp(name, "oFFs", 4) -+ && (!strncmp(argv[i], "offs", 4) || allb)) -+ || (!strncmp(name, "pHYs", 4) -+ && (!strncmp(argv[i], "phys", 4) || allb)) -+ || (!strncmp(name, "pCAL", 4) -+ && (!strncmp(argv[i], "pcal", 4) || allb)) -+ || (!strncmp(name, "sBIT", 4) -+ && (!strncmp(argv[i], "sbit", 4) || allb)) -+ || (!strncmp(name, "sCAL", 4) -+ && (!strncmp(argv[i], "scal", 4) || allb)) -+ || (!strncmp(name, "sRGB", 4) -+ && (!strncmp(argv[i], "srgb", 4) || allb)) -+ || (!strncmp(name, "sPLT", 4) -+ && (!strncmp(argv[i], "splt", 4) || allb)) -+ || (!strncmp(name, "tEXt", 4) -+ && ( allt)) -+ || (!strncmp(name, "tIME", 4) -+ && (!strncmp(argv[i], "time", 4) || allb)) -+ || (!strncmp(name, "tRNS", 4) -+ && (!strncmp(argv[i], "trns", 4) )) -+ || (!strncmp(name, "zTXt", 4) -+ && (!strncmp(argv[i], "ztxt", 4) || allt)) ) -+ { -+ things_have_changed = 1; -+ /* (caller actually does the removal--by failing to create -+ * copy) */ -+ if (verbose > 0 && first_trial) -+ fprintf(STDERR, " Removed the %s chunk.\n", name); -+ return 0; -+ } -+ } -+ } -+ if (verbose > 1 && first_trial) -+ fprintf(STDERR, " Preserving the %s chunk.\n", name); -+ return 1; -+} -+ -+ -+ -+ -+void show_result(void) -+{ -+ if (total_output_length) { -+ if (total_input_length == total_output_length) -+ fprintf(STDERR, " Overall result: no change\n"); -+ else if (total_input_length > total_output_length) -+ fprintf(STDERR, -+ " Overall result: %4.2f%% reduction, %lu bytes\n", -+ (100.0 - -+ (100.0 * total_output_length) / total_input_length), -+ (unsigned long)(total_input_length-total_output_length)); -+ else -+ fprintf(STDERR, -+ " Overall result: %4.2f%% increase, %lu bytes\n", -+ -(100.0 - -+ (100.0 * total_output_length) / total_input_length), -+ (unsigned long)(total_output_length - total_input_length)); -+ } -+ t_stop = (TIME_T) clock(); -+ t_misc += (t_stop - t_start); -+ if (t_stop < t_start) { -+ t_misc += PNG_UINT_31_MAX; -+ if (t_stop < 0) -+ t_misc += PNG_UINT_31_MAX; -+ } -+ t_start = t_stop; -+ fprintf(STDERR, " CPU time used = %.3f seconds", -+ (t_misc + t_decode + t_encode) / (float) CLOCKS_PER_SEC); -+ fprintf(STDERR, " (decoding %.3f,\n", -+ t_decode / (float) CLOCKS_PER_SEC); -+ fprintf(STDERR, " encoding %.3f,", -+ t_encode / (float) CLOCKS_PER_SEC); -+ fprintf(STDERR, " other %.3f seconds)\n\n", -+ t_misc / (float) CLOCKS_PER_SEC); -+#ifdef PNG_USER_MEM_SUPPORTED -+ if (current_allocation) { -+ memory_infop pinfo = pinformation; -+ fprintf(STDERR, "MEMORY ERROR: %d bytes still allocated\n", -+ current_allocation); -+ while (pinfo != NULL) { -+ fprintf(STDERR, " %8lu bytes at %lux\n", (unsigned long)pinfo->size, -+ (unsigned long) pinfo->pointer); -+ free(pinfo->pointer); -+ pinfo = pinfo->next; -+ } -+ } -+#endif -+} -+ -+ -+ -+ -+int main(int argc, char *argv[]) -+{ -+ png_uint_32 y; -+ int bit_depth, color_type; -+ int num_pass, pass; -+ int num_methods; -+ int try_method[MAX_METHODSP1]; -+ int fm[MAX_METHODSP1]; -+ int lv[MAX_METHODSP1]; -+ int zs[MAX_METHODSP1]; -+ int lev, strat, filt; -+#ifdef PNG_gAMA_SUPPORTED -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ png_fixed_point file_gamma = 0; -+#else -+ double file_gamma = 0.; -+#endif -+#endif -+ char *cp; -+ int i; -+ row_buf = (png_bytep) NULL; -+ number_of_open_files = 0; -+#ifdef PNGCRUSH_COUNT_COLORS -+ reduce_to_gray = 0; -+ it_is_opaque = 0; -+#else -+ do_color_count = 0; -+ do_color_count = do_color_count; /* silence compiler warning */ -+#endif -+ -+ if (strcmp(png_libpng_ver, PNG_LIBPNG_VER_STRING)) { -+ fprintf(STDERR, -+ "Warning: versions are different between png.h and png.c\n"); -+ fprintf(STDERR, " png.h version: %s\n", PNG_LIBPNG_VER_STRING); -+ fprintf(STDERR, " png.c version: %s\n\n", png_libpng_ver); -+ } -+ -+ t_start = (TIME_T) clock(); -+ -+ strncpy(prog_string, argv[0], STR_BUF_SIZE); -+ prog_string[STR_BUF_SIZE-1] = '\0'; -+ progname = prog_string; -+ for (i = 0, cp = prog_string; *cp != '\0'; i++, cp++) { -+#ifdef __riscos -+ if (*cp == '.' || *cp == ':') -+ progname = ++cp; -+#else -+ if (*cp == '\\' || *cp == '/') -+ progname = ++cp; -+ if (*cp == '.') -+ *cp = '\0'; -+#endif -+ } -+ -+ /* -+ * Definition of methods ("canonical list" is methods 11 and up) -+ */ -+ for (i = 0; i < MAX_METHODS; i++) { -+ try_method[i] = 1; -+ fm[i] = 5; lv[i] = 9; zs[i] = 1; /* default: method 124 */ -+ } -+ -+ fm[1] = 0; lv[1] = 4; zs[1] = 0; /* method 1 == method 53 */ -+ fm[2] = 1; lv[2] = 4; zs[2] = 0; /* method 2 == method 54 */ -+ lv[3] = 4; /* method 3 == method 64 */ -+ fm[4] = 0; /* method 4 == method 119 */ -+ fm[5] = 1; zs[5] = 0; /* method 5 == method 114 */ -+ zs[6] = 0; /* method 6 == method 118 */ -+ fm[7] = 0; zs[7] = 0; /* method 7 == method 113 */ -+ fm[8] = 1; /* method 8 == method 120 */ -+ lv[9] = 2; zs[9] = 2; /* method 9 == method 16 */ -+ /* method 10 == method 124 */ -+ -+ /* methods 11 through 16 */ -+ /* [strategy 2 (Z_HUFFMAN_ONLY) is independent of zlib compression level] */ -+ method = 11; -+ for (filt = 0; filt <= 5; filt++) { -+ fm[method] = filt; -+ lv[method] = 2; -+ zs[method] = 2; -+ method++; -+ } -+ -+ /* methods 17 through 124 (9*2*6 = 108) */ -+ for (lev = 1; lev <= 9; lev++) { -+ for (strat = 0; strat <= 1; strat++) { -+ for (filt = 0; filt <= 5; filt++) { -+ fm[method] = filt; -+ lv[method] = lev; -+ zs[method] = strat; -+ method++; -+ } -+ } -+ } -+ -+#ifdef Z_RLE -+ /* methods 125 through 136 */ -+ /* [strategy 3 (Z_RLE) is mostly independent of level; 1-3 and 4-9 are -+ * same] */ -+ for (filt = 0; filt <= 5; filt++) { -+ fm[method] = filt; -+ lv[method] = 1; -+ zs[method] = 3; -+ method++; -+ } -+ for (filt = 0; filt <= 5; filt++) { -+ fm[method] = filt; -+ lv[method] = 4; -+ zs[method] = 3; -+ method++; -+ } -+#endif /* Z_RLE */ -+ -+ num_methods = method; /* GRR */ -+ -+ -+#define BUMP_I i++;if(i >= argc) {printf("insufficient parameters\n");exit(1);} -+ names = 1; -+ -+ /* ===================================================================== */ -+ /* FIXME: move args-processing block into separate function (470 lines) */ -+ for (i = 1; i < argc; i++) { -+ if (!strncmp(argv[i], "-", 1)) -+ names++; -+ -+ -+ /* GRR: start of giant else-if block */ -+ if (!strncmp(argv[i], "-fast", 5)) { -+ /* try two fast filters */ -+ methods_specified = 1; -+ try_method[16] = 0; -+ try_method[53] = 0; -+ } else if (!strncmp(argv[i], "-huffman", 8)) { -+ /* try all filters with huffman */ -+ methods_specified = 1; -+ for (method = 11; method <= 16; method++) { -+ try_method[method] = 0; -+ } -+#ifdef Z_RLE -+ } else if (!strncmp(argv[i], "-rle", 4)) { -+ /* try all filters with RLE */ -+ methods_specified = 1; -+ for (method = 125; method <= 136; method++) { -+ try_method[method] = 0; -+ } -+#endif -+ } -+ -+ else if (!strncmp(argv[i], "-already", 8)) { -+ names++; -+ BUMP_I; -+ crushed_idat_size = (png_uint_32) atoi(argv[i]); -+ } -+ -+ else if (!strncmp(argv[i], "-bkgd", 5) || -+ !strncmp(argv[i], "-bKGD", 5)) -+ { -+ names += 3; -+ have_bkgd = 1; -+ bkgd_red = (png_uint_16) atoi(argv[++i]); -+ bkgd_green = (png_uint_16) atoi(argv[++i]); -+ bkgd_blue = (png_uint_16) atoi(argv[++i]); -+ } -+ -+ else if (!strncmp(argv[i], "-brute", 6)) -+ /* brute force: try everything */ -+ { -+ int lev, strat, filt; -+ methods_specified = 1; -+ brute_force++; -+ for (method = 11; method < num_methods; method++) -+ try_method[method] = 0; -+ if (brute_force_filter == 0) -+ for (filt = 0; filt < 6; filt++) -+ brute_force_filters[filt] = 0; -+ if (brute_force_level == 0) -+ for (lev = 0; lev < 10; lev++) -+ brute_force_levels[lev] = 0; -+ if (brute_force_strategy == 0) -+ for (strat = 0; strat < NUM_STRATEGIES; strat++) -+ brute_force_strategies[strat] = 0; -+ } else if (!strncmp(argv[i], "-bit_depth", 10)) { -+ names++; -+ BUMP_I; -+ force_output_bit_depth = atoi(argv[i]); -+ } else if (!strncmp(argv[i], "-cc", 3)) { -+ do_color_count = 1; -+ } else if (!strncmp(argv[i], "-no_cc", 6)) { -+ do_color_count = 0; -+ } else if (!strncmp(argv[i], "-c", 2)) { -+ names++; -+ BUMP_I; -+ force_output_color_type = atoi(argv[i]); -+ } -+#ifdef PNG_gAMA_SUPPORTED -+ else if (!strncmp(argv[i], "-dou", 4)) { -+ double_gamma++; -+ found_gAMA=1; -+ global_things_have_changed = 1; -+ } -+#endif -+ else if (!strncmp(argv[i], "-d", 2)) { -+ BUMP_I; -+ if (pngcrush_mode == EXTENSION_MODE) -+ pngcrush_mode = DIREX_MODE; -+ else -+ pngcrush_mode = DIRECTORY_MODE; -+ directory_name = argv[names++]; -+ } else if (!strncmp(argv[i], "-exit", 5)) { -+ pngcrush_must_exit = 1; -+ } else if (!strncmp(argv[i], "-e", 2)) { -+ BUMP_I; -+ if (pngcrush_mode == DIRECTORY_MODE) -+ pngcrush_mode = DIREX_MODE; -+ else -+ pngcrush_mode = EXTENSION_MODE; -+ extension = argv[names++]; -+ } else if (!strncmp(argv[i], "-force", 6)) { -+ global_things_have_changed = 1; -+ } else if (!strncmp(argv[i], "-fix", 4)) { -+ fix++; -+ } else if (!strncmp(argv[i], "-f", 2)) { -+ int specified_filter = atoi(argv[++i]); -+ int lev, strat, filt; -+ if (specified_filter > 5 || specified_filter < 0) -+ specified_filter = 5; -+ names++; -+ if (brute_force == 0) -+ fm[method] = specified_filter; -+ else { -+ for (filt = 0; filt < 6; filt++) -+ brute_force_filters[filt] = 1; -+ brute_force_filters[specified_filter] = 0; -+ method = 11; -+ for (filt = 0; filt < 6; filt++) { -+ try_method[method] = brute_force_filters[filt] | -+ brute_force_strategies[2]; -+ method++; -+ } -+ for (lev = 1; lev < 10; lev++) { -+ for (strat = 0; strat < 2; strat++) { -+ for (filt = 0; filt < 6; filt++) { -+ try_method[method] = brute_force_levels[lev] | -+ brute_force_filters[filt] | -+ brute_force_strategies[strat]; -+ method++; -+ } -+ } -+ } -+ brute_force_filter++; -+ } -+ } else if (!strncmp(argv[i], "-loco", 5)) { -+#ifdef PNGCRUSH_LOCO -+ do_loco = 1; -+#else -+ printf -+ ("Cannot do -loco because libpng was compiled without MNG features"); -+#endif -+ } else if (!strncmp(argv[i], "-l", 2)) { -+ int lev, strat, filt; -+ int specified_level = atoi(argv[++i]); -+ if (specified_level > 9 || specified_level < 0) -+ specified_level = 9; -+ names++; -+ if (brute_force == 0) -+ lv[method] = specified_level; -+ else { -+ if (brute_force_level == 0) -+ for (lev = 0; lev < 10; lev++) -+ brute_force_levels[lev] = 1; -+ brute_force_levels[specified_level] = 0; -+ method = 11; -+ for (filt = 0; filt < 6; filt++) { -+ lv[method] = specified_level; -+ method++; -+ } -+ for (lev = 1; lev < 10; lev++) { -+ for (strat = 0; strat < 2; strat++) { -+ for (filt = 0; filt < 6; filt++) { -+ try_method[method] = brute_force_levels[lev] | -+ brute_force_filters[filt] | -+ brute_force_strategies[strat]; -+ method++; -+ } -+ } -+ } -+ brute_force_level++; -+ } -+ } -+#ifdef PNG_gAMA_SUPPORTED -+ else if (!strncmp(argv[i], "-g", 2)) { -+ names++; -+ BUMP_I; -+ found_gAMA=1; -+ if (intent < 0) { -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ int c; -+ char number[16]; -+ char *n = number; -+ int nzeroes = -1; -+ int length = strlen(argv[i]); -+ for (c = 0; c < length; c++) { -+ if (*(argv[i] + c) == '.') { -+ nzeroes = 5; -+ } else if (nzeroes) { -+ *n++ = *(argv[i] + c); -+ nzeroes--; -+ } -+ } -+ for (c = 0; c < nzeroes; c++) -+ *n++ = '0'; -+ *n = '\0'; -+ specified_gamma = atoi(number); -+#else -+ specified_gamma = atof(argv[i]); -+#endif -+ } -+ } -+#endif /* PNG_gAMA_SUPPORTED */ -+ else if (!strncmp(argv[i], "-h", 2)) { -+ ++verbose; -+ print_version_info(); -+ print_usage(0); /* this exits */ -+ } -+#ifdef PNG_iCCP_SUPPORTED -+ else if (!strncmp(argv[i], "-iccp", 5)) { -+ FILE *iccp_fn; -+ if (iccp_length) -+ free(iccp_text); -+ iccp_length = atoi(argv[++i]); -+ names += 3; -+ strcpy(iccp_name, argv[++i]); -+ iccp_file = argv[++i]; -+ if ((iccp_fn = FOPEN(iccp_file, "rb")) == NULL) { -+ fprintf(STDERR, "Could not find file: %s\n", iccp_file); -+ iccp_length = 0; -+ } else { -+ int ic; -+ iccp_text = malloc(iccp_length); -+ for (ic = 0; ic < iccp_length; ic++) { -+ png_size_t num_in; -+ num_in = fread(buffer, 1, 1, iccp_fn); -+ if (!num_in) -+ break; -+ iccp_text[ic] = buffer[0]; -+ } -+ } -+ } -+#endif -+ else if (!strncmp(argv[i], "-keep", 5)) { -+ names++; -+ BUMP_I; -+ if (!strncmp(argv[i], "dSIG", 4) -+ && (!strncmp(argv[i], "dsig", 4) )) -+ found_any_chunk=1; -+ } -+ -+ else if (!strncmp(argv[i], "-max", 4)) { -+ names++; -+ BUMP_I; -+ max_idat_size = (png_uint_32) atoi(argv[i]); -+ if (max_idat_size == 0 || max_idat_size > PNG_UINT_31_MAX) -+ max_idat_size = PNG_ZBUF_SIZE; -+#ifdef PNGCRUSH_LOCO -+ } else if (!strncmp(argv[i], "-mng", 4)) { -+ names++; -+ BUMP_I; -+ mngname = argv[i]; -+ new_mng++; -+#endif -+ } else if (!strncmp(argv[i], "-m", 2)) { -+ names++; -+ BUMP_I; -+ method = atoi(argv[i]); -+ methods_specified = 1; -+ brute_force = 0; -+ try_method[method] = 0; -+ } else if (!strncmp(argv[i], "-nofilecheck", 5)) { -+ nofilecheck++; -+ } else if (!strncmp(argv[i], "-nosave", 2)) { -+ /* no save; I just use this for testing decode speed */ -+ nosave++; -+ pngcrush_mode = EXTENSION_MODE; -+ } else if (!strncmp(argv[i], "-plte_len", 9)) { -+ names++; -+ BUMP_I; -+ plte_len = atoi(argv[i]); -+ } else if (!strncmp(argv[i], "-pplt", 3)) { -+ names++; -+ do_pplt++; -+ BUMP_I; -+ strcpy(pplt_string, argv[i]); -+ global_things_have_changed = 1; -+ } else if (!strncmp(argv[i], "-p", 2)) { -+ pauses++; -+ } else if (!strncmp(argv[i], "-q", 2)) { -+ verbose = 0; -+ } else if (!strncmp(argv[i], "-reduce", 7)) { -+ reduction_ok++; -+ do_color_count = 1; -+ } -+#ifdef PNG_gAMA_SUPPORTED -+ else if (!strncmp(argv[i], "-rep", 4)) { -+ names++; -+ BUMP_I; -+ found_gAMA=1; -+ { -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ int c; -+ char number[16]; -+ char *n = number; -+ int nzeroes = -1; -+ int length = strlen(argv[i]); -+ for (c = 0; c < length; c++) { -+ if (*(argv[i] + c) == '.') { -+ nzeroes = 5; -+ } else if (nzeroes) { -+ *n++ = *(argv[i] + c); -+ nzeroes--; -+ } -+ } -+ for (c = 0; c < nzeroes; c++) -+ *n++ = '0'; -+ *n = '\0'; -+ force_specified_gamma = atoi(number); -+#else -+ force_specified_gamma = atof(argv[i]); -+#endif -+ } -+ global_things_have_changed = 1; -+ } -+#endif -+#ifdef PNG_pHYs_SUPPORTED -+ else if (!strncmp(argv[i], "-res", 4)) { -+ names++; -+ BUMP_I; -+ resolution = atoi(argv[i]); -+ global_things_have_changed = 1; -+ } -+#endif -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+ else if (!strncmp(argv[i], "-rows", 5)) { -+ names++; -+ BUMP_I; -+ max_rows_at_a_time = atoi(argv[i]); -+ } -+#endif -+ else if (!strncmp(argv[i], "-r", 2)) { -+ remove_chunks = i; -+ names++; -+ BUMP_I; -+ if (!strncmp(argv[i], "dSIG", 4) -+ && (!strncmp(argv[i], "dsig", 4))) -+ image_is_immutable=0; -+ } else if (!strncmp(argv[i], "-save", 5)) { -+ all_chunks_are_safe++; -+ } else if (!strncmp(argv[i], "-srgb", 5) || -+ !strncmp(argv[i], "-sRGB", 5)) { -+#ifdef PNG_gAMA_SUPPORTED -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ specified_gamma = 45455L; -+#else -+ specified_gamma = 0.45455; -+#endif -+#endif -+ intent = 0; -+ BUMP_I; -+ if (!strncmp(argv[i], "0", 1) || -+ !strncmp(argv[i], "1", 1) || -+ !strncmp(argv[i], "2", 1) || !strncmp(argv[i], "3", 1)) { -+ names++; -+ intent = (int) atoi(argv[i]); -+ } else -+ i--; -+ } else if (!strncmp(argv[i], "-s", 2)) { -+ verbose = 0; -+ } else if (!strncmp(argv[i], "-text", 5) -+ || !strncmp(argv[i], "-tEXt", 5) || -+#ifdef PNG_iTXt_SUPPORTED -+ !strncmp(argv[i], "-itxt", 5) -+ || !strncmp(argv[i], "-iTXt", 5) -+ || !strncmp(argv[i], "-zitxt", 6) -+ || !strncmp(argv[i], "-ziTXt", 6) || -+#endif -+ !strncmp(argv[i], "-ztxt", 5) -+ || !strncmp(argv[i], "-zTXt", 5)) -+ { -+ i += 2; -+ BUMP_I; -+ i -= 3; -+ if (strlen(argv[i + 2]) < 180 && strlen(argv[i + 3]) < 2048 && -+ text_inputs < 10) { -+#ifdef PNG_iTXt_SUPPORTED -+ if (!strncmp(argv[i], "-zi", 3)) { -+ text_compression[text_inputs] = -+ PNG_ITXT_COMPRESSION_zTXt; -+ /* names += 2; */ -+ } else -+#endif -+ if (!strncmp(argv[i], "-z", 2)) -+ text_compression[text_inputs] = -+ PNG_TEXT_COMPRESSION_zTXt; -+ else if (!strncmp(argv[i], "-t", 2)) -+ text_compression[text_inputs] = -+ PNG_TEXT_COMPRESSION_NONE; -+#ifdef PNG_iTXt_SUPPORTED -+ else { -+ text_compression[text_inputs] = -+ PNG_ITXT_COMPRESSION_NONE; -+ /* names += 2; */ -+ } -+#endif -+ names += 3; -+ if (!strncmp(argv[++i], "b", 1)) -+ text_where[text_inputs] = 1; -+ if (!strncmp(argv[i], "a", 1)) -+ text_where[text_inputs] = 2; -+ strcpy(&text_keyword[text_inputs * 80], argv[++i]); -+#ifdef PNG_iTXt_SUPPORTED -+ if (text_compression[text_inputs] <= 0) { -+ text_lang[text_inputs * 80] = '\0'; -+ text_lang_key[text_inputs * 80] = '\0'; -+ } else { -+ i += 2; -+ BUMP_I; -+ i -= 3; -+ names += 2; -+ strcpy(&text_lang[text_inputs * 80], argv[++i]); -+ /* libpng-1.0.5j and later */ -+ strcpy(&text_lang_key[text_inputs * 80], argv[++i]); -+ } -+#endif -+ strcpy(&text_text[text_inputs * 2048], argv[++i]); -+ text_inputs++; -+ } else { -+ if (text_inputs > 9) -+ fprintf(STDERR, -+ "too many text/zTXt inputs; only 10 allowed\n"); -+ else -+ fprintf(STDERR, -+ "keyword exceeds 79 characters or text exceeds 2047 characters\n"); -+ i += 3; -+ names += 3; -+#ifdef PNG_iTXt_SUPPORTED -+ if (!strncmp(argv[i], "-i", 2) -+ || !strncmp(argv[i], "-zi", 3)) { -+ i++; -+ BUMP_I; -+ names += 2; -+ } -+#endif -+ } -+ } -+#ifdef PNG_tRNS_SUPPORTED -+ else if (!strncmp(argv[i], "-trns_a", 7) || -+ !strncmp(argv[i], "-tRNS_a", 7)) { -+ num_trans_in = (png_uint_16) atoi(argv[++i]); -+ trns_index=num_trans_in-1; -+ have_trns = 1; -+ for (ia = 0; ia < num_trans_in; ia++) -+ trans_in[ia] = (png_byte) atoi(argv[++i]); -+ names += 1 + num_trans_in; -+ } else if (!strncmp(argv[i], "-trns", 5) || -+ !strncmp(argv[i], "-tRNS", 5)) { -+ names += 5; -+ have_trns = 1; -+ trns_index = (png_uint_16) atoi(argv[++i]); -+ trns_red = (png_uint_16) atoi(argv[++i]); -+ trns_green = (png_uint_16) atoi(argv[++i]); -+ trns_blue = (png_uint_16) atoi(argv[++i]); -+ trns_gray = (png_uint_16) atoi(argv[++i]); -+ } -+#endif -+ else if (!strncmp(argv[i], "-version", 8)) { -+ fprintf(STDERR, " pngcrush "); -+ fprintf(STDERR, PNGCRUSH_VERSION); -+ fprintf(STDERR, ", uses libpng "); -+ fprintf(STDERR, PNG_LIBPNG_VER_STRING); -+ fprintf(STDERR, " and zlib "); -+ fprintf(STDERR, ZLIB_VERSION); -+ fprintf(STDERR, "\n Check http://pmt.sf.net/\n"); -+ fprintf(STDERR, " for the most recent version.\n"); -+ verbose = 0; -+ } else if (!strncmp(argv[i], "-v", 2)) { -+ verbose++; -+ } else if (!strncmp(argv[i], "-w", 2)) { -+ default_compression_window = atoi(argv[++i]); -+ force_compression_window++; -+ names++; -+ } else if (!strncmp(argv[i], "-zm", 3)) { -+ compression_mem_level = atoi(argv[++i]); -+ names++; -+ } else if (!strncmp(argv[i], "-z", 2)) { -+ int lev, strat, filt; -+ int specified_strategy = atoi(argv[++i]); -+ if (specified_strategy > 2 || specified_strategy < 0) -+ specified_strategy = 0; -+ names++; -+ if (brute_force == 0) -+ zs[method] = specified_strategy; -+ else { -+ if (brute_force_strategy == 0) -+ for (strat = 0; strat < 2; strat++) -+ brute_force_strategies[strat] = 1; -+ brute_force_strategies[specified_strategy] = 0; -+ method = 11; -+ for (filt = 0; filt < 6; filt++) { -+ if (specified_strategy != 2) -+ try_method[method] = 1; -+ method++; -+ } -+ for (lev = 1; lev < 10; lev++) { -+ for (strat = 0; strat < 2; strat++) { -+ for (filt = 0; filt < 6; filt++) { -+ try_method[method] = brute_force_levels[lev] | -+ brute_force_filters[filt] | -+ brute_force_strategies[strat]; -+ method++; -+ } -+ } -+ } -+ } -+ brute_force_strategy++; -+ } /* GRR: end of giant if-else block */ -+ } /* end of loop over args ============================================ */ -+ -+ -+ if (verbose > 0) -+ print_version_info(); -+ -+ if (default_compression_window == 32) -+ default_compression_window = 15; -+ else if (default_compression_window == 16) -+ default_compression_window = 14; -+ else if (default_compression_window == 8) -+ default_compression_window = 13; -+ else if (default_compression_window == 4) -+ default_compression_window = 12; -+ else if (default_compression_window == 2) -+ default_compression_window = 11; -+ else if (default_compression_window == 1) -+ default_compression_window = 10; -+ else if (default_compression_window == 512) -+ default_compression_window = 9; -+ /* Use of compression window size 256 is not recommended. */ -+ else if (default_compression_window == 256) -+ default_compression_window = 8; -+ else if (default_compression_window != 15) { -+ fprintf(STDERR, "Invalid window size (%d); using window size=4\n", -+ default_compression_window); -+ default_compression_window = 12; -+ } -+ -+ if (pngcrush_mode == DEFAULT_MODE) { -+ if (argc - names == 2) { -+ inname = argv[names]; -+ outname = argv[names + 1]; -+ } else { -+ if ((argc - names == 1 || nosave)) { -+ inname = argv[names]; -+ } -+ if (verbose && !nosave) { -+ print_usage(1); /* this exits */ -+ } -+ } -+ } -+ -+ for (ia = 0; ia < 256; ia++) -+ trns_array[ia]=255; -+ -+ for (;;) /* loop on input files */ -+ { -+ first_trial = 1; -+ -+ things_have_changed = global_things_have_changed; -+ -+ if (png_row_filters != NULL) { -+ free(png_row_filters); -+ png_row_filters = NULL; -+ } -+ -+ image_specified_gamma = 0; -+ -+ inname = argv[names++]; -+ -+ if (inname == NULL) { -+ if (verbose > 0) -+ show_result(); -+ break; -+ } -+ -+ if (pngcrush_mode == DIRECTORY_MODE || pngcrush_mode == DIREX_MODE) { -+ int inlen, outlen; -+#ifndef __riscos -+ struct stat stat_buf; -+ if (stat(directory_name, &stat_buf)) -+#else -+ if (fileexists(directory_name) & 2) -+#endif -+ { -+#if defined(_MBCS) || defined(WIN32) || defined(__WIN32__) -+ if (_mkdir(directory_name)) -+#else -+ if (mkdir(directory_name, 0755)) -+#endif -+ { -+ fprintf(STDERR, "could not create directory %s\n", -+ directory_name); -+ exit(1); -+ } -+ nofilecheck = 1; -+ } -+ outlen = strlen(directory_name); -+ if (outlen >= STR_BUF_SIZE-1) { -+ fprintf(STDERR, "directory %s is too long for buffer\n", -+ directory_name); -+ exit(1); -+ } -+ strcpy(out_string, directory_name); -+ /*strcpy(out_string+outlen, SLASH); */ -+ out_string[outlen++] = SLASH[0]; /* (assuming SLASH is 1 byte) */ -+ out_string[outlen] = '\0'; -+ -+ inlen = strlen(inname); -+ if (inlen >= STR_BUF_SIZE) { -+ fprintf(STDERR, "filename %s is too long for buffer\n", inname); -+ exit(1); -+ } -+ strcpy(in_string, inname); -+ in_string[inlen] = '\0'; -+#ifdef __riscos -+ op = strrchr(in_string, '.'); -+ if (!op) -+ op = in_string; -+ else -+ op++; -+#else -+ op = in_string; -+ ip = in_string + inlen - 1; /* start at last char in string */ -+ while (ip > in_string) { -+ if (*ip == '\\' || *ip == '/') { -+ op = ip + 1; -+ break; -+ } -+ --ip; -+ } -+#endif -+ -+ if (outlen + (inlen - (op - in_string)) >= STR_BUF_SIZE) { -+ fprintf(STDERR, "full path is too long for buffer\n"); -+ exit(1); -+ } -+ strcpy(out_string+outlen, op); -+ /*outlen += inlen - (op - in_string); */ -+ outname = out_string; -+ } -+ -+ /* FIXME: need same input-validation fixes (as above) here, too -+ * FIXME: what was the point of setting in_string and out_string in -+ * DIREX_MODE above if going to do all over again here? */ -+ if (pngcrush_mode == EXTENSION_MODE || pngcrush_mode == DIREX_MODE) { -+ ip = in_string; -+ in_string[0] = '\0'; -+ if (pngcrush_mode == EXTENSION_MODE) -+ strcat(in_string, inname); -+ else -+ strcat(in_string, outname); -+ ip = in_string; -+ op = dot = out_string; -+ while (*ip != '\0') { -+ *op++ = *ip++; -+#ifdef __riscos -+ if (*ip == '/') -+ dot = op; -+#else -+ if (*ip == '.') -+ dot = op; -+#endif -+ } -+ *op = '\0'; -+ -+ if (dot != out_string) -+ *dot = '\0'; -+ -+ in_extension[0] = '\0'; -+ if (dot != out_string) { -+ strcat(in_extension, ++dot); -+ } -+ -+ strcat(out_string, extension); -+ outname = out_string; -+ } -+ -+ -+ if (nosave < 2) { -+ P1( "Opening file %s for length measurement\n", -+ inname); -+ -+ if ((fpin = FOPEN(inname, "rb")) == NULL) { -+ fprintf(STDERR, "Could not find file: %s\n", inname); -+ continue; -+ } -+ number_of_open_files++; -+ -+ already_crushed = 0; -+ -+#ifdef PNGCRUSH_LOCO -+ if (new_mng) { -+ -+#ifdef PNG_USER_MEM_SUPPORTED -+ mng_ptr = png_create_write_struct_2(PNG_LIBPNG_VER_STRING, -+ (png_voidp) NULL, (png_error_ptr) png_cexcept_error, -+ (png_error_ptr) NULL, (png_voidp) NULL, -+ (png_malloc_ptr) png_debug_malloc, -+ (png_free_ptr) png_debug_free); -+#else -+ mng_ptr = png_create_write_struct(PNG_LIBPNG_VER_STRING, -+ (png_voidp) NULL, (png_error_ptr) png_cexcept_error, -+ (png_error_ptr) NULL); -+#endif -+ if (mng_ptr == NULL) -+ fprintf(STDERR, "pngcrush could not create mng_ptr"); -+ -+ if ((mng_out = FOPEN(mngname, "wb")) == NULL) { -+ fprintf(STDERR, "Could not open output file %s\n", -+ mngname); -+ FCLOSE(fpin); -+ exit(1); -+ } -+ number_of_open_files++; -+ png_init_io(mng_ptr, mng_out); -+ png_set_write_fn(mng_ptr, (png_voidp) mng_out, -+ (png_rw_ptr) NULL, -+ NULL); -+#endif -+ -+ } -+ -+ idat_length[0] = measure_idats(fpin); -+ -+#ifdef PNGCRUSH_LOCO -+ if (new_mng) { -+ png_destroy_write_struct(&mng_ptr, NULL); -+ FCLOSE(mng_out); -+ } -+#endif -+ -+ FCLOSE(fpin); -+ -+ -+ if (verbose > 0) { -+ fprintf(STDERR, " Recompressing %s\n", inname); -+ fprintf(STDERR, -+ " Total length of data found in IDAT chunks = %8lu\n", -+ (unsigned long)idat_length[0]); -+ fflush(STDERR); -+ } -+ -+ if (idat_length[0] == 0) -+ continue; -+ -+ } else -+ idat_length[0] = 1; -+ -+ if (already_crushed) { -+ fprintf(STDERR, " File %s has already been crushed.\n", inname); -+ } -+ if (image_is_immutable) { -+ fprintf(STDERR, -+ " Image %s has a dSIG chunk and is immutable.\n", inname); -+ } -+ if (!already_crushed && !image_is_immutable) { -+#ifdef PNGCRUSH_COUNT_COLORS -+ reduce_to_gray = 0; -+ it_is_opaque = 0; -+ output_color_type = input_color_type; -+ if (do_color_count) { -+ if (force_output_color_type == 8 && (input_color_type == 2 || -+ (input_color_type == 3) || -+ input_color_type == 4 -+ || input_color_type == 6)) -+ /* check for unused alpha channel or single transparent color */ -+ { -+ int alpha_status; -+ P1( "Opening file %s for alpha check\n", inname); -+ -+ if ((fpin = FOPEN(inname, "rb")) == NULL) { -+ fprintf(STDERR, "Could not find file: %s\n", inname); -+ continue; -+ } -+ number_of_open_files++; -+ -+ alpha_status = count_colors(fpin); -+ if (num_rgba < 257) { -+ P1("Finished counting colors. num_rgba=%d\n", -+ num_rgba); -+ } else { -+ P1("Finished counting colors. num_rgba is more than 256\n"); -+ } -+ alpha_status = alpha_status; /* silence compiler warning. */ -+ -+ FCLOSE(fpin); -+ -+ if (it_is_opaque) { -+ if (output_color_type == 4) -+ output_color_type = 0; -+ else if (output_color_type == 6) -+ output_color_type = 2; -+ } -+ if (reduce_to_gray) { -+ if (output_color_type == 2) -+ output_color_type = 0; -+ else if (output_color_type == 6) -+ output_color_type = 4; -+ } -+ } -+#if 0 /* TO DO */ -+ if (output_color_type == 0) -+ /* see if bit depth can be reduced */ -+ { -+ } -+ -+ if (input_color_type == 2) -+ /* check for 256 or fewer colors */ -+ { -+ /* TO DO */ -+ } -+ -+ if (input_color_type == 3) -+ /* check for unused palette entries */ -+ { -+ /* TO DO */ -+ } -+#endif -+ if (force_output_color_type == 8 -+ && input_color_type != output_color_type) { -+ P1("setting output color type to %d\n", output_color_type); -+ force_output_color_type = output_color_type; -+ } -+ } -+#else -+ if (do_color_count) -+ printf(" color counting (-cc option) is disabled.\n"); -+#endif /* PNGCRUSH_COUNT_COLORS */ -+ -+ if (force_output_bit_depth != 0 && -+ force_output_bit_depth != 1 && -+ force_output_bit_depth != 2 && -+ force_output_bit_depth != 4 && -+ force_output_bit_depth != 8 && -+ force_output_bit_depth != 16) -+ { -+ fprintf(STDERR, "\n Ignoring invalid bit_depth: %d\n", -+ force_output_bit_depth); -+ force_output_bit_depth=0; -+ } -+ if (force_output_color_type != 8 && -+ force_output_color_type != 0 && -+ force_output_color_type != 2 && -+ force_output_color_type != 3 && -+ force_output_color_type != 4 && -+ force_output_color_type != 6) -+ { -+ fprintf(STDERR, "\n Ignoring invalid color_type: %d\n", -+ force_output_color_type); -+ force_output_color_type=8; -+ } -+ output_color_type = force_output_color_type; -+ output_bit_depth = force_output_bit_depth; -+ -+ if (!methods_specified || try_method[0] == 0) { -+ for (i = 1; i <= DEFAULT_METHODS; i++) -+ try_method[i] = 0; -+ try_method[6] = try_method[0]; -+ } -+ -+ best_of_three = 1; -+ -+ /* //////////////////////////////////////////////////////////////////// -+ //////////////// //////////////////// -+ //////////////// START OF MAIN LOOP OVER METHODS //////////////////// -+ //////////////// //////////////////// -+ //////////////////////////////////////////////////////////////////// */ -+ -+ /* MAX_METHODS is 200 */ -+ P1("\n\nENTERING MAIN LOOP OVER %d METHODS\n", MAX_METHODS); -+ for (trial = 1; trial <= MAX_METHODS; trial++) { -+ idat_length[trial] = (png_uint_32) 0xffffffff; -+ -+ /* this part of if-block is for final write-the-best-file -+ iteration */ -+ if (trial == MAX_METHODS) { -+ png_uint_32 best_length; -+ int j; -+ -+ /* check lengths */ -+ best = 0; /* i.e., input file */ -+ best_length = (png_uint_32) 0xffffffff; -+ for (j = things_have_changed; j < MAX_METHODS; j++) { -+ if (best_length > idat_length[j]) { -+ best_length = idat_length[j]; -+ best = j; -+ } -+ } -+ -+ if (image_is_immutable -+ || (idat_length[best] == idat_length[0] -+ && things_have_changed == 0 -+ && idat_length[best] != idat_length[final_method] -+ && nosave == 0)) -+ { -+ /* just copy input to output */ -+ -+ P2("prepare to copy input to output\n"); -+ png_crush_pause(); -+ -+ if ((fpin = FOPEN(inname, "rb")) == NULL) { -+ fprintf(STDERR, "Could not find input file %s\n", -+ inname); -+ continue; -+ } -+ -+ number_of_open_files++; -+ if ((fpout = FOPEN(outname, "wb")) == NULL) { -+ fprintf(STDERR, "Could not open output file %s\n", -+ outname); -+ FCLOSE(fpin); -+ exit(1); -+ } -+ -+ number_of_open_files++; -+ P2("copying input to output... tc=%d ...", -+ things_have_changed); -+ -+ for (;;) { -+ png_size_t num_in; -+ -+ num_in = fread(buffer, 1, 1, fpin); -+ if (!num_in) -+ break; -+ fwrite(buffer, 1, 1, fpout); -+ } -+ P2("copy complete.\n"); -+ png_crush_pause(); -+ FCLOSE(fpin); -+ FCLOSE(fpout); -+ setfiletype(outname); -+ break; -+ } -+ -+ if (idat_length[best] == idat_length[final_method]) { -+ break; -+ } else { -+ filter_type = fm[best]; -+ zlib_level = lv[best]; -+ if (zs[best] == 1) -+ z_strategy = Z_FILTERED; -+ else if (zs[best] == 2) -+ z_strategy = Z_HUFFMAN_ONLY; -+#ifdef Z_RLE -+ else if (zs[best] == 3) -+ z_strategy = Z_RLE; -+#endif -+ else /* if (zs[best] == 0) */ -+ z_strategy = Z_DEFAULT_STRATEGY; -+ } -+ } else { -+ if (trial > 2 && trial < 5 && idat_length[trial - 1] -+ < idat_length[best_of_three]) -+ best_of_three = trial - 1; -+ if (try_method[trial]) { -+ P2("skipping \"late\" trial %d\n", trial); -+ continue; -+ } -+ if (!methods_specified && try_method[0]) { -+ if ((trial == 4 || trial == 7) && best_of_three != 1) { -+ P2("skipping \"early\" trial %d\n", trial); -+ continue; -+ } -+ if ((trial == 5 || trial == 8) && best_of_three != 2) { -+ P2("skipping \"early\" trial %d\n", trial); -+ continue; -+ } -+ if ((trial == 6 || trial == 9 || trial == 10) -+ && best_of_three != 3) { -+ P2("skipping \"early\" trial %d\n", trial); -+ continue; -+ } -+ } -+ filter_type = fm[trial]; -+ zlib_level = lv[trial]; -+ if (zs[trial] == 1) -+ z_strategy = Z_FILTERED; -+ else if (zs[trial] == 2) -+ z_strategy = Z_HUFFMAN_ONLY; -+#ifdef Z_RLE -+ else if (zs[trial] == 3) -+ z_strategy = Z_RLE; -+#endif -+ else /* if (zs[trial] == 0) */ -+ z_strategy = Z_DEFAULT_STRATEGY; -+ final_method = trial; -+ if (!nosave) { -+ P2("\n\n------------------------------------------------\n" -+ "Begin trial %d, filter %d, strategy %d, level %d\n", -+ trial, filter_type, z_strategy, zlib_level); -+ } -+ } -+ -+ P2("prepare to open files.\n"); -+ png_crush_pause(); -+ -+ if ((fpin = FOPEN(inname, "rb")) == NULL) { -+ fprintf(STDERR, "Could not find input file %s\n", inname); -+ continue; -+ } -+ number_of_open_files++; -+ if (nosave == 0) { -+#ifndef __riscos -+ /* Can't sensibly check this on RISC OS without opening a file -+ for update or output -+ */ -+ struct stat stat_in, stat_out; -+ if (first_trial && !nofilecheck -+ && (stat(inname, &stat_in) == 0) -+ && (stat(outname, &stat_out) == 0) && -+#if defined(_MSC_VER) || defined(__MINGW32__) /* maybe others? */ -+ /* MSVC++6.0 will erroneously return 0 for both files, so -+ we simply check the size instead. It is possible that -+ we will erroneously reject the attempt when inputsize -+ and outputsize are equal, for different files -+ */ -+ (stat_in.st_size == stat_out.st_size) && -+#else -+ (stat_in.st_ino == stat_out.st_ino) && -+#endif -+ (stat_in.st_dev == stat_out.st_dev)) { -+ fprintf(STDERR, -+ "\n Cannot overwrite input file %s\n", -+ outname); -+ P1(" st_ino=%d, st_size=%d\n\n", -+ (int) stat_in.st_ino, (int) stat_in.st_size); -+ FCLOSE(fpin); -+ exit(1); -+ } -+#endif -+ if ((fpout = FOPEN(outname, "wb")) == NULL) { -+ fprintf(STDERR, "Could not open output file %s\n", -+ outname); -+ FCLOSE(fpin); -+ exit(1); -+ } -+ -+ number_of_open_files++; -+ } -+ -+ P2("files are opened.\n"); -+ png_crush_pause(); -+ -+/* OK to ignore any warning about the address of exception__prev in "Try" */ -+ Try { -+ png_uint_32 row_length; -+ P1( "Allocating read and write structures\n"); -+#ifdef PNG_USER_MEM_SUPPORTED -+ read_ptr = png_create_read_struct_2(PNG_LIBPNG_VER_STRING, -+ (png_voidp) NULL, (png_error_ptr) png_cexcept_error, -+ (png_error_ptr) NULL, (png_voidp) NULL, -+ (png_malloc_ptr) png_debug_malloc, -+ (png_free_ptr) png_debug_free); -+#else -+ read_ptr = png_create_read_struct(PNG_LIBPNG_VER_STRING, -+ (png_voidp) NULL, (png_error_ptr) png_cexcept_error, -+ (png_error_ptr) NULL); -+#endif -+ if (read_ptr == NULL) -+ Throw "pngcrush could not create read_ptr"; -+ -+ if (nosave == 0) { -+#ifdef PNG_USER_MEM_SUPPORTED -+ write_ptr = png_create_write_struct_2(PNG_LIBPNG_VER_STRING, -+ (png_voidp) NULL, (png_error_ptr) png_cexcept_error, -+ (png_error_ptr) NULL, (png_voidp) NULL, -+ (png_malloc_ptr) png_debug_malloc, -+ (png_free_ptr) png_debug_free); -+#else -+ write_ptr = png_create_write_struct(PNG_LIBPNG_VER_STRING, -+ (png_voidp) NULL, (png_error_ptr) png_cexcept_error, -+ (png_error_ptr) NULL); -+#endif -+ if (write_ptr == NULL) -+ Throw "pngcrush could not create write_ptr"; -+ -+ } -+ P1("Allocating read_info, write_info, end_info structures\n"); -+ read_info_ptr = png_create_info_struct(read_ptr); -+ if (read_info_ptr == NULL) -+ Throw "pngcrush could not create read_info_ptr"; -+ end_info_ptr = png_create_info_struct(read_ptr); -+ if (end_info_ptr == NULL) -+ Throw "pngcrush could not create end_info_ptr"; -+ if (nosave == 0) { -+ write_info_ptr = png_create_info_struct(write_ptr); -+ if (write_info_ptr == NULL) -+ Throw "pngcrush could not create write_info_ptr"; -+ write_end_info_ptr = png_create_info_struct(write_ptr); -+ if (write_end_info_ptr == NULL) -+ Throw -+ "pngcrush could not create write_end_info_ptr"; -+ } -+ -+ P2("structures created.\n"); -+ png_crush_pause(); -+ -+ P1( "Initializing input and output streams\n"); -+#if !defined(PNG_NO_STDIO) -+ png_init_io(read_ptr, fpin); -+ if (nosave == 0) -+ png_init_io(write_ptr, fpout); -+#else -+ png_set_read_fn(read_ptr, (png_voidp) fpin, -+ (png_rw_ptr) NULL); -+ if (nosave == 0) -+ png_set_write_fn(write_ptr, (png_voidp) fpout, -+ (png_rw_ptr) NULL, -+#if defined(PNG_WRITE_FLUSH_SUPPORTED) -+ png_default_flush); -+#else -+ NULL); -+#endif -+#endif -+ -+ P2("io has been initialized.\n"); -+ png_crush_pause(); -+ -+ /* We don't need to check CRC's because they were already -+ checked in the png_measure_idat function */ -+ -+#ifdef PNG_CRC_QUIET_USE -+ png_set_crc_action(read_ptr, PNG_CRC_QUIET_USE, -+ PNG_CRC_QUIET_USE); -+#endif -+ -+#if defined(PNG_READ_UNKNOWN_CHUNKS_SUPPORTED) -+ png_set_keep_unknown_chunks(read_ptr, PNG_HANDLE_CHUNK_ALWAYS, -+ (png_bytep) NULL, 0); -+#endif -+#if defined(PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED) -+ if (nosave == 0) { -+ if (found_any_chunk == 1) -+ png_set_keep_unknown_chunks(write_ptr, -+ PNG_HANDLE_CHUNK_ALWAYS, -+ (png_bytep) "dSIG", 1); -+ if (all_chunks_are_safe) -+ png_set_keep_unknown_chunks(write_ptr, -+ PNG_HANDLE_CHUNK_ALWAYS, -+ (png_bytep) NULL, 0); -+ else { -+#if !defined(PNG_cHRM_SUPPORTED) || !defined(PNG_hIST_SUPPORTED) || \ -+ !defined(PNG_iCCP_SUPPORTED) || !defined(PNG_sCAL_SUPPORTED) || \ -+ !defined(PNG_pCAL_SUPPORTED) || !defined(PNG_sPLT_SUPPORTED) || \ -+ !defined(PNG_tIME_SUPPORTED) -+ png_byte chunk_name[5]; -+ chunk_name[4] = '\0'; -+#endif -+ -+ if (keep_unknown_chunk("alla", argv) && -+ keep_unknown_chunk("allb", argv)) -+ png_set_keep_unknown_chunks(write_ptr, -+ PNG_HANDLE_CHUNK_IF_SAFE, -+ (png_bytep) NULL, -+ 0); -+ else -+ png_set_keep_unknown_chunks(write_ptr, -+ PNG_HANDLE_CHUNK_NEVER, -+ (png_bytep) NULL, -+ 0); -+ -+#if !defined(PNG_cHRM_SUPPORTED) -+ if (keep_unknown_chunk("cHRM", argv)) { -+ png_save_uint_32(chunk_name, PNG_UINT_cHRM); -+ png_set_keep_unknown_chunks(write_ptr, -+ PNG_HANDLE_CHUNK_ALWAYS, -+ chunk_name, 1); -+ } -+#endif -+#if !defined(PNG_hIST_SUPPORTED) -+ if (keep_unknown_chunk("hIST", argv)) { -+ png_save_uint_32(chunk_name, PNG_UINT_hIST); -+ png_set_keep_unknown_chunks(write_ptr, -+ PNG_HANDLE_CHUNK_ALWAYS, -+ chunk_name, 1); -+ } -+#endif -+#if !defined(PNG_iCCP_SUPPORTED) -+ if (keep_unknown_chunk("iCCP", argv)) { -+ png_save_uint_32(chunk_name, PNG_UINT_iCCP); -+ png_set_keep_unknown_chunks(write_ptr, -+ PNG_HANDLE_CHUNK_ALWAYS, -+ chunk_name, 1); -+ } -+#endif -+#if !defined(PNG_sCAL_SUPPORTED) -+ if (keep_unknown_chunk("sCAL", argv)) { -+ png_save_uint_32(chunk_name, PNG_UINT_sCAL); -+ png_set_keep_unknown_chunks(write_ptr, -+ PNG_HANDLE_CHUNK_ALWAYS, -+ chunk_name, 1); -+ } -+#endif -+#if !defined(PNG_pCAL_SUPPORTED) -+ if (keep_unknown_chunk("pCAL", argv)) { -+ png_save_uint_32(chunk_name, PNG_UINT_pCAL); -+ png_set_keep_unknown_chunks(write_ptr, -+ PNG_HANDLE_CHUNK_ALWAYS, -+ chunk_name, 1); -+ } -+#endif -+#if !defined(PNG_sPLT_SUPPORTED) -+ if (keep_unknown_chunk("sPLT", argv)) { -+ png_save_uint_32(chunk_name, PNG_UINT_sPLT); -+ png_set_keep_unknown_chunks(write_ptr, -+ PNG_HANDLE_CHUNK_ALWAYS, -+ chunk_name, 1); -+ } -+#endif -+#if !defined(PNG_tIME_SUPPORTED) -+ if (keep_unknown_chunk("tIME", argv)) { -+ png_save_uint_32(chunk_name, PNG_UINT_tIME); -+ png_set_keep_unknown_chunks(write_ptr, -+ PNG_HANDLE_CHUNK_ALWAYS, -+ chunk_name, 1); -+ } -+#endif -+ } -+ } -+#endif /* PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED */ -+ -+ P1( "Reading info struct\n"); -+ { -+#if defined(PNGCRUSH_LOCO) -+ png_byte mng_signature[8] = -+ { 138, 77, 78, 71, 13, 10, 26, 10 }; -+#endif -+ png_byte png_signature[8] = -+ { 137, 80, 78, 71, 13, 10, 26, 10 }; -+ -+ png_default_read_data(read_ptr, png_signature, 8); -+ png_set_sig_bytes(read_ptr, 8); -+ -+#if defined(PNGCRUSH_LOCO) -+ if (!(int) -+ (png_memcmp(mng_signature, png_signature, 8))) { -+ png_byte buffer[40]; -+ unsigned long length; -+ /* Skip the MHDR */ -+ png_permit_mng_features(read_ptr, -+ PNG_FLAG_MNG_FILTER_64); -+ png_default_read_data(read_ptr, buffer, 4); -+ length=buffer[3]+(buffer[2]<<8)+(buffer[1]<<16)+(buffer[0]<<24); -+ png_default_read_data(read_ptr, buffer, 4); -+ printf("Skipping %c%c%c%c chunk.\n",buffer[0],buffer[1], -+ buffer[2],buffer[3]); -+ png_default_read_data(read_ptr, buffer, length); -+ png_default_read_data(read_ptr, buffer, 4); -+ input_format = 1; -+ } else -+#endif -+ if (png_sig_cmp(png_signature, 0, 8)) { -+ if (png_sig_cmp(png_signature, 0, 4)) -+ png_error(read_ptr, "Not a PNG file!"); -+ else -+ png_error(read_ptr, -+ "PNG file corrupted by ASCII conversion"); -+ } -+ } -+ -+ png_read_info(read_ptr, read_info_ptr); -+ -+ /* { GRR added for quick %-navigation (1) */ -+ -+ /* Start of chunk-copying/removal code, in order: -+ * - IHDR -+ * - bKGD -+ * - cHRM -+ * - gAMA -+ * - sRGB -+ * - iCCP -+ * - oFFs -+ * - pCAL -+ * - pHYs -+ * - hIST -+ * - tRNS -+ * - PLTE -+ * - sBIT -+ * - sCAL -+ * - sPLT -+ * - tEXt/zTXt/iTXt -+ * - tIME -+ * - unknown chunks -+ */ -+ { -+ int interlace_method, compression_method, -+ filter_method; -+ -+ P1( "Transferring info struct\n"); -+ -+ if (png_get_IHDR -+ (read_ptr, read_info_ptr, &width, &height, -+ &bit_depth, &color_type, &interlace_method, -+ &compression_method, &filter_method)) { -+ int need_expand = 0; -+ input_color_type = color_type; -+ input_bit_depth = bit_depth; -+ -+ if (output_color_type > 7) { -+ output_color_type = input_color_type; -+ } -+ -+ if (verbose > 1 && first_trial) { -+ fprintf(STDERR, " IHDR chunk data:\n"); -+ fprintf(STDERR, -+ " Width=%lu, height=%lu\n", -+ (unsigned long)width, -+ (unsigned long)height); -+ fprintf(STDERR, " Bit depth =%d\n", -+ bit_depth); -+ fprintf(STDERR, " Color type=%d\n", -+ color_type); -+ if (output_color_type != color_type) -+ fprintf(STDERR, -+ " Output color type=%d\n", -+ output_color_type); -+ fprintf(STDERR, " Interlace =%d\n", -+ interlace_method); -+ } -+ -+#ifndef PNG_WRITE_PACK_SUPPORTED -+ if (output_bit_depth == 0) -+#else -+ if (force_output_bit_depth == 0) -+#endif -+ { -+ output_bit_depth = input_bit_depth; -+ } -+ if ((output_color_type != 3 -+ || output_bit_depth > 8) -+ && output_bit_depth >= 8 -+ && output_bit_depth != input_bit_depth) -+ need_expand = 1; -+ -+#if defined(PNG_READ_RGB_TO_GRAY_SUPPORTED) -+ if ((color_type == 2 || color_type == 6 -+ || color_type == 3) && -+ (output_color_type == 0 || output_color_type == 4)) -+ { -+ if (verbose > 0 && first_trial) { -+#ifdef PNGCRUSH_COUNT_COLORS -+ if (reduce_to_gray) -+ fprintf(STDERR, " Reducing all-gray " -+ "truecolor image to grayscale.\n"); -+ else -+#endif -+ fprintf(STDERR, " Reducing truecolor " -+ "image to grayscale.\n"); -+ } -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ png_set_rgb_to_gray_fixed(read_ptr, 1, -1, -1); -+#else -+ png_set_rgb_to_gray(read_ptr, 1, 0., 0.); -+#endif -+ if (output_bit_depth < 8) -+ output_bit_depth = 8; -+ if (color_type == 3) -+ need_expand = 1; -+ } -+#endif -+ -+ if (color_type != 3 && output_color_type == 3) { -+ printf(" Cannot change to indexed color " -+ "(color_type 3)\n"); -+ output_color_type = input_color_type; -+ } -+ -+ if ((color_type == 0 || color_type == 4) && -+ (output_color_type == 2 -+ || output_color_type == 6)) { -+ png_set_gray_to_rgb(read_ptr); -+ } -+ -+ if ((color_type == 4 || color_type == 6) && -+ (output_color_type != 4 -+ && output_color_type != 6)) { -+ if (verbose > 0 && first_trial) { -+#ifdef PNGCRUSH_COUNT_COLORS -+ if (it_is_opaque) -+ fprintf(STDERR, -+ " Stripping opaque alpha channel.\n"); -+ else -+#endif -+ fprintf(STDERR, -+ " Stripping existing alpha channel.\n"); -+ } -+#ifdef PNG_READ_STRIP_ALPHA_SUPPORTED -+ png_set_strip_alpha(read_ptr); -+#endif -+ } -+ -+ if ((output_color_type == 4 -+ || output_color_type == 6) && (color_type != 4 -+ && color_type -+ != 6)) { -+ if (verbose > 0 && first_trial) -+ fprintf(STDERR, -+ " Adding an opaque alpha channel.\n"); -+#ifdef PNG_READ_FILLER_SUPPORTED -+ png_set_filler(read_ptr, (png_uint_32) 65535L, -+ PNG_FILLER_AFTER); -+#endif -+ need_expand = 1; -+ } -+ -+ if (output_color_type && output_color_type != 3 && -+ output_bit_depth < 8) -+ output_bit_depth = 8; -+ -+ if ((output_color_type == 2 -+ || output_color_type == 6) -+ && color_type == 3) { -+ if (verbose > 0 && first_trial) -+ fprintf(STDERR, -+ " Expanding indexed color file.\n"); -+ need_expand = 1; -+ } -+#ifdef PNG_READ_EXPAND_SUPPORTED -+ if (need_expand == 1) -+ png_set_expand(read_ptr); -+#endif -+ -+#ifdef PNG_READ_PACK_SUPPORTED -+ if (input_bit_depth < 8) { -+ png_set_packing(read_ptr); -+ } -+ if (output_color_type == 0 && output_bit_depth < 8) { -+ png_color_8 true_bits; -+ true_bits.gray = (png_byte) (output_bit_depth); -+ png_set_shift(read_ptr, &true_bits); -+ } -+#endif -+ -+ if (verbose > 1) -+ fprintf(STDERR, " Setting IHDR\n"); -+ -+#if defined(PNGCRUSH_LOCO) -+ output_format = 0; -+ if (do_loco) { -+ if (output_color_type == 2 -+ || output_color_type == 6) { -+ output_format = 1; -+ filter_method = 64; -+ png_permit_mng_features(write_ptr, -+ PNG_FLAG_MNG_FILTER_64); -+ } -+ } else -+ filter_method = 0; -+ if (input_format != output_format) -+ things_have_changed = 1; -+#endif -+ -+ png_set_IHDR(write_ptr, write_info_ptr, width, -+ height, output_bit_depth, -+ output_color_type, interlace_method, -+ compression_method, filter_method); -+ -+ if (output_color_type != input_color_type) -+ things_have_changed = 1; -+ -+ } -+ } -+ -+#if defined(PNG_READ_bKGD_SUPPORTED) && defined(PNG_WRITE_bKGD_SUPPORTED) -+ { -+ png_color_16p background; -+ -+ if (!have_bkgd -+ && png_get_bKGD(read_ptr, read_info_ptr, -+ &background)) { -+ if (keep_chunk("bKGD", argv)) { -+ if ((input_color_type == 2 -+ || input_color_type == 6) -+ && (output_color_type == 0 -+ || output_color_type == 4)) -+ background->gray = background->green; -+ png_set_bKGD(write_ptr, write_info_ptr, -+ background); -+ } -+ } -+ if (have_bkgd) { -+ /* If we are reducing an RGB image to grayscale, but -+ the background color isn't gray, the green channel -+ is written. That's not spec-compliant. We should -+ really check for a non-gray bKGD and refuse to do -+ the reduction if one is present. */ -+ png_color_16 backgd; -+ png_color_16p background = &backgd; -+ background->red = bkgd_red; -+ background->green = bkgd_green; -+ background->blue = bkgd_blue; -+ background->gray = background->green; -+ png_set_bKGD(write_ptr, write_info_ptr, -+ background); -+ } -+ } -+#endif /* defined(PNG_READ_bKGD_SUPPORTED)&&defined(PNG_WRITE_bKGD_SUPPORTED) */ -+ -+#if defined(PNG_READ_cHRM_SUPPORTED) && defined(PNG_WRITE_cHRM_SUPPORTED) -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ { -+ png_fixed_point white_x, white_y, red_x, red_y, -+ green_x, green_y, blue_x, blue_y; -+ -+ if (found_cHRM && png_get_cHRM_fixed -+ (read_ptr, read_info_ptr, &white_x, &white_y, -+ &red_x, &red_y, &green_x, &green_y, &blue_x, -+ &blue_y)) { -+ if (keep_chunk("cHRM", argv)) { -+ if (white_x == 0 && white_y == 0 && red_x == 0 -+ && red_y == 0 && green_x == 0 -+ && green_y == 0 && blue_x == 0 -+ && blue_y == 0) -+ png_warning(write_ptr, -+ "Deleting all-zero cHRM chunk"); -+ else -+ png_set_cHRM_fixed(write_ptr, -+ write_info_ptr, white_x, -+ white_y, red_x, red_y, -+ green_x, green_y, -+ blue_x, blue_y); -+ } -+ } -+ } -+#else -+ { -+ double white_x, white_y, red_x, red_y, green_x, -+ green_y, blue_x, blue_y; -+ -+ if (png_get_cHRM -+ (read_ptr, read_info_ptr, &white_x, &white_y, -+ &red_x, &red_y, &green_x, &green_y, &blue_x, -+ &blue_y)) { -+ if (keep_chunk("cHRM", argv)) { -+ if (white_x == 0 && white_y == 0 && red_x == 0 -+ && red_y == 0 && green_x == 0 -+ && green_y == 0 && blue_x == 0 -+ && blue_y == 0) -+ png_warning(write_ptr, -+ "Deleting all-zero cHRM chunk"); -+ else -+ png_set_cHRM(write_ptr, write_info_ptr, -+ white_x, white_y, red_x, -+ red_y, green_x, green_y, -+ blue_x, blue_y); -+ } -+ } -+ } -+#endif /* ?PNG_FIXED_POINT_SUPPORTED */ -+#endif /* defined(PNG_READ_cHRM_SUPPORTED)&&defined(PNG_WRITE_cHRM_SUPPORTED) */ -+ -+#if defined(PNG_READ_gAMA_SUPPORTED) && defined(PNG_WRITE_gAMA_SUPPORTED) -+ { -+ if (force_specified_gamma) { -+ if (first_trial) { -+ things_have_changed = 1; -+ if (verbose > 0) -+ fprintf(STDERR, " Inserting gAMA chunk with " -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ "gamma=(%d/100000)\n", -+#else -+ "gamma=%f\n", -+#endif -+ force_specified_gamma); -+ } -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ png_set_gAMA_fixed(write_ptr, write_info_ptr, -+ (png_fixed_point) -+ force_specified_gamma); -+ file_gamma = -+ (png_fixed_point) force_specified_gamma; -+#else -+ png_set_gAMA(write_ptr, write_info_ptr, -+ force_specified_gamma); -+ file_gamma = force_specified_gamma; -+#endif -+ } -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ else if (found_gAMA && png_get_gAMA_fixed -+ (read_ptr, read_info_ptr, &file_gamma)) -+#else -+ else if (found_gAMA && png_get_gAMA -+ (read_ptr, read_info_ptr, &file_gamma)) -+#endif -+ { -+ if (keep_chunk("gAMA", argv)) { -+ if (image_specified_gamma) -+ file_gamma = image_specified_gamma; -+ if (verbose > 1 && first_trial) -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ fprintf(STDERR, " gamma=(%d/100000)\n", -+ (int) file_gamma); -+ if (double_gamma) -+ file_gamma += file_gamma; -+ png_set_gAMA_fixed(write_ptr, write_info_ptr, -+ file_gamma); -+#else -+ fprintf(STDERR, " gamma=%f\n", -+ file_gamma); -+ if (double_gamma) -+ file_gamma += file_gamma; -+ png_set_gAMA(write_ptr, write_info_ptr, -+ file_gamma); -+#endif -+ } -+ } else if (specified_gamma) { -+ if (first_trial) { -+ things_have_changed = 1; -+ if (verbose > 0) -+ fprintf(STDERR, " Inserting gAMA chunk with " -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ "gamma=(%d/100000)\n", -+#else -+ "gamma=%f\n", -+#endif -+ specified_gamma); -+ } -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ png_set_gAMA_fixed(write_ptr, write_info_ptr, -+ specified_gamma); -+ file_gamma = (png_fixed_point) specified_gamma; -+#else -+ png_set_gAMA(write_ptr, write_info_ptr, -+ specified_gamma); -+ file_gamma = specified_gamma; -+#endif -+ } -+ } -+#endif /* defined(PNG_READ_gAMA_SUPPORTED)&&defined(PNG_WRITE_gAMA_SUPPORTED) */ -+ -+#if defined(PNG_READ_sRGB_SUPPORTED) && defined(PNG_WRITE_sRGB_SUPPORTED) -+ { -+ int file_intent; -+ -+ if (png_get_sRGB -+ (read_ptr, read_info_ptr, &file_intent)) { -+ if (keep_chunk("sRGB", argv)) { -+ png_set_sRGB(write_ptr, write_info_ptr, -+ file_intent); -+ intent = file_intent; -+ } -+ } else if (intent >= 0) { -+#ifdef PNG_gAMA_SUPPORTED -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ if (file_gamma >= 45000L && file_gamma <= 46000L) -+#else -+ if (file_gamma >= 0.45000 && file_gamma <= 0.46000) -+#endif -+ { -+ things_have_changed = 1; -+ if (first_trial) -+ fprintf(STDERR, -+ " Inserting sRGB chunk with intent=%d\n", -+ intent); -+ png_set_sRGB(write_ptr, write_info_ptr, -+ intent); -+ } else if (file_gamma != 0) { -+ if (first_trial) { -+ fprintf(STDERR, " Ignoring sRGB request; " -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ "gamma=(%lu/100000)" -+#else -+ "gamma=%f" -+#endif -+ " is not approx. 0.455\n", -+ (unsigned long)file_gamma); -+ } -+ } -+#endif /* PNG_gAMA_SUPPORTED */ -+ } -+ } -+#endif /* defined(PNG_READ_sRGB_SUPPORTED)&&defined(PNG_WRITE_sRGB_SUPPORTED) */ -+ -+#if defined(PNG_READ_iCCP_SUPPORTED) && defined(PNG_WRITE_iCCP_SUPPORTED) -+ if (intent < 0) { /* ignore iCCP if sRGB is being written */ -+ png_charp name; -+ png_charp profile; -+ png_uint_32 proflen; -+ int compression_method; -+ -+ if (png_get_iCCP -+ (read_ptr, read_info_ptr, &name, -+ &compression_method, &profile, &proflen)) { -+ P1("Got iCCP chunk, proflen=%lu\n", -+ (unsigned long)proflen); -+ if (iccp_length) -+ P0("Will not replace existing iCCP chunk.\n"); -+ if (keep_chunk("iCCP", argv)) -+ png_set_iCCP(write_ptr, write_info_ptr, name, -+ compression_method, profile, -+ proflen); -+ -+ } -+#ifdef PNG_iCCP_SUPPORTED -+ else if (iccp_length) { -+ png_set_iCCP(write_ptr, write_info_ptr, iccp_name, -+ 0, iccp_text, iccp_length); -+ P1("Wrote iCCP chunk, proflen=%d\n", iccp_length); -+ } -+#endif -+ -+ } -+#endif /* defined(PNG_READ_iCCP_SUPPORTED)&&defined(PNG_WRITE_iCCP_SUPPORTED) */ -+ -+#if defined(PNG_READ_oFFs_SUPPORTED) && defined(PNG_WRITE_oFFs_SUPPORTED) -+ { -+ png_int_32 offset_x, offset_y; -+ int unit_type; -+ -+ if (png_get_oFFs -+ (read_ptr, read_info_ptr, &offset_x, &offset_y, -+ &unit_type)) { -+ if (offset_x == 0 && offset_y == 0) { -+ if (verbose > 0 && first_trial) -+ fprintf(STDERR, -+ " Deleting useless oFFs 0 0 chunk\n"); -+ } else { -+ if (keep_chunk("oFFs", argv)) -+ png_set_oFFs(write_ptr, write_info_ptr, -+ offset_x, offset_y, -+ unit_type); -+ } -+ } -+ } -+#endif -+ -+#if defined(PNG_READ_pCAL_SUPPORTED) && defined(PNG_WRITE_pCAL_SUPPORTED) -+ { -+ png_charp purpose, units; -+ png_charpp params; -+ png_int_32 X0, X1; -+ int type, nparams; -+ -+ if (png_get_pCAL -+ (read_ptr, read_info_ptr, &purpose, &X0, &X1, -+ &type, &nparams, &units, ¶ms)) { -+ if (keep_chunk("pCAL", argv)) -+ png_set_pCAL(write_ptr, write_info_ptr, -+ purpose, X0, X1, type, nparams, -+ units, params); -+ } -+ } -+#endif -+ -+#if defined(PNG_READ_pHYs_SUPPORTED) && defined(PNG_WRITE_pHYs_SUPPORTED) -+ { -+ png_uint_32 res_x, res_y; -+ int unit_type; -+ -+ if (resolution == 0) { -+ if (png_get_pHYs -+ (read_ptr, read_info_ptr, &res_x, &res_y, -+ &unit_type)) { -+ if (res_x == 0 && res_y == 0) { -+ if (verbose > 0 && first_trial) -+ fprintf(STDERR, -+ " Deleting useless pHYs 0 0 chunk\n"); -+ } else { -+ if (keep_chunk("pHYs", argv)) -+ png_set_pHYs(write_ptr, write_info_ptr, -+ res_x, res_y, unit_type); -+ } -+ } -+ } else { -+ unit_type = 1; -+ res_x = res_y = -+ (png_uint_32) ((resolution / .0254 + 0.5)); -+ png_set_pHYs(write_ptr, write_info_ptr, res_x, -+ res_y, unit_type); -+ if (verbose > 0 && first_trial) -+ fprintf(STDERR, " Added pHYs %lu %lu 1 chunk\n", -+ (unsigned long)res_x, -+ (unsigned long)res_y); -+ } -+ } -+#endif -+ -+#if defined(PNG_READ_hIST_SUPPORTED) && defined(PNG_WRITE_hIST_SUPPORTED) -+ { -+ png_uint_16p hist; -+ -+ if (png_get_hIST(read_ptr, read_info_ptr, &hist)) { -+ if (keep_chunk("hIST", argv)) -+ png_set_hIST(write_ptr, write_info_ptr, hist); -+ } -+ } -+#endif -+ -+#if defined(PNG_READ_tRNS_SUPPORTED) && defined(PNG_WRITE_tRNS_SUPPORTED) -+ { -+ png_bytep trans; -+ int num_trans; -+ png_color_16p trans_values; -+ -+ if (png_get_tRNS -+ (read_ptr, read_info_ptr, &trans, &num_trans, -+ &trans_values)) { -+ if (verbose > 1) -+ fprintf(STDERR, -+ " Found tRNS chunk in input file.\n"); -+ if (have_trns == 1) { -+ P0(" Will not overwrite existing tRNS chunk.\n"); -+ } -+ if (keep_chunk("tRNS", argv)) { -+ int last_nonmax = -1; -+ trns_red = trans_values->red; -+ trns_green = trans_values->green; -+ trns_blue = trans_values->blue; -+ trns_gray = trans_values->gray; -+ if (output_color_type == 3) { -+ for (ia = 0; ia < num_trans; ia++) -+ trns_array[ia] = trans[ia]; -+ for (; ia < 256; ia++) -+ trns_array[ia] = 255; -+ for (ia = 0; ia < 256; ia++) { -+ if (trns_array[ia] != 255) -+ last_nonmax = ia; -+ } -+ if (first_trial && verbose > 0) { -+ if (last_nonmax < 0) -+ fprintf(STDERR, " Deleting " -+ "all-opaque tRNS chunk.\n"); -+ else if (last_nonmax + 1 < num_trans) -+ fprintf(STDERR, -+ " Truncating trailing opaque " -+ "entries from tRNS chunk.\n"); -+ } -+ num_trans = last_nonmax + 1; -+ } -+ if (verbose > 1) -+ fprintf(STDERR, -+ " png_set_tRNS, num_trans=%d\n", -+ num_trans); -+ if (output_color_type != 3 || num_trans) -+ png_set_tRNS(write_ptr, write_info_ptr, -+ trans, num_trans, -+ trans_values); -+ } -+ } else if (have_trns == 1) { /* will not overwrite existing trns data */ -+ png_color_16 trans_data; -+ png_byte index_data = (png_byte) trns_index; -+ num_trans = index_data + 1; -+ if (verbose > 1) -+ fprintf(STDERR, "Have_tRNS, num_trans=%d\n", -+ num_trans); -+ if (output_color_type == 3) { -+ trans_values = NULL; -+ for (ia = 0; ia < num_trans; ia++) -+ trns_array[ia] = trans_in[ia]; -+ for (; ia < 256; ia++) -+ trns_array[ia] = 255; -+ } else { -+ for (ia = 0; ia < 256; ia++) -+ trns_array[ia] = 255; -+ trns_array[index_data] = 0; -+ -+ trans_data.index = index_data; -+ trans_data.red = trns_red; -+ trans_data.green = trns_green; -+ trans_data.blue = trns_blue; -+ trans_data.gray = trns_gray; -+ trans_values = &trans_data; -+ } -+ -+ P0(" Adding a tRNS chunk\n"); -+ png_set_tRNS(write_ptr, write_info_ptr, trns_array, -+ num_trans, trans_values); -+ -+ things_have_changed = 1; -+ } else { -+ for (ia = 0; ia < 256; ia++) -+ trns_array[ia] = 255; -+ } -+ if (verbose > 1 && first_trial) { -+ int last = -1; -+ for (i = 0; ia < num_palette; ia++) -+ if (trns_array[ia] != 255) -+ last = ia; -+ if (last >= 0) { -+ fprintf(STDERR, " Transparency:\n"); -+ if (output_color_type == 3) -+ for (i = 0; ia < num_palette; ia++) -+ fprintf(STDERR, " %4d %4d\n", ia, -+ trns_array[ia]); -+ else if (output_color_type == 0) -+ fprintf(STDERR, " %d\n", trns_gray); -+ else if (output_color_type == 2) -+ fprintf(STDERR, " %d %d %d\n", -+ trns_red, trns_green, trns_blue); -+ } -+ } -+ } -+#endif /* defined(PNG_READ_tRNS_SUPPORTED)&&defined(PNG_WRITE_tRNS_SUPPORTED) */ -+ -+ if (png_get_PLTE -+ (read_ptr, read_info_ptr, &palette, &num_palette)) -+ { -+ if (plte_len > 0) -+ num_palette = plte_len; -+ if (do_pplt) { -+ printf("PPLT: %s\n", pplt_string); -+ printf("Sorry, PPLT is not implemented yet.\n"); -+ } -+ if (output_color_type == 3) -+ png_set_PLTE(write_ptr, write_info_ptr, palette, -+ num_palette); -+ else if (keep_chunk("PLTE", argv)) -+ png_set_PLTE(write_ptr, write_info_ptr, palette, -+ num_palette); -+ if (verbose > 1 && first_trial) { -+ int i; -+ png_colorp p = palette; -+ fprintf(STDERR, " Palette:\n"); -+ fprintf(STDERR, -+ " I R G B ( color ) A\n"); -+ for (i = 0; i < num_palette; i++) { -+ fprintf(STDERR, -+ " %4d %4d %4d %4d (#%2.2x%2.2x%2.2x) %4d\n", -+ i, p->red, p->green, p->blue, p->red, -+ p->green, p->blue, trns_array[i]); -+ p++; -+ } -+ } -+ } -+ -+ -+#if defined(PNG_READ_sBIT_SUPPORTED) && defined(PNG_WRITE_sBIT_SUPPORTED) -+ { -+ png_color_8p sig_bit; -+ -+ /* If we are reducing a truecolor PNG to grayscale, and the -+ * RGB sBIT values aren't identical, we'll lose sBIT info. -+ */ -+ if (png_get_sBIT(read_ptr, read_info_ptr, &sig_bit)) { -+ if (keep_chunk("sBIT", argv)) { -+ if ((input_color_type == 0 -+ || input_color_type == 4) -+ && (output_color_type == 2 -+ || output_color_type == 6 -+ || output_color_type == 3)) -+ sig_bit->red = sig_bit->green = -+ sig_bit->blue = sig_bit->gray; -+ if ((input_color_type == 2 -+ || input_color_type == 6 -+ || output_color_type == 3) -+ && (output_color_type == 0 -+ || output_color_type == 4)) -+ sig_bit->gray = sig_bit->green; -+ -+ if ((input_color_type == 0 -+ || input_color_type == 2) -+ && (output_color_type == 4 -+ || output_color_type == 6)) -+ sig_bit->alpha = 1; -+ -+ png_set_sBIT(write_ptr, write_info_ptr, -+ sig_bit); -+ } -+ } -+ } -+#endif /* defined(PNG_READ_sBIT_SUPPORTED)&&defined(PNG_WRITE_sBIT_SUPPORTED) */ -+ -+#if defined(PNG_sCAL_SUPPORTED) -+#ifdef PNG_FLOATING_POINT_SUPPORTED -+ { -+ int unit; -+ double scal_width, scal_height; -+ -+ if (png_get_sCAL -+ (read_ptr, read_info_ptr, &unit, &scal_width, -+ &scal_height)) { -+ png_set_sCAL(write_ptr, write_info_ptr, unit, -+ scal_width, scal_height); -+ } -+ } -+#else -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ { -+ int unit; -+ png_charp scal_width, scal_height; -+ -+ if (png_get_sCAL_s -+ (read_ptr, read_info_ptr, &unit, &scal_width, -+ &scal_height)) { -+ if (keep_chunk("sCAL", argv)) -+ png_set_sCAL_s(write_ptr, write_info_ptr, unit, -+ scal_width, scal_height); -+ } -+ } -+#endif -+#endif /* PNG_FLOATING_POINT_SUPPORTED */ -+#endif /* ?PNG_sCAL_SUPPORTED */ -+ -+#if defined(PNG_sPLT_SUPPORTED) -+ { -+ png_sPLT_tp entries; -+ int num_entries; -+ -+ num_entries = -+ (int) png_get_sPLT(read_ptr, read_info_ptr, -+ &entries); -+ if (num_entries) { -+ if (keep_chunk("sPLT", argv)) -+ png_set_sPLT(write_ptr, write_info_ptr, -+ entries, num_entries); -+ png_free_data(read_ptr, read_info_ptr, -+ PNG_FREE_SPLT, num_entries); -+ } -+ } -+#endif -+ -+#if defined(PNG_TEXT_SUPPORTED) -+ { -+ png_textp text_ptr; -+ int num_text = 0; -+ -+ if (png_get_text -+ (read_ptr, read_info_ptr, &text_ptr, &num_text) > 0 -+ || text_inputs) { -+ int ntext; -+ P1( "Handling %d tEXt/zTXt chunks\n", -+ num_text); -+ -+ if (verbose > 1 && first_trial && num_text > 0) { -+ for (ntext = 0; ntext < num_text; ntext++) { -+ fprintf(STDERR, "%d %s", ntext, -+ text_ptr[ntext].key); -+ if (text_ptr[ntext].text_length) -+ fprintf(STDERR, ": %s\n", -+ text_ptr[ntext].text); -+#ifdef PNG_iTXt_SUPPORTED -+ else if (text_ptr[ntext].itxt_length) { -+ fprintf(STDERR, " (%s: %s): \n", -+ text_ptr[ntext].lang, -+ text_ptr[ntext].lang_key); -+ fprintf(STDERR, "%s\n", -+ text_ptr[ntext].text); -+ } -+#endif -+ else -+ fprintf(STDERR, "\n"); -+ } -+ } -+ -+ if (num_text > 0) { -+ if (keep_chunk("text", argv)) { -+ int num_to_write = num_text; -+ for (ntext = 0; ntext < num_text; ntext++) { -+ if (first_trial) -+ P2("Text chunk before IDAT, " -+ "compression=%d\n", -+ text_ptr[ntext].compression); -+ if (text_ptr[ntext].compression == -+ PNG_TEXT_COMPRESSION_NONE) { -+ if (!keep_chunk("tEXt", argv)) { -+ text_ptr[ntext].key[0] = '\0'; -+ num_to_write--; -+ } -+ } -+ if (text_ptr[ntext].compression == -+ PNG_TEXT_COMPRESSION_zTXt) { -+ if (!keep_chunk("zTXt", argv)) { -+ text_ptr[ntext].key[0] = '\0'; -+ num_to_write--; -+ } -+ } -+#ifdef PNG_iTXt_SUPPORTED -+ if (text_ptr[ntext].compression == -+ PNG_ITXT_COMPRESSION_NONE -+ || text_ptr[ntext].compression == -+ PNG_ITXT_COMPRESSION_zTXt) { -+ if (!keep_chunk("iTXt", argv)) { -+ text_ptr[ntext].key[0] = '\0'; -+ num_to_write--; -+ } -+ } -+#endif -+ } -+ if (num_to_write > 0) -+ png_set_text(write_ptr, write_info_ptr, -+ text_ptr, num_text); -+ } -+ } -+ for (ntext = 0; ntext < text_inputs; ntext++) { -+ if (text_where[ntext] == 1) { -+ png_textp added_text; -+ added_text = (png_textp) png_malloc(write_ptr, -+ (png_uint_32) sizeof(png_text)); -+ added_text[0].key = &text_keyword[ntext * 80]; -+#ifdef PNG_iTXt_SUPPORTED -+ added_text[0].lang = &text_lang[ntext * 80]; -+ added_text[0].lang_key = -+ &text_lang_key[ntext * 80]; -+#endif -+ added_text[0].text = &text_text[ntext * 2048]; -+ added_text[0].compression = -+ text_compression[ntext]; -+ png_set_text(write_ptr, write_info_ptr, -+ added_text, 1); -+ if (added_text[0].compression < 0) -+ printf(" Added a tEXt chunk.\n"); -+ else if (added_text[0].compression == 0) -+ printf(" Added a zTXt chunk.\n"); -+#ifdef PNG_iTXt_SUPPORTED -+ else -+ printf(" Added a%scompressed iTXt chunk" -+ ".\n", (added_text[0].compression == 1)? -+ "n un" : " "); -+#endif -+#if 0 -+ printf(" key=%s.\n",(added_text[0].key)); -+#endif -+ png_free(write_ptr, added_text); -+ added_text = (png_textp) NULL; -+ } -+ } -+ } -+ } -+#endif /* defined(PNG_TEXT_SUPPORTED) */ -+ -+#if defined(PNG_READ_tIME_SUPPORTED) && defined(PNG_WRITE_tIME_SUPPORTED) -+ { -+ png_timep mod_time; -+ -+ if (png_get_tIME(read_ptr, read_info_ptr, &mod_time)) { -+ if (keep_chunk("tIME", argv)) -+ png_set_tIME(write_ptr, write_info_ptr, mod_time); -+ } -+ } -+#endif -+ -+#ifdef PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED -+ /* This section handles pCAL and tIME (at least, in default -+ * build), gIFx/gIFg/gIFt, private Fireworks chunks, etc. */ -+ { -+ png_unknown_chunkp unknowns; /* allocated by libpng */ -+ int num_unknowns; -+ -+ num_unknowns = (int)png_get_unknown_chunks(read_ptr, -+ read_info_ptr, &unknowns); -+ P1("Found %d unknown chunks\n", num_unknowns); -+ -+ if (nosave == 0 && num_unknowns) { -+ png_unknown_chunkp unknowns_keep; /* allocated by us */ -+ int num_unknowns_keep; -+ int i; -+ -+ unknowns_keep = png_malloc(write_ptr, -+ (png_uint_32) num_unknowns*sizeof(png_unknown_chunk)); -+ P1("malloc for %d unknown chunks\n", num_unknowns); -+ num_unknowns_keep = 0; -+ -+ /* make an array of only those chunks we want to keep */ -+ for (i = 0; i < num_unknowns; i++) { -+ P1("Handling unknown chunk %d %s\n", i, -+ (char *)unknowns[i].name); -+ /* not EBCDIC-safe, but neither is keep_chunks(): */ -+ P2(" unknown[%d] = %s (%lu bytes, location %d)\n", -+ i, unknowns[i].name, -+ (unsigned long)unknowns[i].size, -+ unknowns[i].location); -+ if (keep_chunk((char *)unknowns[i].name, argv)) { -+ memcpy(&unknowns_keep[num_unknowns_keep], -+ &unknowns[i], sizeof(png_unknown_chunk)); -+ ++num_unknowns_keep; -+ } -+ } -+ -+ P1("Keeping %d unknown chunks\n", num_unknowns_keep); -+ png_set_unknown_chunks(write_ptr, write_info_ptr, -+ unknowns_keep, num_unknowns_keep); -+ -+ /* relevant location bits: -+ * (1) !PNG_HAVE_PLTE && !PNG_HAVE_IDAT (before PLTE) -+ * (2) PNG_HAVE_PLTE && !PNG_HAVE_IDAT (between) -+ * (3) PNG_AFTER_IDAT (after IDAT) -+ * PNG_HAVE_PLTE = 0x02 -+ * PNG_HAVE_IDAT = 0x04 -+ * PNG_AFTER_IDAT = 0x08 -+ */ -+ for (i = 0; i < num_unknowns_keep; i++) { -+ png_set_unknown_chunk_location(write_ptr, -+ write_info_ptr, i, -+ (int)unknowns_keep[i].location); -+ } -+ -+ /* png_set_unknown_chunks() makes own copy, so nuke -+ * ours */ -+ png_free(write_ptr, unknowns_keep); -+ } -+ } -+ P0("unknown chunk handling done.\n"); -+#endif /* PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED */ -+ -+ /* } GRR added for quick %-navigation (1) */ -+ -+ png_read_transform_info(read_ptr, read_info_ptr); -+ -+ -+ /* this is the default case (nosave == 1 -> perf-testing -+ only) */ -+ if (nosave == 0) { -+ -+ if (filter_type == 0) -+ png_set_filter(write_ptr, 0, PNG_FILTER_NONE); -+ else if (filter_type == 1) -+ png_set_filter(write_ptr, 0, PNG_FILTER_SUB); -+ else if (filter_type == 2) -+ png_set_filter(write_ptr, 0, PNG_FILTER_UP); -+ else if (filter_type == 3) -+ png_set_filter(write_ptr, 0, PNG_FILTER_AVG); -+ else if (filter_type == 4) -+ png_set_filter(write_ptr, 0, PNG_FILTER_PAETH); -+ else if (filter_type == 5) -+ png_set_filter(write_ptr, 0, PNG_ALL_FILTERS); -+ else -+ png_set_filter(write_ptr, 0, PNG_FILTER_NONE); -+ -+ -+/* GRR 20050220: not clear why unknowns treated differently from other chunks */ -+/* (i.e., inside nosave==0 block)... Moved up 50 lines now. */ -+#if 0 /* #ifdef PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED */ -+ { -+ png_unknown_chunkp unknowns; -+ int num_unknowns = (int) png_get_unknown_chunks( -+ read_ptr, read_info_ptr, &unknowns); -+ -+ P1("Keeping %d unknown chunks\n", num_unknowns); -+ if (num_unknowns) { -+ int i; -+ -+ png_set_unknown_chunks(write_ptr, write_info_ptr, -+ unknowns, num_unknowns); -+ for (i = 0; i < num_unknowns; i++) { -+ P2(" unknown[%d] = %s\n", i, unknowns[i].name); -+ png_set_unknown_chunk_location(write_ptr, -+ write_info_ptr, i, (int)unknowns[i].location); -+ } -+ } -+ } -+#endif /* 0, was PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED */ -+ -+#ifdef PNGCRUSH_LOCO -+ if (do_loco) { -+ png_byte buffer[30]; -+ const png_byte png_MHDR[5] = { 77, 72, 68, 82, '\0' }; -+ png_byte mng_signature[8] = -+ { 138, 77, 78, 71, 13, 10, 26, 10 }; -+ /* write the MNG 8-byte signature */ -+ if (outname[strlen(outname) - 3] == 'p') -+ png_warning(read_ptr, -+ " Writing a MNG file with a .png extension"); -+ png_default_write_data(write_ptr, &mng_signature[0], -+ (png_size_t) 8); -+ png_set_sig_bytes(write_ptr, 8); -+ -+ /* Write a MHDR chunk */ -+ -+ buffer[0] = (png_byte) ((width >> 24) & 0xff); -+ buffer[1] = (png_byte) ((width >> 16) & 0xff); -+ buffer[2] = (png_byte) ((width >> 8) & 0xff); -+ buffer[3] = (png_byte) ((width) & 0xff); -+ buffer[4] = (png_byte) ((height >> 24) & 0xff); -+ buffer[5] = (png_byte) ((height >> 16) & 0xff); -+ buffer[6] = (png_byte) ((height >> 8) & 0xff); -+ buffer[7] = (png_byte) ((height) & 0xff); -+ for (i = 8; i < 27; i++) -+ buffer[i] = 0x00; -+ buffer[15] = 2; /* layer count */ -+ buffer[19] = 1; /* frame count */ -+ if (output_color_type == 6) -+ buffer[27] = 0x09; /* profile: MNG-VLC with trans. */ -+ else -+ buffer[27] = 0x01; /* profile: MNG-VLC */ -+ png_write_chunk(write_ptr, (png_bytep) png_MHDR, -+ buffer, (png_size_t) 28); -+ } -+#endif /* PNGCRUSH_LOCO */ -+ -+ png_crush_pause(); -+ P1( "\nWriting info struct\n"); -+ -+#if 0 /* doesn't work; compression level has to be the same as in IDAT */ -+ /* if zTXt other compressed chunk */ -+ png_set_compression_level(write_ptr, 9); -+ png_set_compression_window_bits(write_ptr, 15); -+#endif -+ -+ png_crush_pause(); -+ { -+ int compression_window; -+ png_uint_32 zbuf_size; -+ png_uint_32 required_window; -+ int channels = 0; -+ png_set_compression_strategy(write_ptr, -+ z_strategy); -+ png_set_compression_mem_level(write_ptr, -+ compression_mem_level); -+ -+ if (output_color_type == 0) -+ channels = 1; -+ if (output_color_type == 2) -+ channels = 3; -+ if (output_color_type == 3) -+ channels = 1; -+ if (output_color_type == 4) -+ channels = 2; -+ if (output_color_type == 6) -+ channels = 4; -+ -+ required_window = -+ (png_uint_32) (height * -+ ((width * channels * bit_depth + -+ 15) >> 3) + 262); -+ -+ zbuf_size = -+ png_get_compression_buffer_size(write_ptr); -+ -+ /* reinitialize zbuf - compression buffer */ -+ if (zbuf_size != max_idat_size) { -+ png_uint_32 max_possible_size = -+ required_window; -+ if (max_possible_size > max_idat_size) -+ max_possible_size = max_idat_size; -+ P2("reinitializing write zbuf to %lu.\n", -+ (unsigned long)max_possible_size); -+ png_set_compression_buffer_size(write_ptr, -+ max_possible_size); -+ } -+ -+#ifdef WBITS_8_OK -+ if (required_window <= 256) -+ compression_window = 8; -+ else if (required_window <= 512) -+ compression_window = 9; -+#else -+ if (required_window <= 512) -+ compression_window = 9; -+#endif -+ else if (required_window <= 1024) -+ compression_window = 10; -+ else if (required_window <= 2048) -+ compression_window = 11; -+ else if (required_window <= 4096) -+ compression_window = 12; -+ else if (required_window <= 8192) -+ compression_window = 13; -+ else if (required_window <= 16384) -+ compression_window = 14; -+ else -+ compression_window = 15; -+ if (compression_window > default_compression_window -+ || force_compression_window) -+ compression_window = -+ default_compression_window; -+ -+ if (verbose > 1 && first_trial -+ && (compression_window != 15 -+ || force_compression_window)) -+ fprintf(STDERR, -+ " Compression window for output= %d\n", -+ 1 << compression_window); -+ -+ png_set_compression_window_bits(write_ptr, -+ compression_window); -+ } -+ -+ png_set_compression_level(write_ptr, zlib_level); -+ png_write_info(write_ptr, write_info_ptr); -+ P1( "\nWrote info struct\n"); -+#ifdef PNG_WRITE_PACK_SUPPORTED -+ if (output_bit_depth < 8) { -+ if (output_color_type == 0) { -+ png_color_8 true_bits; -+ true_bits.gray = (png_byte) (output_bit_depth); -+ png_set_shift(write_ptr, &true_bits); -+ } -+ png_set_packing(write_ptr); -+ } -+#endif -+ -+ } -+ /* no save */ -+#define LARGE_PNGCRUSH -+ -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+ rows_at_a_time = max_rows_at_a_time; -+ if (rows_at_a_time == 0 || rows_at_a_time < height) -+ rows_at_a_time = height; -+#endif -+ -+#ifndef LARGE_PNGCRUSH -+ { -+ png_uint_32 rowbytes_s; -+ png_uint_32 rowbytes; -+ -+ rowbytes = png_get_rowbytes(read_ptr, read_info_ptr); -+ -+ rowbytes_s = (png_size_t) rowbytes; -+ if (rowbytes == (png_uint_32) rowbytes_s) -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+ row_buf = -+ png_malloc(read_ptr, -+ rows_at_a_time * rowbytes + 16); -+#else -+ row_buf = png_malloc(read_ptr, rowbytes + 16); -+#endif -+ else -+ row_buf = NULL; -+ } -+#else -+ { -+ png_uint_32 read_row_length, write_row_length; -+ read_row_length = -+ (png_uint_32) (png_get_rowbytes -+ (read_ptr, read_info_ptr)); -+ write_row_length = -+ (png_uint_32) (png_get_rowbytes -+ (write_ptr, write_info_ptr)); -+ row_length = -+ read_row_length > -+ write_row_length ? read_row_length : -+ write_row_length; -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+ row_buf = -+ (png_bytep) png_malloc(read_ptr, -+ rows_at_a_time * -+ row_length + 16); -+#else -+ row_buf = -+ (png_bytep) png_malloc(read_ptr, row_length + 16); -+#endif -+ } -+#endif -+ -+ if (row_buf == NULL) -+ png_error(read_ptr, -+ "Insufficient memory to allocate row buffer"); -+ -+ { -+ /* check for sufficient memory: we need 2*zlib_window and, -+ if filter_type == 5, 4*rowbytes in separate allocations. -+ If it's not enough we can drop the "average" filter and -+ we can reduce the zlib_window for writing. We can't -+ change the input zlib_window because the input file -+ might have used the full 32K sliding window. -+ */ -+ } -+ -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+ row_pointers = (png_bytepp) png_malloc(read_ptr, -+ rows_at_a_time * -+ sizeof(png_bytepp)); -+ for (i = 0; i < rows_at_a_time; i++) -+ row_pointers[i] = row_buf + i * row_length; -+#endif -+ -+ P2("allocated rowbuf.\n"); -+ png_crush_pause(); -+ -+ num_pass = png_set_interlace_handling(read_ptr); -+ if (nosave == 0) -+ png_set_interlace_handling(write_ptr); -+ -+ t_stop = (TIME_T) clock(); -+ t_misc += (t_stop - t_start); -+ if (t_stop < t_start) { -+ t_misc += PNG_UINT_31_MAX; -+ if (t_stop < 0) -+ t_misc += PNG_UINT_31_MAX; -+ } -+ t_start = t_stop; -+ for (pass = 0; pass < num_pass; pass++) { -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+ png_uint_32 num_rows; -+#endif -+ P1( "\nBegin interlace pass %d\n", pass); -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+ num_rows = rows_at_a_time; -+ for (y = 0; y < height; y += rows_at_a_time) -+#else -+ for (y = 0; y < height; y++) -+#endif -+ { -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+ if (y + num_rows > height) -+ num_rows = height - y; -+ png_read_rows(read_ptr, row_pointers, -+ (png_bytepp) NULL, num_rows); -+#else -+ png_read_row(read_ptr, row_buf, (png_bytep) NULL); -+#endif -+ if (nosave == 0) { -+ t_stop = (TIME_T) clock(); -+ t_decode += (t_stop - t_start); -+ if (t_stop < t_start) { -+ t_decode += PNG_UINT_31_MAX; -+ if (t_stop < 0) -+ t_decode += PNG_UINT_31_MAX; -+ } -+ t_start = t_stop; -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+ png_write_rows(write_ptr, row_pointers, -+ num_rows); -+#else -+ png_write_row(write_ptr, row_buf); -+#endif -+ t_stop = (TIME_T) clock(); -+ t_encode += (t_stop - t_start); -+ if (t_stop < t_start) { -+ t_encode += PNG_UINT_31_MAX; -+ if (t_stop < 0) -+ t_encode += PNG_UINT_31_MAX; -+ } -+ t_start = t_stop; -+ } -+ } -+ P2( "End interlace pass %d\n\n", pass); -+ } -+ if (nosave) { -+ t_stop = (TIME_T) clock(); -+ t_decode += (t_stop - t_start); -+ if (t_stop < t_start) { -+ t_decode += PNG_UINT_31_MAX; -+ if (t_stop < 0) -+ t_decode += PNG_UINT_31_MAX; -+ } -+ t_start = t_stop; -+ } -+ -+#if defined(PNG_READ_RGB_TO_GRAY_SUPPORTED) && \ -+ defined(PNG_FLOATING_POINT_SUPPORTED) -+ if ((color_type == 2 || color_type == 6 || color_type == 3) -+ && (output_color_type == 0 || output_color_type == 4)) -+ { -+ png_byte rgb_error = -+ png_get_rgb_to_gray_status(read_ptr); -+ if ((first_trial) && rgb_error) -+ printf( -+ " **** Converted non-gray image to gray. **** \n"); -+ } -+#endif -+ -+#ifdef PNG_FREE_UNKN -+# if defined(PNG_READ_UNKNOWN_CHUNKS_SUPPORTED) -+ png_free_data(read_ptr, read_info_ptr, PNG_FREE_UNKN, -1); -+# endif -+# if defined(PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED) -+ png_free_data(write_ptr, write_info_ptr, PNG_FREE_UNKN, -1); -+# endif -+#else -+# if defined(PNG_READ_UNKNOWN_CHUNKS_SUPPORTED) -+ png_free_unknown_chunks(read_ptr, read_info_ptr, -1); -+# endif -+# if defined(PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED) -+ png_free_unknown_chunks(write_ptr, write_info_ptr, -1); -+# endif -+#endif -+ -+ P1( "Reading and writing end_info data\n"); -+ png_read_end(read_ptr, end_info_ptr); -+ -+ /* { GRR: added for %-navigation (2) */ -+ -+#if (defined(PNG_READ_tEXt_SUPPORTED) && defined(PNG_WRITE_tEXt_SUPPORTED)) \ -+ || (defined(PNG_READ_zTXt_SUPPORTED) && defined(PNG_WRITE_zTXt_SUPPORTED)) -+ { -+ png_textp text_ptr; -+ int num_text = 0; -+ -+ if (png_get_text -+ (read_ptr, end_info_ptr, &text_ptr, &num_text) > 0 -+ || text_inputs) { -+ int ntext; -+ P1( "Handling %d tEXt/zTXt chunks\n", -+ num_text); -+ -+ if (verbose > 1 && first_trial && num_text > 0) { -+ for (ntext = 0; ntext < num_text; ntext++) { -+ fprintf(STDERR, "%d %s", ntext, -+ text_ptr[ntext].key); -+ if (text_ptr[ntext].text_length) -+ fprintf(STDERR, ": %s\n", -+ text_ptr[ntext].text); -+#ifdef PNG_iTXt_SUPPORTED -+ else if (text_ptr[ntext].itxt_length) { -+ fprintf(STDERR, " (%s: %s): \n", -+ text_ptr[ntext].lang, -+ text_ptr[ntext].lang_key); -+ fprintf(STDERR, "%s\n", -+ text_ptr[ntext].text); -+ } -+#endif -+ else -+ fprintf(STDERR, "\n"); -+ } -+ } -+ -+ if (num_text > 0) { -+ if (keep_chunk("text", argv)) { -+ int num_to_write = num_text; -+ for (ntext = 0; ntext < num_text; ntext++) { -+ if (first_trial) -+ P2("Text chunk after IDAT, " -+ "compression=%d\n", -+ text_ptr[ntext].compression); -+ if (text_ptr[ntext].compression == -+ PNG_TEXT_COMPRESSION_NONE) { -+ if (!keep_chunk("tEXt", argv)) { -+ text_ptr[ntext].key[0] = '\0'; -+ num_to_write--; -+ } -+ } -+ if (text_ptr[ntext].compression == -+ PNG_TEXT_COMPRESSION_zTXt) { -+ if (!keep_chunk("zTXt", argv)) { -+ text_ptr[ntext].key[0] = '\0'; -+ num_to_write--; -+ } -+ } -+#ifdef PNG_iTXt_SUPPORTED -+ if (text_ptr[ntext].compression == -+ PNG_ITXT_COMPRESSION_NONE -+ || text_ptr[ntext].compression == -+ PNG_ITXT_COMPRESSION_zTXt) { -+ if (!keep_chunk("iTXt", argv)) { -+ text_ptr[ntext].key[0] = '\0'; -+ num_to_write--; -+ } -+ } -+#endif -+ } -+ if (num_to_write > 0) -+ png_set_text(write_ptr, -+ write_end_info_ptr, -+ text_ptr, num_text); -+ } -+ } -+ for (ntext = 0; ntext < text_inputs; ntext++) { -+ if (text_where[ntext] == 2) { -+ png_textp added_text; -+ added_text = (png_textp) -+ png_malloc(write_ptr, -+ (png_uint_32) -+ sizeof(png_text)); -+ added_text[0].key = -+ &text_keyword[ntext * 80]; -+#ifdef PNG_iTXt_SUPPORTED -+ added_text[0].lang = -+ &text_lang[ntext * 80]; -+ added_text[0].lang_key = -+ &text_lang_key[ntext * 80]; -+#endif -+ added_text[0].text = -+ &text_text[ntext * 2048]; -+ added_text[0].compression = -+ text_compression[ntext]; -+ png_set_text(write_ptr, write_end_info_ptr, -+ added_text, 1); -+ if (added_text[0].compression < 0) -+ printf(" Added a tEXt chunk.\n"); -+ else if (added_text[0].compression == 0) -+ printf(" Added a zTXt chunk.\n"); -+#ifdef PNG_iTXt_SUPPORTED -+ else if (added_text[0].compression == 1) -+ printf(" Added an uncompressed iTXt " -+ "chunk.\n"); -+ else -+ printf(" Added a compressed iTXt " -+ "chunk.\n"); -+#endif -+ png_free(write_ptr, added_text); -+ added_text = (png_textp) NULL; -+ } -+ } -+ } -+ } -+#endif /* (PNG_READ_tEXt_SUPPORTED and PNG_WRITE_tEXt_SUPPORTED) or */ -+ /* (PNG_READ_zTXt_SUPPORTED and PNG_WRITE_zTXt_SUPPORTED) */ -+#if defined(PNG_READ_tIME_SUPPORTED) && defined(PNG_WRITE_tIME_SUPPORTED) -+ { -+ png_timep mod_time; -+ -+ if (png_get_tIME(read_ptr, end_info_ptr, &mod_time)) { -+ if (keep_chunk("tIME", argv)) -+ png_set_tIME(write_ptr, write_end_info_ptr, -+ mod_time); -+ } -+ } -+#endif -+ -+#if defined(PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED) -+ /* GRR FIXME? this block may need same fix as above */ -+ { -+ png_unknown_chunkp unknowns; -+ int num_unknowns = -+ (int) png_get_unknown_chunks(read_ptr, -+ end_info_ptr, -+ &unknowns); -+ if (num_unknowns && nosave == 0) { -+ int i; -+ printf("setting %d unknown chunks after IDAT\n", -+ num_unknowns); -+ png_set_unknown_chunks(write_ptr, -+ write_end_info_ptr, -+ unknowns, num_unknowns); -+ for (i = 0; i < num_unknowns; i++) -+ png_set_unknown_chunk_location(write_ptr, -+ write_end_info_ptr, -+ i, -+ (int) -+ unknowns[i]. -+ location); -+ } -+ } -+#endif -+ /* } GRR: added for %-navigation (2) */ -+ -+ if (nosave == 0) { -+#if 0 /* doesn't work; compression level has to be the same as in IDAT */ -+ /* if zTXt other compressed chunk */ -+ png_set_compression_level(write_ptr, 9); -+ png_set_compression_window_bits(write_ptr, 15); -+ png_set_compression_buffer_size(write_ptr, -+ PNG_ZBUF_SIZE); -+ png_set_compression_strategy(write_ptr, 0); -+#endif -+ png_write_end(write_ptr, write_end_info_ptr); -+ } -+ -+ P1( "Destroying data structs\n"); -+ if (row_buf != (png_bytep) NULL) { -+ png_free(read_ptr, row_buf); -+ row_buf = (png_bytep) NULL; -+ } -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+ if (row_pointers != (png_bytepp) NULL) { -+ png_free(read_ptr, row_pointers); -+ row_pointers = (png_bytepp) NULL; -+ } -+#endif -+ png_destroy_read_struct(&read_ptr, &read_info_ptr, -+ &end_info_ptr); -+ if (nosave == 0) { -+#ifdef PNGCRUSH_LOCO -+ if (do_loco) { -+ const png_byte png_MEND[5] = -+ { 77, 69, 78, 68, '\0' }; -+ /* write the MNG MEND chunk */ -+ png_write_chunk(write_ptr, (png_bytep) png_MEND, -+ NULL, (png_size_t) 0); -+ } -+#endif -+ png_destroy_info_struct(write_ptr, -+ &write_end_info_ptr); -+ png_destroy_write_struct(&write_ptr, &write_info_ptr); -+ } -+ } -+ Catch(msg) { -+ if (nosave == 0) -+ fprintf(stderr, "While converting %s to %s:\n", inname, -+ outname); -+ else -+ fprintf(stderr, "While reading %s:\n", inname); -+ fprintf(stderr, -+ " pngcrush caught libpng error:\n %s\n\n", msg); -+ if (row_buf) { -+ png_free(read_ptr, row_buf); -+ row_buf = (png_bytep) NULL; -+ } -+#ifdef PNGCRUSH_MULTIPLE_ROWS -+ if (row_pointers != (png_bytepp) NULL) { -+ png_free(read_ptr, row_pointers); -+ row_pointers = (png_bytepp) NULL; -+ } -+#endif -+ if (nosave == 0) { -+ png_destroy_info_struct(write_ptr, -+ &write_end_info_ptr); -+ png_destroy_write_struct(&write_ptr, &write_info_ptr); -+ FCLOSE(fpout); -+ setfiletype(outname); -+ } -+ png_destroy_read_struct(&read_ptr, &read_info_ptr, -+ &end_info_ptr); -+ FCLOSE(fpin); -+ if (verbose > 1) -+ fprintf(stderr, "returning after cleanup\n"); -+ trial = MAX_METHODS + 1; -+ } -+ -+ read_ptr = NULL; -+ write_ptr = NULL; -+ FCLOSE(fpin); -+ if (nosave == 0) { -+ FCLOSE(fpout); -+ setfiletype(outname); -+ } -+ -+ if (nosave) -+ break; -+ -+ first_trial = 0; -+ -+ if (nosave == 0) { -+ P1( "Opening file for length measurement\n"); -+ if ((fpin = FOPEN(outname, "rb")) == NULL) { -+ fprintf(STDERR, "Could not find output file %s\n", outname); -+ if (png_row_filters != NULL) { -+ free(png_row_filters); -+ png_row_filters = NULL; -+ } -+ exit(1); -+ } -+ number_of_open_files++; -+ -+ idat_length[trial] = measure_idats(fpin); -+ -+ FCLOSE(fpin); -+ } -+ -+ if (verbose > 0 && trial != MAX_METHODS) { -+ fprintf(STDERR, -+ " IDAT length with method %3d (fm %d zl %d zs %d) = %8lu\n", -+ trial, filter_type, zlib_level, z_strategy, -+ (unsigned long)idat_length[trial]); -+ fflush(STDERR); -+ } -+ -+ } /* end of trial-loop */ -+ -+ P1("\n\nFINISHED MAIN LOOP OVER %d METHODS\n\n\n", MAX_METHODS); -+ -+ /* //////////////////////////////////////////////////////////////////// -+ ////////////////// //////////////////// -+ ////////////////// END OF MAIN LOOP OVER METHODS //////////////////// -+ ////////////////// //////////////////// -+ //////////////////////////////////////////////////////////////////// */ -+ } -+ -+ if (fpin) { -+ FCLOSE(fpin); -+ } -+ if (nosave == 0 && fpout) { -+ FCLOSE(fpout); -+ setfiletype(outname); -+ } -+ -+ if (verbose > 0 && nosave == 0) { -+ png_uint_32 input_length, output_length; -+#ifndef __riscos -+ struct stat stat_buf; -+ struct utimbuf utim; -+ -+ stat(inname, &stat_buf); -+ input_length = (unsigned long) stat_buf.st_size; -+ utim.actime = stat_buf.st_atime; -+ utim.modtime = stat_buf.st_mtime; -+ stat(outname, &stat_buf); -+ output_length = (unsigned long) stat_buf.st_size; -+ utime(outname, &utim); /* set timestamp (no big deal if fails) */ -+#else -+ input_length = (unsigned long) filesize(inname); -+ output_length = (unsigned long) filesize(outname); -+#endif -+ total_input_length += input_length + output_length; -+ -+ if (!already_crushed && !image_is_immutable) { -+ fprintf(STDERR, " Best pngcrush method = %d (fm %d zl %d zs %d) " -+ "for %s\n", best, fm[best], lv[best], zs[best], outname); -+ } -+ if (idat_length[0] == idat_length[best]) -+ fprintf(STDERR, " (no IDAT change)\n"); -+ else if (idat_length[0] > idat_length[best]) -+ fprintf(STDERR, " (%4.2f%% IDAT reduction)\n", -+ (100.0 - (100.0 * idat_length[best]) / idat_length[0])); -+ else -+ fprintf(STDERR, " (%4.2f%% IDAT increase)\n", -+ -(100.0 - (100.0 * idat_length[best]) / idat_length[0])); -+ if (input_length == output_length) -+ fprintf(STDERR, " (no filesize change)\n\n"); -+ else if (input_length > output_length) -+ fprintf(STDERR, " (%4.2f%% filesize reduction)\n\n", -+ (100.0 - (100.0 * output_length) / input_length)); -+ else -+ fprintf(STDERR, " (%4.2f%% filesize increase)\n\n", -+ -(100.0 - (100.0 * output_length) / input_length)); -+ -+ if (verbose > 2) -+ fprintf(STDERR, " Number of open files=%d\n", -+ number_of_open_files); -+ -+ } -+ -+ if (pngcrush_mode == DEFAULT_MODE) { -+ if (png_row_filters != NULL) { -+ free(png_row_filters); -+ png_row_filters = NULL; -+ } -+ if (verbose > 0) -+ show_result(); -+#ifdef PNG_iCCP_SUPPORTED -+ if (iccp_length) -+ free(iccp_text); -+#endif -+ if (pngcrush_must_exit) -+ exit(0); -+ return 0; -+ } -+ } /* end of loop on input files */ -+ -+ return 0; /* just in case */ -+ -+} /* end of main() */ -+ -+ -+ -+ -+png_uint_32 measure_idats(FILE * fpin) -+{ -+ /* Copyright (C) 1999-2002,2006 Glenn Randers-Pehrson (glennrp@users.sf.net) -+ See notice in pngcrush.c for conditions of use and distribution */ -+ P2("\nmeasure_idats:\n"); -+ P1( "Allocating read structure\n"); -+/* OK to ignore any warning about the address of exception__prev in "Try" */ -+ Try { -+ read_ptr = -+ png_create_read_struct(PNG_LIBPNG_VER_STRING, (png_voidp) NULL, -+ (png_error_ptr) png_cexcept_error, -+ (png_error_ptr) NULL); -+ P1( "Allocating read_info, end_info structures\n"); -+ read_info_ptr = png_create_info_struct(read_ptr); -+ end_info_ptr = png_create_info_struct(read_ptr); -+ -+#if !defined(PNG_NO_STDIO) -+ png_init_io(read_ptr, fpin); -+#else -+ png_set_read_fn(read_ptr, (png_voidp) fpin, (png_rw_ptr) NULL); -+#endif -+ -+ png_set_sig_bytes(read_ptr, 0); -+ measured_idat_length = png_measure_idat(read_ptr); -+ P2("measure_idats: IDAT length=%lu\n", -+ (unsigned long)measured_idat_length); -+ P1( "Destroying data structs\n"); -+ png_destroy_read_struct(&read_ptr, &read_info_ptr, &end_info_ptr); -+ } -+ Catch(msg) { -+ fprintf(STDERR, "\nWhile measuring IDATs in %s ", inname); -+ fprintf(STDERR, "pngcrush caught libpng error:\n %s\n\n", msg); -+ png_destroy_read_struct(&read_ptr, &read_info_ptr, &end_info_ptr); -+ P1( "Destroyed data structs\n"); -+ measured_idat_length = 0; -+ } -+ return measured_idat_length; -+} -+ -+ -+ -+ -+ -+png_uint_32 png_measure_idat(png_structp png_ptr) -+{ -+ /* Copyright (C) 1999-2002,2006 Glenn Randers-Pehrson (glennrp@users.sf.net) -+ See notice in pngcrush.c for conditions of use and distribution */ -+ png_uint_32 sum_idat_length = 0; -+ png_byte *bb = NULL; -+ png_uint_32 malloced_length=0; -+ -+ { -+ png_byte png_signature[8] = { 137, 80, 78, 71, 13, 10, 26, 10 }; -+#if defined(PNGCRUSH_LOCO) -+ png_byte mng_signature[8] = { 138, 77, 78, 71, 13, 10, 26, 10 }; -+#endif -+ -+ png_default_read_data(png_ptr, png_signature, 8); -+ png_set_sig_bytes(png_ptr, 8); -+ -+#if defined(PNGCRUSH_LOCO) -+ if (!(int) (png_memcmp(mng_signature, png_signature, 8))) { -+ const png_byte png_MHDR[5] = { 77, 72, 68, 82, '\0' }; -+ -+ int b; -+ png_byte buffer[40]; -+ unsigned long length; -+ /* read the MHDR */ -+ png_default_read_data(read_ptr, buffer, 4); -+ length=buffer[3]+(buffer[2]<<8)+(buffer[1]<<16)+(buffer[0]<<24); -+ png_default_read_data(read_ptr, buffer, 4); -+ printf("Reading %c%c%c%c chunk.\n",buffer[0],buffer[1], -+ buffer[2],buffer[3]); -+ for (b=0; b<40; b++) -+ buffer[b]='\0'; -+ png_default_read_data(read_ptr, buffer, length); -+ if (verbose) { -+ printf(" width=%lu\n",(unsigned long)(buffer[3]+(buffer[2]<<8) -+ +(buffer[1]<<16)+(buffer[0]<<24))); -+ printf(" height=%lu\n",(unsigned long)(buffer[7]+(buffer[6]<<8) -+ +(buffer[5]<<16)+(buffer[4]<<24))); -+ printf(" ticksps=%lu\n",(unsigned long)(buffer[11]+ -+ (buffer[10]<<8)+(buffer[9]<<16)+(buffer[8]<<24))); -+ printf(" nomlayc=%lu\n",(unsigned long)(buffer[15]+ -+ (buffer[14]<<8)+(buffer[13]<<16)+(buffer[12]<<24))); -+ printf(" nomfram=%lu\n",(unsigned long)(buffer[19]+ -+ (buffer[18]<<8)+(buffer[17]<<16)+(buffer[16]<<24))); -+ printf(" nomplay=%lu\n",(unsigned long)(buffer[23]+ -+ (buffer[22]<<8)+(buffer[21]<<16)+(buffer[20]<<24))); -+ printf(" profile=%lu\n",(unsigned long)(buffer[27]+ -+ (buffer[26]<<8)+(buffer[25]<<16)+(buffer[24]<<24))); -+ } -+ -+ if (new_mng) { -+ /* write the MNG 8-byte signature */ -+ png_default_write_data(mng_ptr, &mng_signature[0], -+ (png_size_t) 8); -+ -+ /* Write a MHDR chunk */ -+ png_write_chunk(mng_ptr, (png_bytep) png_MHDR, -+ buffer, (png_size_t) 28); -+ } -+ -+ png_default_read_data(read_ptr, buffer, 4); -+ input_format = 1; -+ -+ } else -+#endif -+ if (png_sig_cmp(png_signature, 0, 8)) { -+ if (png_sig_cmp(png_signature, 0, 4)) -+ png_error(png_ptr, "Not a PNG file.."); -+ else -+ png_error(png_ptr, -+ "PNG file corrupted by ASCII conversion"); -+ } -+ } -+ -+ if (fix) -+ { -+#ifdef PNG_CRC_WARN_USE -+ png_set_crc_action(png_ptr, PNG_CRC_WARN_USE, PNG_CRC_WARN_USE); -+#endif -+#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR -+ inflateUndermine(&png_ptr->zstream, 1); -+#endif -+ } -+ -+ for (;;) { -+#ifndef PNG_UINT_IDAT -+#if defined(PNG_USE_LOCAL_ARRAYS) || defined(PNGCRUSH_USE_LOCAL_ARRAYS) -+ PNG_IDAT; -+ PNG_IEND; -+ PNG_IHDR; -+#ifdef PNG_iCCP_SUPPORTED -+ PNG_iCCP; -+#else -+ const png_byte png_iCCP[5] = { 105, 67, 67, 80, '\0' }; -+#endif -+#endif -+#endif -+ png_byte chunk_name[5]; -+ png_byte chunk_length[4]; -+ png_byte buffer[32]; -+ png_uint_32 length; -+ -+ png_default_read_data(png_ptr, chunk_length, 4); -+ length = png_get_uint_31(png_ptr,chunk_length); -+ -+ png_reset_crc(png_ptr); -+ png_crc_read(png_ptr, chunk_name, 4); -+ -+ if (new_mng) { -+ const png_byte png_DHDR[5] = { 68, 72, 68, 82, '\0' }; -+ const png_byte png_DEFI[5] = { 68, 69, 70, 73, '\0' }; -+ const png_byte png_FRAM[5] = { 70, 82, 65, 77, '\0' }; -+ const png_byte png_nEED[5] = { 110, 69, 69, 68, '\0' }; -+ if (!png_memcmp(chunk_name, png_nEED, 4)) -+ { -+ /* Skip the nEED chunk */ -+ printf (" skipping MNG %c%c%c%c chunk, %lu bytes\n",chunk_name[0], -+ chunk_name[1],chunk_name[2],chunk_name[3],(unsigned long)length); -+ } -+ else { -+ /* copy the chunk. */ -+ printf (" reading MNG %c%c%c%c chunk, %lu bytes\n",chunk_name[0], -+ chunk_name[1],chunk_name[2],chunk_name[3],(unsigned long)length); -+ if (length > malloced_length) { -+ png_free(mng_ptr,bb); -+ printf (" png_malloc %lu bytes.\n",(unsigned long)length); -+ bb=png_malloc(mng_ptr, length); -+ malloced_length=length; -+ } -+ png_crc_read(png_ptr, bb, length); -+ png_write_chunk(mng_ptr, chunk_name, -+ bb, (png_size_t) length); -+ -+ if (!png_memcmp(chunk_name, png_DHDR, 4)) { -+ if (verbose > 1) { -+ printf(" objid=%lu\n",(unsigned long)(bb[1]+(bb[0]<<8))); -+ printf(" itype=%lu\n",(unsigned long)(bb[2])); -+ printf(" dtype=%lu\n",(unsigned long)(bb[3])); -+ printf(" width=%lu\n",(unsigned long)(bb[7]+(bb[6]<<8) -+ +(bb[5]<<16)+(bb[4]<<24))); -+ printf(" height=%lu\n",(unsigned long)(bb[11]+(bb[10]<<8) -+ +(bb[9]<<16)+(bb[8]<<24))); -+ printf(" xloc=%lu\n",(unsigned long)(bb[15]+(bb[14]<<8) -+ +(bb[13]<<16)+(bb[12]<<24))); -+ printf(" yloc=%lu\n",(unsigned long)(bb[19]+(bb[18]<<8) -+ +(bb[17]<<16)+(bb[16]<<24))); -+ } -+ } -+ -+ if (!png_memcmp(chunk_name, png_DEFI, 4)) { -+ if (verbose > 1) { -+ printf(" objid=%lu\n",(unsigned long)(bb[1]+(bb[0]<<8))); -+ printf(" do_not_show=%lu\n",(unsigned long)(bb[2])); -+ printf(" concrete=%lu\n",(unsigned long)(bb[3])); -+ if (length > 4) { -+ printf(" xloc=%lu\n",(unsigned long)(bb[15]+(bb[14]<<8) -+ +(bb[13]<<16)+(bb[12]<<24))); -+ printf(" yloc=%lu\n",(unsigned long)(bb[19]+(bb[18]<<8) -+ +(bb[17]<<16)+(bb[16]<<24))); -+ if (length > 12) { -+ printf(" l_cb=%lu\n",(unsigned long)(bb[20]+(bb[19]<<8) -+ +(bb[18]<<16)+(bb[17]<<24))); -+ printf(" r_cb=%lu\n",(unsigned long)(bb[24]+(bb[23]<<8) -+ +(bb[22]<<16)+(bb[21]<<24))); -+ } -+ } -+ } -+ } -+ if (!png_memcmp(chunk_name, png_FRAM, 4)) { -+ if (verbose > 1) { -+ printf(" mode=%lu\n",(unsigned long)bb[0]); -+ if (length > 1) { -+ int ib; -+ printf(" name = "); -+ for (ib=0; bb[ib]; ib++) -+ { -+ printf ("%c", bb[ib]); -+ } -+ printf ("\n"); -+ } -+ } -+ } -+ length=0; -+ } -+ } -+ -+ else { -+ -+#ifdef PNG_UINT_IDAT -+ if (png_get_uint_32(chunk_name) == PNG_UINT_IDAT) -+#else -+ if (!png_memcmp(chunk_name, png_IDAT, 4)) -+#endif -+ { -+ sum_idat_length += length; -+ if (length > crushed_idat_size) -+ already_crushed++; -+ } -+ -+ if (verbose > 1) { -+ chunk_name[4] = '\0'; -+ printf("Reading %s chunk, length = %lu.\n", chunk_name, -+ (unsigned long)length); -+ } -+#ifdef PNG_UINT_IHDR -+ if (png_get_uint_32(chunk_name) == PNG_UINT_IHDR) -+#else -+ if (!png_memcmp(chunk_name, png_IHDR, 4)) -+#endif -+ { -+ /* get the color type */ -+ png_crc_read(png_ptr, buffer, 13); -+ length -= 13; -+ input_color_type = buffer[9]; -+ } -+ else -+ { -+ if (png_get_uint_32(chunk_name) == PNG_UINT_dSIG) -+ { -+ if (found_any_chunk == 0 && !all_chunks_are_safe) -+ { -+ image_is_immutable=1; -+ } -+ } -+ else -+ found_any_chunk=1; -+ } -+ -+#ifdef PNG_gAMA_SUPPORTED -+ if (png_get_uint_32(chunk_name) == PNG_UINT_gAMA) -+ found_gAMA=1; -+#endif -+ -+#ifdef PNG_cHRM_SUPPORTED -+ if (png_get_uint_32(chunk_name) == PNG_UINT_cHRM) -+ found_cHRM=1; -+#endif -+ -+#ifdef PNG_iCCP_SUPPORTED -+ /* check for bad Photoshop iCCP chunk */ -+#ifdef PNG_UINT_iCCP -+ if (png_get_uint_32(chunk_name) == PNG_UINT_iCCP) -+#else -+ if (!png_memcmp(chunk_name, png_iCCP, 4)) -+#endif -+ { -+ /* Check for bad Photoshop iCCP chunk. Libpng will reject the -+ * bad chunk because the Adler-32 bytes are missing, but we check -+ * here to see if it's really the sRGB profile, and if so, set the -+ * "intent" flag and gamma so pngcrush will write an sRGB chunk -+ * and a gamma chunk. -+ */ -+ if (length == 2615) { -+ png_crc_read(png_ptr, buffer, 22); -+ length -= 22; -+ buffer[23] = 0; -+ if (!strncmp((png_const_charp) buffer, "Photoshop ICC profile", -+ 21)) -+ { -+ printf(" Replacing bad Photoshop ICCP chunk with an " -+ "sRGB chunk\n"); -+#ifdef PNG_gAMA_SUPPORTED -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ image_specified_gamma = 45455L; -+#else -+ image_specified_gamma = 0.45455; -+#endif -+#endif -+ intent = 0; -+ } -+ } -+ } -+#endif -+ -+ -+ } -+ png_crc_finish(png_ptr, length); -+ -+#ifdef PNGCRUSH_LOCO -+#ifdef PNG_UINT_MEND -+ if (png_get_uint_32(chunk_name) == PNG_UINT_MEND) -+ return sum_idat_length; -+#else -+ { -+ const png_byte png_MEND[5] = -+ { 77, 69, 78, 68, '\0' }; -+ if (!png_memcmp(chunk_name, png_MEND, 4)) -+ { -+ if (new_mng) -+ png_free(mng_ptr,bb); -+ return (0); -+ return sum_idat_length; -+ } -+ } -+#endif -+#endif -+ -+ -+if (input_format == 0) -+ { -+#ifdef PNG_UINT_IEND -+ if (png_get_uint_32(chunk_name) == PNG_UINT_IEND) -+#else -+ if (!png_memcmp(chunk_name, png_IEND, 4)) -+#endif -+ return sum_idat_length; -+ } -+ } -+} -+ -+ -+ -+ -+ -+#ifdef PNGCRUSH_COUNT_COLORS -+#define USE_HASHCODE -+int count_colors(FILE * fpin) -+{ -+ /* Copyright (C) 2000-2002,2006 Glenn Randers-Pehrson (glennrp@users.sf.net) -+ See notice in pngcrush.c for conditions of use and distribution */ -+ int bit_depth, color_type, interlace_method, filter_method, -+ compression_method; -+ png_uint_32 rowbytes; -+ volatile png_uint_32 channels; -+ -+ int i; -+ int pass, num_pass; -+ int ret; -+ volatile int result, hashmiss, hashinserts; -+ -+ png_uint_32 rgba_frequency[257]; -+ -+ png_uint_32 rgba_hi[257]; /* Actually contains ARGB not RGBA */ -+#if 0 -+ png_uint_32 rgba_lo[257]; /* Low bytes of ARGB in 16-bit PNGs */ -+#endif -+ -+ /* arrays to facilitate easy interlacing - use pass (0 - 6) as index */ -+ -+ /* start of interlace block */ -+ int png_pass_start[] = { 0, 4, 0, 2, 0, 1, 0 }; -+ -+ /* offset to next interlace block */ -+ int png_pass_inc[] = { 8, 8, 4, 4, 2, 2, 1 }; -+ -+ /* start of interlace block in the y direction */ -+ int png_pass_ystart[] = { 0, 0, 4, 0, 2, 0, 1 }; -+ -+ /* offset to next interlace block in the y direction */ -+ int png_pass_yinc[] = { 8, 8, 8, 4, 4, 2, 2 }; -+ -+ result = 0; -+ reduce_to_gray = 1; -+ it_is_opaque = 1; -+ hashmiss = 0; -+ hashinserts = 0; -+ row_buf = (png_bytep) NULL; -+ -+ num_rgba = 0; -+ for (i = 0; i < 257; i++) { -+ rgba_frequency[i] = 0; -+ } -+ -+ P2("Checking alphas:\n"); -+ P1( "Allocating read structure\n"); -+ Try { -+ read_ptr = -+ png_create_read_struct(PNG_LIBPNG_VER_STRING, (png_voidp) NULL, -+ (png_error_ptr) png_cexcept_error, -+ (png_error_ptr) NULL); -+ if (read_ptr) { -+ P1( "Allocating read_info structure\n"); -+ read_info_ptr = png_create_info_struct(read_ptr); -+ if (read_info_ptr == NULL) -+ png_destroy_read_struct(&read_ptr, (png_infopp) NULL, -+ (png_infopp) NULL); -+ } else -+ read_info_ptr = NULL; -+ if (read_info_ptr) { -+ -+#ifdef USE_HASHCODE -+ int hash[16385]; -+#endif -+ -+#ifdef USE_HASHCODE -+ for (i = 0; i < 16385; i++) -+ hash[i] = -1; -+#endif -+ end_info_ptr = NULL; -+ -+#if !defined(PNG_NO_STDIO) -+ png_init_io(read_ptr, fpin); -+#else -+ png_set_read_fn(read_ptr, (png_voidp) fpin, (png_rw_ptr) NULL); -+#endif -+ -+ { -+#if defined(PNGCRUSH_LOCO) -+ png_byte mng_signature[8] = -+ { 138, 77, 78, 71, 13, 10, 26, 10 }; -+#endif -+ png_byte png_signature[8] = -+ { 137, 80, 78, 71, 13, 10, 26, 10 }; -+ -+ png_default_read_data(read_ptr, png_signature, 8); -+ png_set_sig_bytes(read_ptr, 8); -+ -+#if defined(PNGCRUSH_LOCO) -+ if (!(int) (png_memcmp(mng_signature, png_signature, 8))) { -+ png_byte buffer[40]; -+ unsigned long length; -+ /* skip the MHDR */ -+ png_default_read_data(read_ptr, buffer, 4); -+ length=buffer[3]+(buffer[2]<<8)+(buffer[1]<<16)+(buffer[0]<<24); -+ png_default_read_data(read_ptr, buffer, 4); -+ printf("Skipping %c%c%c%c chunk.\n",buffer[0],buffer[1], -+ buffer[2],buffer[3]); -+ png_default_read_data(read_ptr, buffer, length); -+ png_default_read_data(read_ptr, buffer, 4); -+ png_permit_mng_features(read_ptr, -+ PNG_FLAG_MNG_FILTER_64); -+ input_format = 1; -+ } else -+#endif -+ if (png_sig_cmp(png_signature, 0, 8)) { -+ if (png_sig_cmp(png_signature, 0, 4)) -+ png_error(read_ptr, "Not a PNG file."); -+ else -+ png_error(read_ptr, -+ "PNG file corrupted by ASCII conversion"); -+ } -+ } -+ png_read_info(read_ptr, read_info_ptr); -+ -+#ifdef PNG_CRC_QUIET_USE -+ png_set_crc_action(read_ptr, PNG_CRC_QUIET_USE, -+ PNG_CRC_QUIET_USE); -+#endif -+ -+ png_get_IHDR(read_ptr, read_info_ptr, &width, &height, -+ &bit_depth, &color_type, &interlace_method, -+ &compression_method, &filter_method); -+ -+ if (color_type == 2) -+ channels = 3; -+ else if (color_type == 4) -+ channels = 2; -+ else if (color_type == 6) -+ channels = 4; -+ else -+ channels = 1; -+ -+ if (color_type == 0 || color_type == 3 || color_type == 4) -+ reduce_to_gray = 1; -+ -+ if (bit_depth == 8) { -+ if (interlace_method) -+ num_pass = 7; -+ else -+ num_pass = 1; -+ -+ rowbytes = png_get_rowbytes(read_ptr, read_info_ptr); -+ -+ row_buf = png_malloc(read_ptr, rowbytes + 16); -+ -+ for (pass = 0; pass < num_pass; pass++) { -+ png_byte *rp; -+ png_uint_32 pass_height, pass_width, y; -+ P2( "\nBegin count_colors() interlace pass %d\n", pass); -+ -+ if (interlace_method) { -+ pass_height = (height - png_pass_ystart[pass] -+ + png_pass_yinc[pass] - -+ 1) / png_pass_yinc[pass]; -+ pass_width = (width - png_pass_start[pass] -+ + png_pass_inc[pass] - -+ 1) / png_pass_inc[pass]; -+ } else { -+ pass_height = height; -+ pass_width = width; -+ } -+ -+ for (y = 0; y < pass_height; y++) { -+ png_uint_32 x; -+ png_read_row(read_ptr, row_buf, (png_bytep) NULL); -+ if (result < 2 || it_is_opaque || reduce_to_gray) { -+ if (color_type == 2) { -+ for (rp = row_buf, x = 0; x < pass_width; -+ x++, rp += channels) { -+#ifdef USE_HASHCODE -+ int hashcode; -+#endif -+ png_uint_32 rgba_high = -+ (255 << 24) | (*(rp) << 16) | -+ (*(rp + 1) << 8) | *(rp + 2); -+ assert(num_rgba < 258); -+ rgba_hi[num_rgba] = rgba_high; -+ -+ if (reduce_to_gray && -+ ((*(rp)) != (*(rp + 1)) -+ || (*(rp)) != (*(rp + 2)))) -+ reduce_to_gray = 0; -+ -+ if (result > 1 || !it_is_opaque) -+ continue; -+ -+ -+#ifdef USE_HASHCODE -+ /* -+ * R G B mask -+ * 11,111 0,0000, 0000 0x3e00 -+ * 00,000 1,1111, 0000 0x01f0 -+ * 00,000 0,0000, 1111 0x000f -+ * -+ */ -+ -+ hashcode = -+ (int) (((rgba_high >> 10) & 0x3e00) -+ | ((rgba_high >> 7) & -+ 0x01f0) | ((rgba_high >> -+ 4) & -+ 0x000f)); -+ assert(hashcode < 16385); -+ if (hash[hashcode] < 0) { -+ hash[hashcode] = i = num_rgba; -+ if (i > 256) -+ result = 2; -+ else -+ num_rgba++; -+ } else { -+ int start = hash[hashcode]; -+ for (i = start; i <= num_rgba; i++) -+ if (rgba_high == rgba_hi[i]) -+ break; -+ hashmiss += (i - start); -+ if (i == num_rgba) { -+ int j; -+ if (i > 256) -+ result = 2; -+ else { -+ for (j = num_rgba; -+ j > start + 1; j--) { -+ rgba_hi[j] = -+ rgba_hi[j - 1]; -+ rgba_frequency[j] = -+ rgba_frequency[j - -+ 1]; -+ } -+ assert(start + 1 < 258); -+ rgba_hi[start + 1] = -+ rgba_high; -+ rgba_frequency[start + 1] = -+ 0; -+ for (j = 0; j < 16384; j++) -+ if (hash[j] > start) -+ hash[j]++; -+ i = start + 1; -+ hashinserts++; -+ num_rgba++; -+ } -+ } -+ } -+#else -+ for (i = 0; i <= num_rgba; i++) -+ if (rgba_high == rgba_hi[i]) -+ break; -+ hashmiss += i; -+ if (i > 256) -+ result = 2; -+ else if (i == num_rgba) -+ num_rgba++; -+#endif -+ assert(i < 258); -+ ++rgba_frequency[i]; -+ } -+ } else if (color_type == 6) { -+ for (rp = row_buf, x = 0; x < pass_width; -+ x++, rp += channels) { -+#ifdef USE_HASHCODE -+ int hashcode; -+#endif -+ png_uint_32 rgba_high = -+ (*(rp + 3) << 24) | (*(rp) << 16) | -+ (*(rp + 1) << 8) | *(rp + 2); -+ assert(rp - row_buf + 3 < rowbytes); -+ rgba_hi[num_rgba] = rgba_high; -+ if (reduce_to_gray && -+ ((*(rp)) != (*(rp + 1)) -+ || (*(rp)) != (*(rp + 2)))) -+ reduce_to_gray = 0; -+ if (it_is_opaque && (*(rp + 3)) != 255) -+ it_is_opaque = 0; -+ if (result > 1) -+ continue; -+#ifdef USE_HASHCODE -+ /* -+ * A R G B mask -+ * 11,1 000,0 000,0 000 0x3800 -+ * 00,0 111,1 000,0 000 0x0780 -+ * 00,0 000,0 111,1 000 0x0078 -+ * 00,0 000,0 000,0 111 0x0007 -+ * -+ */ -+ -+ hashcode = -+ (int) (((rgba_high >> 18) & 0x3800) -+ | ((rgba_high >> 12) & -+ 0x0780) | ((rgba_high >> -+ 8) & 0x0078) -+ | ((rgba_high >> 4) & -+ 0x0007)); -+ assert(hashcode < 16385); -+ if (hash[hashcode] < 0) { -+ hash[hashcode] = i = num_rgba; -+ if (i > 256) -+ result = 2; -+ else -+ num_rgba++; -+ } else { -+ int start = hash[hashcode]; -+ for (i = start; i <= num_rgba; i++) -+ if (rgba_high == rgba_hi[i]) -+ break; -+ hashmiss += (i - start); -+ if (i == num_rgba) { -+ if (i > 256) -+ result = 2; -+ else { -+ int j; -+ for (j = num_rgba; -+ j > start + 1; j--) { -+ rgba_hi[j] = -+ rgba_hi[j - 1]; -+ rgba_frequency[j] = -+ rgba_frequency[j - -+ 1]; -+ } -+ rgba_hi[start + 1] = -+ rgba_high; -+ rgba_frequency[start + 1] = -+ 0; -+ for (j = 0; j < 16384; j++) -+ if (hash[j] > start) -+ hash[j]++; -+ i = start + 1; -+ hashinserts++; -+ num_rgba++; -+ } -+ } -+ } -+#else -+ for (i = 0; i <= num_rgba; i++) -+ if (rgba_high == rgba_hi[i]) -+ break; -+ hashmiss += i; -+ if (i > 256) -+ result = 2; -+ else if (i == num_rgba) -+ num_rgba++; -+#endif -+ ++rgba_frequency[i]; -+ } -+ } else if (color_type == 4) { -+ for (rp = row_buf, x = 0; x < pass_width; -+ x++, rp += channels) { -+#ifdef USE_HASHCODE -+ int hashcode; -+#endif -+ png_uint_32 rgba_high = -+ (*(rp + 1) << 24) | (*(rp) << 16) | -+ (*(rp) << 8) | (*rp); -+ assert(rp - row_buf + 1 < rowbytes); -+ rgba_hi[num_rgba] = rgba_high; -+ if (it_is_opaque && (*(rp + 1)) != 255) -+ it_is_opaque = 0; -+#ifdef USE_HASHCODE -+ /* -+ * A G mask -+ * 11,1111, 0000,0000 0x3f00 -+ * 00,0000, 1111,1111 0x00ff -+ * -+ */ -+ -+ hashcode = -+ (int) (((rgba_high >> 18) & 0x3f00) -+ | ((rgba_high >> 4) & -+ 0x00ff)); -+ if (hash[hashcode] < 0) { -+ hash[hashcode] = i = num_rgba; -+ if (i > 256) -+ result = 2; -+ else -+ num_rgba++; -+ } else { -+ int start = hash[hashcode]; -+ for (i = start; i <= num_rgba; i++) -+ if (rgba_high == rgba_hi[i]) -+ break; -+ hashmiss += (i - start); -+ if (i == num_rgba) { -+ if (i > 256) -+ result = 2; -+ else { -+ int j; -+ for (j = num_rgba; -+ j > start + 1; j--) { -+ rgba_hi[j] = -+ rgba_hi[j - 1]; -+ rgba_frequency[j] = -+ rgba_frequency[j - -+ 1]; -+ } -+ rgba_hi[start + 1] = -+ rgba_high; -+ rgba_frequency[start + 1] = -+ 0; -+ for (j = 0; j < 16384; j++) -+ if (hash[j] > start) -+ hash[j]++; -+ i = start + 1; -+ hashinserts++; -+ num_rgba++; -+ } -+ } -+ } -+#else -+ for (i = 0; i <= num_rgba; i++) -+ if (rgba_high == rgba_hi[i]) -+ break; -+ hashmiss += i; -+ if (i > 256) -+ result = 2; -+ else if (i == num_rgba) -+ num_rgba++; -+#endif -+ ++rgba_frequency[i]; -+ } -+ } else { /* other color type */ -+ -+ result = 2; -+ } -+ } -+ } -+ P2( "End count_colors() interlace pass %d\n\n", pass); -+ } -+ -+ } else /* (bit_depth != 8) */ { -+ -+ /* TO DO: 16-bit support */ -+ reduce_to_gray = 0; -+ it_is_opaque = 0; -+ result = 0; -+ } -+ -+ png_free(read_ptr, row_buf); -+ row_buf = (png_bytep) NULL; -+ P1( "Destroying data structs\n"); -+ png_destroy_read_struct(&read_ptr, &read_info_ptr, -+ (png_infopp) NULL); -+ } else -+ result = 2; -+ } -+ Catch(msg) { -+ fprintf(STDERR, "\nWhile checking alphas in %s ", inname); -+ fprintf(STDERR, "pngcrush caught libpng error:\n %s\n\n", msg); -+ png_free(read_ptr, row_buf); -+ row_buf = (png_bytep) NULL; -+ png_destroy_read_struct(&read_ptr, &read_info_ptr, -+ (png_infopp) NULL); -+ P1( "Destroyed data structs\n"); -+ result = 2; -+ } -+ if (verbose > 1) { -+ int total = 0; -+ if (num_rgba && num_rgba < 257) { -+ for (i = 0; i < num_rgba; i++) { -+ printf("RGBA=(%3.3d,%3.3d,%3.3d,%3.3d), frequency=%d\n", -+ (int) (rgba_hi[i] >> 16) & 0xff, -+ (int) (rgba_hi[i] >> 8) & 0xff, -+ (int) (rgba_hi[i]) & 0xff, -+ (int) (rgba_hi[i] >> 24) & 0xff, -+ (int) rgba_frequency[i]); -+ total += rgba_frequency[i]; -+ } -+ P2("num_rgba=%d, total pixels=%d\n", num_rgba, total); -+ P2("hashcode misses=%d, inserts=%d\n", hashmiss, hashinserts); -+ } -+ if (color_type == 0 || color_type == 2) -+ it_is_opaque = 0; -+ if (reduction_ok) { -+ if (reduce_to_gray) -+ P1("The truecolor image is all gray and will be reduced.\n"); -+ if (it_is_opaque) -+ P1("The image is opaque and the alpha channel will be " -+ "removed.\n"); -+ } else { -+ if (reduce_to_gray) -+ P1("The truecolor image is all gray and could be reduced.\n"); -+ if (it_is_opaque) -+ P1("The image is opaque and the alpha channel could be " -+ "removed.\n"); -+ if (reduce_to_gray || it_is_opaque) -+ P1("Rerun pngcrush with the \"-reduce\" option to do so.\n"); -+ reduce_to_gray = 0; -+ it_is_opaque = 0; -+ } -+ P2("Finished checking alphas, result=%d\n", result); -+ } -+ ret = result; -+ return (ret); -+} -+#endif /* PNGCRUSH_COUNT_COLORS */ -+ -+ -+ -+ -+ -+void print_version_info(void) -+{ -+ fprintf(STDERR, -+ "\n" -+ " | pngcrush %s\n" -+ /* If you have modified this source, you may insert additional notices -+ * immediately after this sentence: */ -+ " | Copyright (C) 1998-2002,2006-2008 Glenn Randers-Pehrson\n" -+ " | Copyright (C) 2005 Greg Roelofs\n" -+ " | This is a free, open-source program. Permission is irrevocably\n" -+ " | granted to everyone to use this version of pngcrush without\n" -+ " | payment of any fee.\n" -+ " | Executable name is %s\n" -+ " | It was built with libpng version %s, and is\n" -+ " | running with %s" -+ " | Copyright (C) 1998-2004,2006-2008 Glenn Randers-Pehrson,\n" -+ " | Copyright (C) 1996, 1997 Andreas Dilger,\n" -+ " | Copyright (C) 1995, Guy Eric Schalnat, Group 42 Inc.,\n" -+ " | and zlib version %s, Copyright (C) 1998-2002 (or later),\n" -+ " | Jean-loup Gailly and Mark Adler.\n", -+ PNGCRUSH_VERSION, progname, PNG_LIBPNG_VER_STRING, -+ png_get_header_version(NULL), ZLIB_VERSION); -+ -+#if defined(__GNUC__) -+ fprintf(STDERR, -+ " | It was compiled with gcc version %s", __VERSION__); -+# if defined(PNG_USE_PNGGCCRD) -+ fprintf(STDERR, -+ " and gas version %s", GAS_VERSION); -+# endif -+# if defined(__DJGPP__) -+ fprintf(STDERR, -+ "\n" -+ " | under DJGPP %d.%d, Copyright (C) 1995, D. J. Delorie\n" -+ " | and loaded with PMODE/DJ, by Thomas Pytel and Matthias Grimrath\n" -+ " | Copyright (C) 1996, Matthias Grimrath.\n", -+ __DJGPP__, __DJGPP_MINOR__); -+# else -+ fprintf(STDERR, ".\n"); -+# endif -+#endif -+ -+ fprintf(STDERR, "\n"); -+} -+ -+ -+ -+ -+ -+static const char *pngcrush_legal[] = { -+ "", -+ /* If you have modified this source, you may insert additional notices -+ * immediately after this sentence: */ -+ "Copyright (C) 1998-2002,2006-2008 Glenn Randers-Pehrson (glennrp@users.sf.net)", -+ "Copyright (C) 2005 Greg Roelofs", -+ "", -+ "DISCLAIMER: The pngcrush computer program is supplied \"AS IS\".", -+ "The Author disclaims all warranties, expressed or implied, including,", -+ "without limitation, the warranties of merchantability and of fitness", -+ "for any purpose. The Author assumes no liability for direct, indirect,", -+ "incidental, special, exemplary, or consequential damages, which may", -+ "result from the use of the computer program, even if advised of the", -+ "possibility of such damage. There is no warranty against interference", -+ "with your enjoyment of the computer program or against infringement.", -+ "There is no warranty that my efforts or the computer program will", -+ "fulfill any of your particular purposes or needs. This computer", -+ "program is provided with all faults, and the entire risk of satisfactory", -+ "quality, performance, accuracy, and effort is with the user.", -+ "", -+ "LICENSE: Permission is hereby irrevocably granted to everyone to use,", -+ "copy, modify, and distribute this computer program, or portions hereof,", -+ "purpose, without payment of any fee, subject to the following", -+ "restrictions:", -+ "", -+ "1. The origin of this binary or source code must not be misrepresented.", -+ "", -+ "2. Altered versions must be plainly marked as such and must not be", -+ "misrepresented as being the original binary or source.", -+ "", -+ "3. The Copyright notice, disclaimer, and license may not be removed", -+ "or altered from any source, binary, or altered source distribution.", -+ "" -+}; -+ -+static const char *pngcrush_usage[] = { -+ "\nusage: %s [options] infile.png outfile.png\n", -+ " %s -e ext [other options] files.png ...\n", -+ " %s -d dir [other options] files.png ...\n" -+}; -+ -+struct options_help pngcrush_options[] = { -+ {0, " -already already_crushed_size [e.g., 8192]"}, -+ {2, ""}, /* blank */ -+ {2, " If file has an IDAT greater than this size, it"}, -+ {2, " will be considered to be already crushed and will"}, -+ {2, " not be processed, unless you are making other changes"}, -+ {2, " or the \"-force\" option is present."}, -+ {2, ""}, -+ -+ {0, " -bit_depth depth (bit_depth to use in output file)"}, -+ {2, ""}, -+ {2, " Default output depth is same as input depth."}, -+ {2, ""}, -+ -+#ifdef Z_RLE -+ {0, " -brute (use brute-force: try 126 different methods [11-136])"}, -+#else -+ {0, " -brute (use brute-force: try 114 different methods [11-124])"}, -+#endif -+ {2, ""}, -+ {2, " Very time-consuming and generally not worthwhile."}, -+ {2, " You can restrict this option to certain filter types,"}, -+ {2, " compression levels, or strategies by following it"}, -+ {2, " with \"-f filter\", \"-l level\", or \"-z strategy\"."}, -+ {2, ""}, -+ -+ {0, " -c color_type of output file [0, 2, 4, or 6]"}, -+ {2, ""}, -+ {2, " Color type for the output file. Future versions"}, -+ {2, " will also allow color_type 3, if there are 256 or"}, -+ {2, " fewer colors present in the input file. Color types"}, -+ {2, " 4 and 6 are padded with an opaque alpha channel if"}, -+ {2, " the input file does not have alpha information."}, -+ {2, " You can use 0 or 4 to convert color to grayscale."}, -+ {2, " Use 0 or 2 to delete an unwanted alpha channel."}, -+ {2, " Default is to use same color type as the input file."}, -+ {2, ""}, -+ -+#ifdef PNGCRUSH_COUNT_COLORS -+ {0, " -cc (do color counting)"}, -+ {2, ""}, -+#endif -+ -+ {0, " -d directory_name (where output files will go)"}, -+ {2, ""}, -+ {2, " If a directory name is given, then the output"}, -+ {2, " files are placed in it, with the same filenames as"}, -+ {2, " those of the original files. For example,"}, -+ {2, " you would type 'pngcrush -directory CRUSHED *.png'"}, -+ {2, " to get *.png => CRUSHED/*.png"}, -+ {2, ""}, -+ -+ {0, FAKE_PAUSE_STRING}, -+ -+ {0, " -double_gamma (used for fixing gamma in PhotoShop 5.0/5.02 files)"}, -+ {2, ""}, -+ {2, " It has been claimed that the PS5 bug is actually"}, -+ {2, " more complex than that, in some unspecified way."}, -+ {2, ""}, -+ -+ {0, " -e extension (used for creating output filename)"}, -+ {2, ""}, -+ {2, " e.g., -ext .new means *.png => *.new"}, -+ {2, " and -e _C.png means *.png => *_C.png"}, -+ {2, ""}, -+ -+ {0, " -f user_filter [0-5]"}, -+ {2, ""}, -+ {2, " filter to use with the method specified in the"}, -+ {2, " preceding '-m method' or '-brute_force' argument."}, -+ {2, " 0: none; 1-4: use specified filter; 5: adaptive."}, -+ {2, ""}, -+ -+ {0, " -fix (fix otherwise fatal conditions such as bad CRCs)"}, -+ {2, ""}, -+ -+ {0, " -force (write a new output file even if larger than input)"}, -+ {2, ""}, -+ {2, " Otherwise the input file will be copied to output"}, -+ {2, " if it is smaller than any generated file and no chunk"}, -+ {2, " additions, removals, or changes were requested."}, -+ {2, ""}, -+ -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ {0, " -g gamma (float or fixed*100000, e.g., 0.45455 or 45455)"}, -+#else -+ {0, " -g gamma (float, e.g., 0.45455)"}, -+#endif -+ {2, ""}, -+ {2, " Value to insert in gAMA chunk, only if the input"}, -+ {2, " file has no gAMA chunk. To replace an existing"}, -+ {2, " gAMA chunk, use the '-replace_gamma' option."}, -+ {2, ""}, -+ -+ {0, FAKE_PAUSE_STRING}, -+ -+ {0, " -huffman (use only zlib strategy 2, Huffman-only)"}, -+ {2, ""}, -+ {2, " Fast, but almost never very effective except for"}, -+ {2, " certain rare image types."}, -+ {2, ""}, -+ -+#ifdef PNG_iCCP_SUPPORTED -+ {0, " -iccp length \"Profile Name\" iccp_file"}, -+ {2, ""}, -+ {2, " file with ICC profile to insert in an iCCP chunk."}, -+ {2, ""}, -+#endif -+ -+#ifdef PNG_iTXt_SUPPORTED -+ {0, " -itxt b[efore_IDAT]|a[fter_IDAT] \"keyword\""}, -+ {2, " \"language_code\" \"translated_keyword\" \"text\""}, -+ {2, ""}, -+ {2, " Uncompressed iTXt chunk to insert (see -text)."}, -+ {2, ""}, -+#endif -+ -+ {0, " -keep chunk_name"}, -+ {2, ""}, -+ {2, " keep named chunk even when pngcrush makes"}, -+ {2, " changes to the PNG datastream that cause it"}, -+ {2, " to become invalid. Currently only dSIG is"}, -+ {2, " recognized as a chunk to be kept."}, -+ {2, ""}, -+ -+ -+ {0, " -l zlib_compression_level [0-9]"}, -+ {2, ""}, -+ {2, " zlib compression level to use with method specified"}, -+ {2, " with the preceding '-m method' or '-brute_force'"}, -+ {2, " argument."}, -+ {2, ""}, -+ -+#ifdef PNGCRUSH_LOCO -+ {0, " -loco (\"loco crush\" truecolor PNGs)"}, -+ {2, ""}, -+ {2, " Make the file more compressible by performing a"}, -+ {2, " lossless, reversible, color transformation."}, -+ {2, " The resulting file is a MNG, not a PNG, and should"}, -+ {2, " be given the \".mng\" file extension. The"}, -+ {2, " \"loco\" option has no effect on grayscale or"}, -+ {2, " indexed-color PNG files."}, -+ {2, ""}, -+#endif -+ -+ {0, " -m method [0 through " STRNGIFY(MAX_METHODS) "]"}, -+ {2, ""}, -+ {2, " pngcrush method to try (0 means try all of 1-10)."}, -+ {2, " Can be repeated as in '-m 1 -m 4 -m 7'."}, -+ {2, " This can be useful if pngcrush runs out of memory"}, -+ {2, " when it tries methods 2, 3, 5, 6, 8, 9, or 10 which"}, -+ {2, " use filtering and are memory-intensive. Methods"}, -+ {2, " 1, 4, and 7 use no filtering; methods 11 and up use"}, -+ {2, " specified filter, compression level, and strategy."}, -+ {2, ""}, -+ {2, FAKE_PAUSE_STRING}, -+ -+ {0, " -max maximum_IDAT_size [default "STRNGIFY(PNG_ZBUF_SIZE)"]"}, -+ {2, ""}, -+ -+#ifdef PNGCRUSH_LOCO -+ {0, " -mng (write a new MNG, do not crush embedded PNGs)"}, -+ {2, ""}, -+#endif -+ -+ -+#ifdef PNGCRUSH_COUNT_COLORS -+ {0, " -no_cc (no color counting)"}, -+ {2, ""}, -+#endif -+ -+ {0, " -nofilecheck (do not check for infile.png == outfile.png)"}, -+ {2, ""}, -+ {2, " To avoid false hits from MSVC-compiled code. Note"}, -+ {2, " that if you use this option, you are responsible for"}, -+ {2, " ensuring that the input file is not the output file."}, -+ {2, ""}, -+ -+ {0, " -n (no save; does not do compression or write output PNG)"}, -+ {2, ""}, -+ {2, " Useful in conjunction with -v option to get info."}, -+ {2, ""}, -+ -+ -+ {0, " -plte_len n (truncate PLTE)"}, -+ {2, ""}, -+ {2, " Truncates the PLTE. Be sure not to truncate it to"}, -+ {2, " less than the greatest index present in IDAT."}, -+ {2, ""}, -+ -+ {0, " -q (quiet)"}, -+ {2, ""}, -+ -+ {0, " -reduce (do lossless color-type or bit-depth reduction)"}, -+ {2, ""}, -+ {2, " (if possible)"}, -+ {2, ""}, -+ -+ {0, " -rem chunkname (or \"alla\" or \"allb\")"}, -+ {2, ""}, -+ {2, " Name of an ancillary chunk or optional PLTE to be"}, -+ {2, " removed. Be careful with this. Please don't use "}, -+ {2, " this feature to remove transparency, gamma, copyright,"}, -+ {2, " or other valuable information. To remove several"}, -+ {2, " different chunks, repeat: -rem tEXt -rem pHYs."}, -+ {2, " Known chunks (those in the PNG 1.1 spec or extensions"}, -+ {2, " document) can be named with all lower-case letters,"}, -+ {2, " so \"-rem bkgd\" is equivalent to \"-rem bKGD\". But"}, -+ {2, " note: \"-rem text\" removes all forms of text chunks;"}, -+ {2, " Exact case is required to remove unknown chunks."}, -+ {2, " To do surgery with a chain-saw, \"-rem alla\" removes"}, -+ {2, " all known ancillary chunks except for tRNS, and"}, -+ {2, " \"-rem allb\" removes all but tRNS and gAMA."}, -+ {2, ""}, -+ -+ {0, FAKE_PAUSE_STRING}, -+ -+#ifdef PNG_FIXED_POINT_SUPPORTED -+ {0, "-replace_gamma gamma (float or fixed*100000) even if gAMA is present."}, -+#else -+ {0, "-replace_gamma gamma (float, e.g. 0.45455) even if gAMA is present."}, -+#endif -+ {2, ""}, -+ -+ {0, " -res dpi"}, -+ {2, ""}, -+ {2, " Write a pHYs chunk with the given resolution."}, -+ {2, ""}, -+ -+#ifdef Z_RLE -+ {0, " -rle (use only zlib strategy 3, RLE-only)"}, -+ {2, ""}, -+ {2, " A relatively fast subset of the \"-brute\" methods,"}, -+ {2, " generally more effective than \"-huffman\" on PNG images"}, -+ {2, " (and quite effective on black-and-white images),"}, -+ {2, " but not necessarily worth the bother otherwise."}, -+ {2, ""}, -+#endif -+ -+ {0, " -save (keep all copy-unsafe chunks)"}, -+ {2, ""}, -+ {2, " Save otherwise unknown ancillary chunks that would"}, -+ {2, " be considered copy-unsafe. This option makes"}, -+ {2, " chunks 'known' to pngcrush, so they can be copied."}, -+ {2, " It also causes the dSIG chunk to be saved, even when"}, -+ {2, " it becomes invalid due to datastream changes."}, -+ {2, ""}, -+ -+ {0, FAKE_PAUSE_STRING}, -+ -+ {0, " -srgb [0, 1, 2, or 3]"}, -+ {2, ""}, -+ {2, " Value of 'rendering intent' for sRGB chunk."}, -+ {2, ""}, -+ -+ {0, " -text b[efore_IDAT]|a[fter_IDAT] \"keyword\" \"text\""}, -+ {2, ""}, -+ {2, " tEXt chunk to insert. keyword < 80 chars,"}, -+ {2, " text < 2048 chars. For now, you can add no more than"}, -+ {2, " ten tEXt, iTXt, or zTXt chunks per pngcrush run."}, -+ {2, ""}, -+ -+#ifdef PNG_tRNS_SUPPORTED -+ {0, " -trns_array n trns[0] trns[1] .. trns[n-1]"}, -+ {2, ""}, -+ {2, " Insert a tRNS chunk, if no tRNS chunk found in file."}, -+ {2, " Values are for the tRNS array in indexed-color PNG."}, -+ {2, ""}, -+ -+ {0, " -trns index red green blue gray"}, -+ {2, ""}, -+ {2, " Insert a tRNS chunk, if no tRNS chunk found in file."}, -+ {2, " You must give all five parameters regardless of the"}, -+ {2, " color type, scaled to the output bit depth."}, -+ {2, ""}, -+#endif -+ -+ {0, " -v (display more detailed information)"}, -+ {2, ""}, -+ {2, " Repeat the option (use \"-v -v\") for even more."}, -+ {2, ""}, -+ -+ {0, " -version (display the pngcrush version)"}, -+ {2, ""}, -+ {2, " Look for the most recent version of pngcrush at"}, -+ {2, " http://pmt.sf.net"}, -+ {2, ""}, -+ -+ {0, " -w compression_window_size [32, 16, 8, 4, 2, 1, 512]"}, -+ {2, ""}, -+ {2, " Size of the sliding compression window, in kbytes"}, -+ {2, " (or bytes, in case of 512). It's best to"}, -+ {2, " use the default (32) unless you run out of memory."}, -+ {2, " The program will use a smaller window anyway when"}, -+ {2, " the uncompressed file is smaller than 16k."}, -+ {2, ""}, -+ -+#ifdef Z_RLE -+ {0, " -z zlib_strategy [0, 1, 2, or 3]"}, -+#else -+ {0, " -z zlib_strategy [0, 1, or 2]"}, -+#endif -+ {2, ""}, -+ {2, " zlib compression strategy to use with the preceding"}, -+ {2, " '-m method' argument."}, -+ {2, ""}, -+ -+ {0, " -zmem zlib_compression_mem_level [1-9, default 9]"}, -+ {2, ""}, -+ -+#ifdef PNG_iTXt_SUPPORTED -+ {0, " -zitxt b[efore_IDAT]|a[fter_IDAT] \"keyword\""}, -+ {2, " \"language_code\" \"translated_keyword\" \"text\""}, -+ {2, ""}, -+ {2, " Compressed iTXt chunk to insert (see -text)."}, -+ {2, ""}, -+#endif -+ -+ {0, " -ztxt b[efore_IDAT]|a[fter_IDAT] \"keyword\" \"text\""}, -+ {2, ""}, -+ {2, " zTXt chunk to insert (see -text)."}, -+ {2, ""}, -+ {2, FAKE_PAUSE_STRING}, -+ -+ {0, " -h (help and legal notices)"}, -+ {2, ""}, -+ {2, " Display this information."}, -+ {2, ""}, -+ -+ {0, " -p (pause)"} -+}; -+ -+ -+ -+ -+ -+void print_usage(int retval) -+{ -+ int j, jmax; -+ -+ if (verbose) { -+ jmax = sizeof(pngcrush_legal) / sizeof(char *); -+ for (j = 0; j < jmax; ++j) -+ fprintf(STDERR, "%s\n", pngcrush_legal[j]); -+ -+ jmax = sizeof(pngcrush_usage) / sizeof(char *); -+ for (j = 0; j < jmax; ++j) -+ fprintf(STDERR, pngcrush_usage[j], progname); /* special case */ -+ } -+ -+ /* this block is also handled specially due to the "else" clause... */ -+ if (verbose > 1) { -+ png_crush_pause(); -+ fprintf(STDERR, -+ "\n" -+ "options (Note: any option can be spelled out for clarity, e.g.,\n" -+ " \"pngcrush -dir New -method 7 -remove bkgd *.png\"\n" -+ " is the same as \"pngcrush -d New -m 7 -rem bkgd *.png\"):" -+ "\n\n"); -+ } else -+ fprintf(STDERR, "options:\n"); -+ -+ /* this is the main part of the help screen; it is more complex than the -+ * other blocks due to the mix of verbose and non-verbose lines */ -+ jmax = sizeof(pngcrush_options) / sizeof(struct options_help); -+ for (j = 0; j < jmax; ++j) { -+ if (verbose >= pngcrush_options[j].verbosity) { -+ if (pngcrush_options[j].textline[0] == FAKE_PAUSE_STRING[0]) -+ png_crush_pause(); -+ else -+ fprintf(STDERR, "%s\n", pngcrush_options[j].textline); -+ } -+ } -+ -+ /* due to progname, the verbose part of the -p option is handled explicitly -+ * (fortunately, it's the very last option anyway) */ -+ if (verbose > 1) { -+ fprintf(STDERR, "\n" -+ " Wait for [enter] key before continuing display.\n" -+ " e.g., type '%s -pause -help', if the help\n" -+ " screen scrolls out of sight.\n\n", progname); -+ } -+ -+ exit(retval); -+} diff --git a/media-gfx/pngcrush/pngcrush-1.6.7.ebuild b/media-gfx/pngcrush/pngcrush-1.6.7.ebuild deleted file mode 100644 index 8ebfd2a25ead..000000000000 --- a/media-gfx/pngcrush/pngcrush-1.6.7.ebuild +++ /dev/null @@ -1,35 +0,0 @@ -# Copyright 1999-2008 Gentoo Foundation -# Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/media-gfx/pngcrush/pngcrush-1.6.7.ebuild,v 1.4 2008/08/24 15:49:13 nixnut Exp $ - -inherit eutils toolchain-funcs - -DESCRIPTION="Portable Network Graphics (PNG) optimizing utility" -HOMEPAGE="http://pmt.sourceforge.net/pngcrush" -SRC_URI="mirror://debian/pool/main/p/${PN}/${PN}_${PV}.orig.tar.gz" - -LICENSE="as-is" -SLOT="0" -KEYWORDS="~alpha amd64 ppc x86" -IUSE="" - -DEPEND=">=media-libs/libpng-1.2.26-r1" - -S=${WORKDIR}/${P}-nolib - -src_unpack() { - unpack ${A} - cd "${S}" - # Use system libpng, fix various bugs and sanitize Makefile - epatch "${FILESDIR}"/${P}-modified_debian_patchset_1.patch -} - -src_compile() { - tc-export CC - emake || die "emake failed." -} - -src_install() { - dobin ${PN} || die "dobin failed." - dodoc *.txt -} |