summaryrefslogtreecommitdiff
path: root/graphics/h5utils/patches
diff options
context:
space:
mode:
authorwiz <wiz@pkgsrc.org>2011-02-01 09:05:30 +0000
committerwiz <wiz@pkgsrc.org>2011-02-01 09:05:30 +0000
commit5103fa3737bbee18085330b2f5a8cd2b7546bc22 (patch)
tree8bc4830995387e1636b5767961e1033b0e797e49 /graphics/h5utils/patches
parentf9885044968a453507ace23d5916ba018a997301 (diff)
downloadpkgsrc-5103fa3737bbee18085330b2f5a8cd2b7546bc22.tar.gz
Fix build with png-1.5.
Diffstat (limited to 'graphics/h5utils/patches')
-rw-r--r--graphics/h5utils/patches/patch-writepng.c42
1 files changed, 42 insertions, 0 deletions
diff --git a/graphics/h5utils/patches/patch-writepng.c b/graphics/h5utils/patches/patch-writepng.c
new file mode 100644
index 00000000000..42543c2938f
--- /dev/null
+++ b/graphics/h5utils/patches/patch-writepng.c
@@ -0,0 +1,42 @@
+$NetBSD: patch-writepng.c,v 1.1 2011/02/01 09:05:31 wiz Exp $
+
+Fix build with png-1.5.
+
+--- writepng.c.orig 2009-06-12 20:58:50.000000000 +0000
++++ writepng.c
+@@ -240,6 +240,8 @@ void writepng(char *filename,
+ double skewsin = sin(skew), skewcos = cos(skew);
+ REAL minoverlay = 0, maxoverlay = 0;
+ png_byte mask_byte;
++ png_colorp palette = NULL;
++
+
+ /* we must use direct color for translucent overlays */
+ if (overlay)
+@@ -309,7 +311,7 @@ void writepng(char *filename,
+ }
+ /* Set error handling. REQUIRED if you aren't supplying your own *
+ * error hadnling functions in the png_create_write_struct() call. */
+- if (setjmp(png_ptr->jmpbuf)) {
++ if (setjmp(png_jmpbuf(png_ptr))) {
+ /* If we get here, we had a problem reading the file */
+ fclose(fp);
+ png_destroy_write_struct(&png_ptr, (png_infopp) NULL);
+@@ -334,8 +336,6 @@ void writepng(char *filename,
+ PNG_INTERLACE_NONE,
+ PNG_COMPRESSION_TYPE_BASE, PNG_FILTER_TYPE_BASE);
+ else {
+- png_colorp palette;
+-
+ png_set_IHDR(png_ptr, info_ptr, width, height, 8 /* bit_depth */ ,
+ PNG_COLOR_TYPE_PALETTE,
+ PNG_INTERLACE_NONE,
+@@ -434,7 +434,7 @@ void writepng(char *filename,
+ png_write_end(png_ptr, info_ptr);
+
+ /* if you malloced the palette, free it here */
+- free(info_ptr->palette);
++ free(palette);
+
+ /* if you allocated any text comments, free them here */
+