Parag Nemade 5ac6d8
From e76a8a537dbf8c47024f5863f9f18ed55ad686d3 Mon Sep 17 00:00:00 2001
Parag Nemade 5ac6d8
From: michal-n <michal-n@users.sourceforge.net>
Parag Nemade 5ac6d8
Date: Sat, 17 Dec 2011 15:24:12 +0100
Parag Nemade 5ac6d8
Subject: [PATCH] There was no need to panic...
Parag Nemade 5ac6d8
 The patch from Paul contained errant reference to 'png_color16'.
Parag Nemade 5ac6d8
 The correct form is 'png_color_16'. So, patch reapplied.
Parag Nemade 5ac6d8
Parag Nemade 5ac6d8
---
Parag Nemade 5ac6d8
 gutils/gimagewritepng.c |  100 +++++++++++++++++++++++-----------------------
Parag Nemade 5ac6d8
 1 files changed, 50 insertions(+), 50 deletions(-)
Parag Nemade 5ac6d8
Parag Nemade 5ac6d8
diff --git a/gutils/gimagewritepng.c b/gutils/gimagewritepng.c
Parag Nemade 5ac6d8
index 43fa097..a88ec63 100644
Parag Nemade 5ac6d8
--- a/gutils/gimagewritepng.c
Parag Nemade 5ac6d8
+++ b/gutils/gimagewritepng.c
Parag Nemade 5ac6d8
@@ -236,6 +236,7 @@ return(false);
Parag Nemade 5ac6d8
        }
Parag Nemade 5ac6d8
    } else {
Parag Nemade 5ac6d8
        if ( base->trans!=-1 ) {
Parag Nemade 5ac6d8
+	   trans_color = galloc(sizeof(png_color_16));
Parag Nemade 5ac6d8
 	   trans_color->red = COLOR_RED(base->trans);
Parag Nemade 5ac6d8
 	   trans_color->green = COLOR_GREEN(base->trans);
Parag Nemade 5ac6d8
 	   trans_color->blue = COLOR_BLUE(base->trans);
Parag Nemade 5ac6d8
@@ -258,6 +259,7 @@ return(false);
Parag Nemade 5ac6d8
     _png_write_end(png_ptr, info_ptr);
Parag Nemade 5ac6d8
 
Parag Nemade 5ac6d8
     if ( trans_alpha!=NULL ) gfree(trans_alpha);
Parag Nemade 5ac6d8
+    if ( trans_color!=NULL ) gfree(trans_color);
Parag Nemade 5ac6d8
     if ( palette!=NULL ) gfree(palette);
Parag Nemade 5ac6d8
     _png_destroy_write_struct(&png_ptr, &info_ptr);
Parag Nemade 5ac6d8
     gfree(rows);
Parag Nemade 5ac6d8
@@ -296,7 +298,7 @@ static void user_error_fn(png_structp png_ptr, png_const_charp error_msg) {
Parag Nemade 5ac6d8
 #if (PNG_LIBPNG_VER < 10500)
Parag Nemade 5ac6d8
     longjmp(png_ptr->jmpbuf,1);
Parag Nemade 5ac6d8
 #else
Parag Nemade 5ac6d8
-    _png_longjmp (png_ptr, 1);
Parag Nemade 5ac6d8
+    png_longjmp (png_ptr, 1);
Parag Nemade 5ac6d8
 #endif
Parag Nemade 5ac6d8
 }
Parag Nemade 5ac6d8
 
Parag Nemade 5ac6d8
@@ -310,6 +312,12 @@ int GImageWrite_Png(GImage *gi, FILE *fp, int progressive) {
Parag Nemade 5ac6d8
     png_infop info_ptr;
Parag Nemade 5ac6d8
     png_byte **rows;
Parag Nemade 5ac6d8
     int i;
Parag Nemade 5ac6d8
+    int bit_depth;
Parag Nemade 5ac6d8
+    int color_type;
Parag Nemade 5ac6d8
+    int num_palette;
Parag Nemade 5ac6d8
+    png_bytep trans_alpha = NULL;
Parag Nemade 5ac6d8
+    png_color_16p trans_color = NULL;
Parag Nemade 5ac6d8
+    png_colorp palette = NULL;
Parag Nemade 5ac6d8
 
Parag Nemade 5ac6d8
    png_ptr = png_create_write_struct(PNG_LIBPNG_VER_STRING,
Parag Nemade 5ac6d8
       (void *)NULL, user_error_fn, user_warning_fn);
Parag Nemade 5ac6d8
@@ -336,65 +344,60 @@ return(false);
Parag Nemade 5ac6d8
 
Parag Nemade 5ac6d8
    png_init_io(png_ptr, fp);
Parag Nemade 5ac6d8
 
Parag Nemade 5ac6d8
-   info_ptr->width = base->width;
Parag Nemade 5ac6d8
-   info_ptr->height = base->height;
Parag Nemade 5ac6d8
-   info_ptr->bit_depth = 8;
Parag Nemade 5ac6d8
-   info_ptr->valid = 0;
Parag Nemade 5ac6d8
-   info_ptr->interlace_type = progressive;
Parag Nemade 5ac6d8
-   if ( base->trans!=-1 ) {
Parag Nemade 5ac6d8
-       info_ptr->num_trans = 1;
Parag Nemade 5ac6d8
-       info_ptr->valid |= PNG_INFO_tRNS;
Parag Nemade 5ac6d8
+   bit_depth = 8;
Parag Nemade 5ac6d8
+   num_palette = base->clut==NULL?2:base->clut->clut_len;
Parag Nemade 5ac6d8
+   if ( base->image_type==it_index || base->image_type==it_bitmap ) {
Parag Nemade 5ac6d8
+       color_type = PNG_COLOR_TYPE_PALETTE;
Parag Nemade 5ac6d8
+       if ( num_palette<=2 )
Parag Nemade 5ac6d8
+	   bit_depth=1;
Parag Nemade 5ac6d8
+       else if ( num_palette<=4 )
Parag Nemade 5ac6d8
+	   bit_depth=2;
Parag Nemade 5ac6d8
+       else if ( num_palette<=16 )
Parag Nemade 5ac6d8
+	   bit_depth=4;
Parag Nemade 5ac6d8
+   } else {
Parag Nemade 5ac6d8
+       color_type = PNG_COLOR_TYPE_RGB;
Parag Nemade 5ac6d8
+       if ( base->image_type == it_rgba )
Parag Nemade 5ac6d8
+	   color_type = PNG_COLOR_TYPE_RGB_ALPHA;
Parag Nemade 5ac6d8
    }
Parag Nemade 5ac6d8
+
Parag Nemade 5ac6d8
+   png_set_IHDR(png_ptr, info_ptr, base->width, base->height,
Parag Nemade 5ac6d8
+		bit_depth, color_type, progressive,
Parag Nemade 5ac6d8
+		PNG_COMPRESSION_TYPE_DEFAULT, PNG_FILTER_TYPE_DEFAULT);
Parag Nemade 5ac6d8
    if ( base->image_type==it_index || base->image_type==it_bitmap ) {
Parag Nemade 5ac6d8
-       info_ptr->color_type = PNG_COLOR_TYPE_PALETTE;
Parag Nemade 5ac6d8
-       info_ptr->valid |= PNG_INFO_PLTE;
Parag Nemade 5ac6d8
-       info_ptr->num_palette = base->clut==NULL?2:base->clut->clut_len;
Parag Nemade 5ac6d8
-       info_ptr->palette = (png_color *) galloc(info_ptr->num_palette*sizeof(png_color));
Parag Nemade 5ac6d8
+       palette = (png_color *) galloc(num_palette*sizeof(png_color));
Parag Nemade 5ac6d8
        if ( base->clut==NULL ) {
Parag Nemade 5ac6d8
-	    info_ptr->palette[0].red = info_ptr->palette[0].green = info_ptr->palette[0].blue = 0;
Parag Nemade 5ac6d8
-	    info_ptr->palette[1].red = info_ptr->palette[1].green = info_ptr->palette[1].blue = 0xff;
Parag Nemade 5ac6d8
+	    palette[0].red = palette[0].green = palette[0].blue = 0;
Parag Nemade 5ac6d8
+	    palette[1].red = palette[1].green = palette[1].blue = 0xff;
Parag Nemade 5ac6d8
        } else {
Parag Nemade 5ac6d8
-	   for ( i=0; i<info_ptr->num_palette; ++i ) {
Parag Nemade 5ac6d8
+	   for ( i=0; i
Parag Nemade 5ac6d8
 		long col = base->clut->clut[i];
Parag Nemade 5ac6d8
-		info_ptr->palette[i].red = COLOR_RED(col);
Parag Nemade 5ac6d8
-		info_ptr->palette[i].green = COLOR_GREEN(col);
Parag Nemade 5ac6d8
-		info_ptr->palette[i].blue = COLOR_BLUE(col);
Parag Nemade 5ac6d8
+		palette[i].red = COLOR_RED(col);
Parag Nemade 5ac6d8
+		palette[i].green = COLOR_GREEN(col);
Parag Nemade 5ac6d8
+		palette[i].blue = COLOR_BLUE(col);
Parag Nemade 5ac6d8
 	   }
Parag Nemade 5ac6d8
        }
Parag Nemade 5ac6d8
-       if ( info_ptr->num_palette<=2 )
Parag Nemade 5ac6d8
-	   info_ptr->bit_depth=1;
Parag Nemade 5ac6d8
-       else if ( info_ptr->num_palette<=4 )
Parag Nemade 5ac6d8
-	   info_ptr->bit_depth=2;
Parag Nemade 5ac6d8
-       else if ( info_ptr->num_palette<=16 )
Parag Nemade 5ac6d8
-	   info_ptr->bit_depth=4;
Parag Nemade 5ac6d8
-       if ( info_ptr->num_palette<=16 )
Parag Nemade 5ac6d8
+       png_set_PLTE(png_ptr, info_ptr, palette, num_palette);
Parag Nemade 5ac6d8
+       if ( num_palette<=16 )
Parag Nemade 5ac6d8
 	   png_set_packing(png_ptr);
Parag Nemade 5ac6d8
+
Parag Nemade 5ac6d8
        if ( base->trans!=-1 ) {
Parag Nemade 5ac6d8
-#if ( PNG_LIBPNG_VER_MAJOR > 1 || PNG_LIBPNG_VER_MINOR > 2 )
Parag Nemade 5ac6d8
-	   info_ptr->trans_alpha = galloc(1);
Parag Nemade 5ac6d8
-	   info_ptr->trans_alpha[0] = base->trans;
Parag Nemade 5ac6d8
-#else
Parag Nemade 5ac6d8
-	   info_ptr->trans = galloc(1);
Parag Nemade 5ac6d8
-	   info_ptr->trans[0] = base->trans;
Parag Nemade 5ac6d8
-#endif
Parag Nemade 5ac6d8
+	  trans_alpha = galloc(1);
Parag Nemade 5ac6d8
+	  trans_alpha[0] = base->trans;
Parag Nemade 5ac6d8
        }
Parag Nemade 5ac6d8
    } else {
Parag Nemade 5ac6d8
-       info_ptr->color_type = PNG_COLOR_TYPE_RGB;
Parag Nemade 5ac6d8
        if ( base->trans!=-1 ) {
Parag Nemade 5ac6d8
-#if ( PNG_LIBPNG_VER_MAJOR > 1 || PNG_LIBPNG_VER_MINOR > 2 )
Parag Nemade 5ac6d8
-	   info_ptr->trans_color.red = COLOR_RED(base->trans);
Parag Nemade 5ac6d8
-	   info_ptr->trans_color.green = COLOR_GREEN(base->trans);
Parag Nemade 5ac6d8
-	   info_ptr->trans_color.blue = COLOR_BLUE(base->trans);
Parag Nemade 5ac6d8
-#else
Parag Nemade 5ac6d8
-	   info_ptr->trans_values.red = COLOR_RED(base->trans);
Parag Nemade 5ac6d8
-	   info_ptr->trans_values.green = COLOR_GREEN(base->trans);
Parag Nemade 5ac6d8
-	   info_ptr->trans_values.blue = COLOR_BLUE(base->trans);
Parag Nemade 5ac6d8
-#endif
Parag Nemade 5ac6d8
+	   trans_color = galloc(sizeof(png_color_16));
Parag Nemade 5ac6d8
+	   trans_color->red = COLOR_RED(base->trans);
Parag Nemade 5ac6d8
+	   trans_color->green = COLOR_GREEN(base->trans);
Parag Nemade 5ac6d8
+	   trans_color->blue = COLOR_BLUE(base->trans);
Parag Nemade 5ac6d8
        }
Parag Nemade 5ac6d8
    }
Parag Nemade 5ac6d8
+   if ( base->trans!=-1 ) {
Parag Nemade 5ac6d8
+       png_set_tRNS(png_ptr, info_ptr, trans_alpha, 1, trans_color);
Parag Nemade 5ac6d8
+   }
Parag Nemade 5ac6d8
    png_write_info(png_ptr, info_ptr);
Parag Nemade 5ac6d8
 
Parag Nemade 5ac6d8
-    if (info_ptr->color_type == PNG_COLOR_TYPE_RGB)
Parag Nemade 5ac6d8
+    if (color_type == PNG_COLOR_TYPE_RGB)
Parag Nemade 5ac6d8
 	png_set_filler(png_ptr, '\0', PNG_FILLER_BEFORE);
Parag Nemade 5ac6d8
 
Parag Nemade 5ac6d8
     rows = galloc(base->height*sizeof(png_byte *));
Parag Nemade 5ac6d8
@@ -405,12 +408,9 @@ return(false);
Parag Nemade 5ac6d8
 
Parag Nemade 5ac6d8
     png_write_end(png_ptr, info_ptr);
Parag Nemade 5ac6d8
 
Parag Nemade 5ac6d8
-#if ( PNG_LIBPNG_VER_MAJOR > 1 || PNG_LIBPNG_VER_MINOR > 2 )
Parag Nemade 5ac6d8
-    if ( info_ptr->trans_alpha!=NULL ) gfree(info_ptr->trans_alpha);
Parag Nemade 5ac6d8
-#else
Parag Nemade 5ac6d8
-    if ( info_ptr->trans!=NULL ) gfree(info_ptr->trans);
Parag Nemade 5ac6d8
-#endif
Parag Nemade 5ac6d8
-    if ( info_ptr->palette!=NULL ) gfree(info_ptr->palette);
Parag Nemade 5ac6d8
+    if ( trans_alpha!=NULL ) gfree(trans_alpha);
Parag Nemade 5ac6d8
+    if ( trans_color!=NULL ) gfree(trans_color);
Parag Nemade 5ac6d8
+    if ( palette!=NULL ) gfree(palette);
Parag Nemade 5ac6d8
     png_destroy_write_struct(&png_ptr, &info_ptr);
Parag Nemade 5ac6d8
     gfree(rows);
Parag Nemade 5ac6d8
 return( 1 );
Parag Nemade 5ac6d8
-- 
Parag Nemade 5ac6d8
1.7.4.1
Parag Nemade 5ac6d8