From 80c7eac2acfd4096c1e69371da65391ab69c3bd8 Mon Sep 17 00:00:00 2001 From: Juergen Daubert Date: Sat, 24 Feb 2024 10:50:27 +0100 Subject: [PATCH] libpng: updated to version 1.6.43 --- libpng/.footprint | 6 +- libpng/.signature | 10 +- libpng/Pkgfile | 2 +- libpng/libpng-apng.patch | 419 +++++++++++++++++++++++++++++++-------- 4 files changed, 348 insertions(+), 89 deletions(-) diff --git a/libpng/.footprint b/libpng/.footprint index 524a34df4..67361f539 100644 --- a/libpng/.footprint +++ b/libpng/.footprint @@ -18,9 +18,9 @@ lrwxrwxrwx root/root usr/lib/libpng.la -> libpng16.la lrwxrwxrwx root/root usr/lib/libpng.so -> libpng16.so -rw-r--r-- root/root usr/lib/libpng16.a -rwxr-xr-x root/root usr/lib/libpng16.la -lrwxrwxrwx root/root usr/lib/libpng16.so -> libpng16.so.16.41.0 -lrwxrwxrwx root/root usr/lib/libpng16.so.16 -> libpng16.so.16.41.0 --rwxr-xr-x root/root usr/lib/libpng16.so.16.41.0 +lrwxrwxrwx root/root usr/lib/libpng16.so -> libpng16.so.16.43.0 +lrwxrwxrwx root/root usr/lib/libpng16.so.16 -> libpng16.so.16.43.0 +-rwxr-xr-x root/root usr/lib/libpng16.so.16.43.0 drwxr-xr-x root/root usr/lib/pkgconfig/ lrwxrwxrwx root/root usr/lib/pkgconfig/libpng.pc -> libpng16.pc -rw-r--r-- root/root usr/lib/pkgconfig/libpng16.pc diff --git a/libpng/.signature b/libpng/.signature index 195003ff7..d91190966 100644 --- a/libpng/.signature +++ b/libpng/.signature @@ -1,6 +1,6 @@ untrusted comment: verify with /etc/ports/opt.pub -RWSE3ohX2g5d/aVE7CtSyNp9cmpbyyK6xxo3nfqfhDHt9GlsKKK85beEc2+AocdfiVwLi7sIqwbbV2Dlk2U8T2frKOxQeY9YeAU= -SHA256 (Pkgfile) = 66bb2e019b9202a1cca49ff02db4a37e909a1eb88602192e8917733cd7b1f166 -SHA256 (.footprint) = 62ccf71b897ec2c3059522e68eb81368ecd97894b148c93469da1fd3e231c732 -SHA256 (libpng-1.6.42.tar.xz) = c919dbc11f4c03b05aba3f8884d8eb7adfe3572ad228af972bb60057bdb48450 -SHA256 (libpng-apng.patch) = 2234b5138069824e30e84357a36bd725c2cb3fd589d5c2135ecbe60b0b4800d8 +RWSE3ohX2g5d/aSNnlVgArh6gpZayuRsoxFU5vZD5dKwXuNdjVRqhbLSBZxlNYCeBZredKgIvj6WRvDDd7lSEI76Z53qY925LAs= +SHA256 (Pkgfile) = a20bf0cbff1a764111973211989ba22589582231b4cabd8a3d0b6a14263c99d5 +SHA256 (.footprint) = fd3b45a97540f1420eb9f86499e507ec3850c1f7e7506582ef08e8750243139f +SHA256 (libpng-1.6.43.tar.xz) = 6a5ca0652392a2d7c9db2ae5b40210843c0bbc081cbd410825ab00cc59f14a6c +SHA256 (libpng-apng.patch) = b351225f51e6080b1e91169968e7ad2f47cafc4ada77674e4c77a224d97c092f diff --git a/libpng/Pkgfile b/libpng/Pkgfile index 80072a267..3f58c6eec 100644 --- a/libpng/Pkgfile +++ b/libpng/Pkgfile @@ -4,7 +4,7 @@ # Depends on: zlib name=libpng -version=1.6.42 +version=1.6.43 release=1 source=(http://download.sourceforge.net/$name/$name-$version.tar.xz $name-apng.patch) diff --git a/libpng/libpng-apng.patch b/libpng/libpng-apng.patch index f346d9f7c..373db492f 100644 --- a/libpng/libpng-apng.patch +++ b/libpng/libpng-apng.patch @@ -1,7 +1,7 @@ -diff -Naru libpng-1.6.34.org/png.h libpng-1.6.34/png.h ---- libpng-1.6.34.org/png.h 2017-09-29 18:55:30.653711999 +0900 -+++ libpng-1.6.34/png.h 2017-09-29 18:56:30.306850103 +0900 -@@ -361,6 +361,10 @@ +diff -Nru libpng-1.6.43.orig/png.h libpng-1.6.43/png.h +--- libpng-1.6.43.orig/png.h 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/png.h 2024-02-24 10:42:18.501729536 +0100 +@@ -329,6 +329,10 @@ # include "pnglibconf.h" #endif @@ -12,7 +12,7 @@ diff -Naru libpng-1.6.34.org/png.h libpng-1.6.34/png.h #ifndef PNG_VERSION_INFO_ONLY /* Machine specific configuration. */ # include "pngconf.h" -@@ -456,6 +460,17 @@ +@@ -424,6 +428,17 @@ * See pngconf.h for base types that vary by machine/system */ @@ -30,7 +30,7 @@ diff -Naru libpng-1.6.34.org/png.h libpng-1.6.34/png.h /* This triggers a compiler error in png.c, if png.c and png.h * do not agree upon the version number. */ -@@ -777,6 +792,10 @@ +@@ -745,6 +760,10 @@ #define PNG_INFO_sCAL 0x4000U /* ESR, 1.0.6 */ #define PNG_INFO_IDAT 0x8000U /* ESR, 1.0.6 */ #define PNG_INFO_eXIf 0x10000U /* GR-P, 1.6.31 */ @@ -41,7 +41,7 @@ diff -Naru libpng-1.6.34.org/png.h libpng-1.6.34/png.h /* This is used for the transformation routines, as some of them * change these values for the row. It also should enable using -@@ -814,6 +833,10 @@ +@@ -782,6 +801,10 @@ #ifdef PNG_PROGRESSIVE_READ_SUPPORTED typedef PNG_CALLBACK(void, *png_progressive_info_ptr, (png_structp, png_infop)); typedef PNG_CALLBACK(void, *png_progressive_end_ptr, (png_structp, png_infop)); @@ -52,7 +52,7 @@ diff -Naru libpng-1.6.34.org/png.h libpng-1.6.34/png.h /* The following callback receives png_uint_32 row_number, int pass for the * png_bytep data of the row. When transforming an interlaced image the -@@ -3257,6 +3280,74 @@ +@@ -3229,6 +3252,74 @@ /******************************************************************************* * END OF HARDWARE AND SOFTWARE OPTIONS ******************************************************************************/ @@ -127,7 +127,7 @@ diff -Naru libpng-1.6.34.org/png.h libpng-1.6.34/png.h /* Maintainer: Put new public prototypes here ^, in libpng.3, in project * defs, and in scripts/symbols.def. -@@ -3266,7 +3357,11 @@ +@@ -3238,7 +3329,11 @@ * one to use is one more than this.) */ #ifdef PNG_EXPORT_LAST_ORDINAL @@ -139,10 +139,10 @@ diff -Naru libpng-1.6.34.org/png.h libpng-1.6.34/png.h #endif #ifdef __cplusplus -diff -Naru libpng-1.6.34.org/pngget.c libpng-1.6.34/pngget.c ---- libpng-1.6.34.org/pngget.c 2017-09-29 18:53:22.698691668 +0900 -+++ libpng-1.6.34/pngget.c 2017-09-29 18:56:30.286848380 +0900 -@@ -1245,4 +1245,166 @@ +diff -Nru libpng-1.6.43.orig/pngget.c libpng-1.6.43/pngget.c +--- libpng-1.6.43.orig/pngget.c 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/pngget.c 2024-02-24 10:42:18.501729536 +0100 +@@ -1264,4 +1264,166 @@ # endif #endif @@ -309,9 +309,9 @@ diff -Naru libpng-1.6.34.org/pngget.c libpng-1.6.34/pngget.c +} +#endif /* PNG_APNG_SUPPORTED */ #endif /* READ || WRITE */ -diff -Naru libpng-1.6.34.org/pnginfo.h libpng-1.6.34/pnginfo.h ---- libpng-1.6.34.org/pnginfo.h 2017-09-29 18:53:22.698691668 +0900 -+++ libpng-1.6.34/pnginfo.h 2017-09-29 18:56:30.286848380 +0900 +diff -Nru libpng-1.6.43.orig/pnginfo.h libpng-1.6.43/pnginfo.h +--- libpng-1.6.43.orig/pnginfo.h 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/pnginfo.h 2024-02-24 10:42:18.501729536 +0100 @@ -263,5 +263,18 @@ png_bytepp row_pointers; /* the image bits */ #endif @@ -331,9 +331,9 @@ diff -Naru libpng-1.6.34.org/pnginfo.h libpng-1.6.34/pnginfo.h + }; #endif /* PNGINFO_H */ -diff -Naru libpng-1.6.34.org/pngpread.c libpng-1.6.34/pngpread.c ---- libpng-1.6.34.org/pngpread.c 2017-09-29 18:53:22.698691668 +0900 -+++ libpng-1.6.34/pngpread.c 2017-09-29 18:56:30.286848380 +0900 +diff -Nru libpng-1.6.43.orig/pngpread.c libpng-1.6.43/pngpread.c +--- libpng-1.6.43.orig/pngpread.c 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/pngpread.c 2024-02-24 10:42:18.501729536 +0100 @@ -195,6 +195,106 @@ chunk_name = png_ptr->chunk_name; @@ -451,7 +451,7 @@ diff -Naru libpng-1.6.34.org/pngpread.c libpng-1.6.34/pngpread.c png_ptr->idat_size = png_ptr->push_length; png_ptr->process_mode = PNG_READ_IDAT_MODE; png_push_have_info(png_ptr, info_ptr); -@@ -406,6 +509,30 @@ +@@ -414,6 +517,30 @@ png_handle_iTXt(png_ptr, info_ptr, png_ptr->push_length); } #endif @@ -482,7 +482,7 @@ diff -Naru libpng-1.6.34.org/pngpread.c libpng-1.6.34/pngpread.c else { -@@ -539,7 +666,11 @@ +@@ -547,7 +674,11 @@ png_byte chunk_tag[4]; /* TODO: this code can be commoned up with the same code in push_read */ @@ -494,7 +494,7 @@ diff -Naru libpng-1.6.34.org/pngpread.c libpng-1.6.34/pngpread.c png_push_fill_buffer(png_ptr, chunk_length, 4); png_ptr->push_length = png_get_uint_31(png_ptr, chunk_length); png_reset_crc(png_ptr); -@@ -547,17 +678,64 @@ +@@ -555,17 +686,64 @@ png_ptr->chunk_name = PNG_CHUNK_FROM_STRING(chunk_tag); png_ptr->mode |= PNG_HAVE_CHUNK_HEADER; @@ -559,7 +559,7 @@ diff -Naru libpng-1.6.34.org/pngpread.c libpng-1.6.34/pngpread.c } if (png_ptr->idat_size != 0 && png_ptr->save_buffer_size != 0) -@@ -631,6 +809,15 @@ +@@ -639,6 +817,15 @@ if (!(buffer_length > 0) || buffer == NULL) png_error(png_ptr, "No IDAT data (internal error)"); @@ -575,7 +575,7 @@ diff -Naru libpng-1.6.34.org/pngpread.c libpng-1.6.34/pngpread.c /* This routine must process all the data it has been given * before returning, calling the row callback as required to * handle the uncompressed results. -@@ -1085,6 +1272,18 @@ +@@ -1093,6 +1280,18 @@ png_set_read_fn(png_ptr, progressive_ptr, png_push_fill_buffer); } @@ -594,12 +594,12 @@ diff -Naru libpng-1.6.34.org/pngpread.c libpng-1.6.34/pngpread.c png_voidp PNGAPI png_get_progressive_ptr(png_const_structrp png_ptr) { -diff -Naru libpng-1.6.34.org/pngpriv.h libpng-1.6.34/pngpriv.h ---- libpng-1.6.34.org/pngpriv.h 2017-09-29 18:53:22.699691754 +0900 -+++ libpng-1.6.34/pngpriv.h 2017-09-29 18:56:30.286848380 +0900 -@@ -628,6 +628,10 @@ +diff -Nru libpng-1.6.43.orig/pngpriv.h libpng-1.6.43/pngpriv.h +--- libpng-1.6.43.orig/pngpriv.h 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/pngpriv.h 2024-02-24 10:42:18.501729536 +0100 +@@ -662,6 +662,10 @@ #define PNG_HAVE_CHUNK_AFTER_IDAT 0x2000U /* Have another chunk after IDAT */ - /* 0x4000U (unused) */ + #define PNG_WROTE_eXIf 0x4000U #define PNG_IS_READ_STRUCT 0x8000U /* Else is a write struct */ +#ifdef PNG_APNG_SUPPORTED +#define PNG_HAVE_acTL 0x10000U @@ -608,7 +608,7 @@ diff -Naru libpng-1.6.34.org/pngpriv.h libpng-1.6.34/pngpriv.h /* Flags for the transformations the PNG library does on the image data */ #define PNG_BGR 0x0001U -@@ -864,6 +868,16 @@ +@@ -898,6 +902,16 @@ #define png_tRNS PNG_U32(116, 82, 78, 83) #define png_zTXt PNG_U32(122, 84, 88, 116) @@ -625,7 +625,7 @@ diff -Naru libpng-1.6.34.org/pngpriv.h libpng-1.6.34/pngpriv.h /* The following will work on (signed char*) strings, whereas the get_uint_32 * macro will fail on top-bit-set values because of the sign extension. */ -@@ -1635,6 +1649,47 @@ +@@ -1703,6 +1717,47 @@ */ #endif @@ -673,9 +673,9 @@ diff -Naru libpng-1.6.34.org/pngpriv.h libpng-1.6.34/pngpriv.h /* Added at libpng version 1.4.0 */ #ifdef PNG_COLORSPACE_SUPPORTED /* These internal functions are for maintaining the colorspace structure within -diff -Naru libpng-1.6.34.org/pngread.c libpng-1.6.34/pngread.c ---- libpng-1.6.34.org/pngread.c 2017-09-29 18:53:22.699691754 +0900 -+++ libpng-1.6.34/pngread.c 2017-09-29 18:56:30.286848380 +0900 +diff -Nru libpng-1.6.43.orig/pngread.c libpng-1.6.43/pngread.c +--- libpng-1.6.43.orig/pngread.c 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/pngread.c 2024-02-24 10:42:18.501729536 +0100 @@ -161,6 +161,9 @@ else if (chunk_name == png_IDAT) @@ -777,10 +777,10 @@ diff -Naru libpng-1.6.34.org/pngread.c libpng-1.6.34/pngread.c /* Optional call to update the users info_ptr structure */ void PNGAPI png_read_update_info(png_structrp png_ptr, png_inforp info_ptr) -diff -Naru libpng-1.6.34.org/pngrutil.c libpng-1.6.34/pngrutil.c ---- libpng-1.6.34.org/pngrutil.c 2017-09-29 18:53:22.701691926 +0900 -+++ libpng-1.6.34/pngrutil.c 2017-09-29 18:56:30.287848466 +0900 -@@ -865,6 +865,11 @@ +diff -Nru libpng-1.6.43.orig/pngrutil.c libpng-1.6.43/pngrutil.c +--- libpng-1.6.43.orig/pngrutil.c 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/pngrutil.c 2024-02-24 10:42:18.501729536 +0100 +@@ -863,6 +863,11 @@ filter_type = buf[11]; interlace_type = buf[12]; @@ -792,7 +792,7 @@ diff -Naru libpng-1.6.34.org/pngrutil.c libpng-1.6.34/pngrutil.c /* Set internal variables */ png_ptr->width = width; png_ptr->height = height; -@@ -2840,6 +2845,179 @@ +@@ -2857,6 +2862,179 @@ } #endif @@ -972,7 +972,7 @@ diff -Naru libpng-1.6.34.org/pngrutil.c libpng-1.6.34/pngrutil.c #ifdef PNG_READ_UNKNOWN_CHUNKS_SUPPORTED /* Utility function for png_handle_unknown; set up png_ptr::unknown_chunk */ static int -@@ -4145,7 +4323,38 @@ +@@ -4165,7 +4343,38 @@ { uInt avail_in; png_bytep buffer; @@ -983,7 +983,7 @@ diff -Naru libpng-1.6.34.org/pngrutil.c libpng-1.6.34/pngrutil.c + { + png_crc_finish(png_ptr, bytes_to_skip); + bytes_to_skip = 0; -+ + + png_ptr->idat_size = png_read_chunk_header(png_ptr); + if (png_ptr->num_frames_read == 0) + { @@ -1001,7 +1001,7 @@ diff -Naru libpng-1.6.34.org/pngrutil.c libpng-1.6.34/pngrutil.c + bytes_to_skip = png_ptr->idat_size; + continue; + } - ++ + png_ensure_sequence_number(png_ptr, png_ptr->idat_size); + + png_ptr->idat_size -= 4; @@ -1011,7 +1011,7 @@ diff -Naru libpng-1.6.34.org/pngrutil.c libpng-1.6.34/pngrutil.c while (png_ptr->idat_size == 0) { png_crc_finish(png_ptr, 0); -@@ -4157,7 +4366,7 @@ +@@ -4177,7 +4386,7 @@ if (png_ptr->chunk_name != png_IDAT) png_error(png_ptr, "Not enough image data"); } @@ -1020,7 +1020,7 @@ diff -Naru libpng-1.6.34.org/pngrutil.c libpng-1.6.34/pngrutil.c avail_in = png_ptr->IDAT_read_size; if (avail_in > png_ptr->idat_size) -@@ -4220,6 +4429,9 @@ +@@ -4240,6 +4449,9 @@ png_ptr->mode |= PNG_AFTER_IDAT; png_ptr->flags |= PNG_FLAG_ZSTREAM_ENDED; @@ -1030,7 +1030,7 @@ diff -Naru libpng-1.6.34.org/pngrutil.c libpng-1.6.34/pngrutil.c if (png_ptr->zstream.avail_in > 0 || png_ptr->idat_size > 0) png_chunk_benign_error(png_ptr, "Extra compressed data"); -@@ -4658,4 +4870,80 @@ +@@ -4677,4 +4889,80 @@ png_ptr->flags |= PNG_FLAG_ROW_INIT; } @@ -1111,10 +1111,10 @@ diff -Naru libpng-1.6.34.org/pngrutil.c libpng-1.6.34/pngrutil.c +#endif /* PNG_PROGRESSIVE_READ_SUPPORTED */ +#endif /* PNG_READ_APNG_SUPPORTED */ #endif /* READ */ -diff -Naru libpng-1.6.34.org/pngset.c libpng-1.6.34/pngset.c ---- libpng-1.6.34.org/pngset.c 2017-09-29 18:53:22.701691926 +0900 -+++ libpng-1.6.34/pngset.c 2017-09-29 18:56:30.292848897 +0900 -@@ -288,6 +288,11 @@ +diff -Nru libpng-1.6.43.orig/pngset.c libpng-1.6.43/pngset.c +--- libpng-1.6.43.orig/pngset.c 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/pngset.c 2024-02-24 10:42:18.501729536 +0100 +@@ -280,6 +280,11 @@ info_ptr->pixel_depth = (png_byte)(info_ptr->channels * info_ptr->bit_depth); info_ptr->rowbytes = PNG_ROWBYTES(info_ptr->pixel_depth, width); @@ -1126,7 +1126,7 @@ diff -Naru libpng-1.6.34.org/pngset.c libpng-1.6.34/pngset.c } #ifdef PNG_oFFs_SUPPORTED -@@ -1158,6 +1163,147 @@ +@@ -1151,6 +1156,147 @@ } #endif /* sPLT */ @@ -1274,10 +1274,10 @@ diff -Naru libpng-1.6.34.org/pngset.c libpng-1.6.34/pngset.c #ifdef PNG_STORE_UNKNOWN_CHUNKS_SUPPORTED static png_byte check_location(png_const_structrp png_ptr, int location) -diff -Naru libpng-1.6.34.org/pngstruct.h libpng-1.6.34/pngstruct.h ---- libpng-1.6.34.org/pngstruct.h 2017-09-29 18:53:22.701691926 +0900 -+++ libpng-1.6.34/pngstruct.h 2017-09-29 18:56:30.287848466 +0900 -@@ -403,6 +403,27 @@ +diff -Nru libpng-1.6.43.orig/pngstruct.h libpng-1.6.43/pngstruct.h +--- libpng-1.6.43.orig/pngstruct.h 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/pngstruct.h 2024-02-24 10:42:18.505062868 +0100 +@@ -399,6 +399,27 @@ png_byte filter_type; #endif @@ -1305,13 +1305,13 @@ diff -Naru libpng-1.6.34.org/pngstruct.h libpng-1.6.34/pngstruct.h /* New members added in libpng-1.2.0 */ /* New members added in libpng-1.0.2 but first enabled by default in 1.2.0 */ -diff -Naru libpng-1.6.34.org/pngtest.c libpng-1.6.34/pngtest.c ---- libpng-1.6.34.org/pngtest.c 2017-09-29 18:55:30.654712085 +0900 -+++ libpng-1.6.34/pngtest.c 2017-09-29 18:56:30.287848466 +0900 -@@ -875,6 +875,10 @@ - volatile int num_passes; - int pass; +diff -Nru libpng-1.6.43.orig/pngtest.c libpng-1.6.43/pngtest.c +--- libpng-1.6.43.orig/pngtest.c 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/pngtest.c 2024-02-24 10:42:46.448396344 +0100 +@@ -882,6 +882,10 @@ int bit_depth, color_type; + user_chunk_info my_user_chunk_data; + int pass, num_passes; +#ifdef PNG_APNG_SUPPORTED + png_uint_32 num_frames; + png_uint_32 num_plays; @@ -1319,7 +1319,7 @@ diff -Naru libpng-1.6.34.org/pngtest.c libpng-1.6.34/pngtest.c row_buf = NULL; error_parameters.file_name = inname; -@@ -1381,6 +1385,22 @@ +@@ -1380,6 +1384,22 @@ } } #endif @@ -1342,7 +1342,7 @@ diff -Naru libpng-1.6.34.org/pngtest.c libpng-1.6.34/pngtest.c #ifdef PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED { png_unknown_chunkp unknowns; -@@ -1461,6 +1481,110 @@ +@@ -1439,6 +1459,110 @@ t_misc += (t_stop - t_start); t_start = t_stop; #endif @@ -1453,9 +1453,9 @@ diff -Naru libpng-1.6.34.org/pngtest.c libpng-1.6.34/pngtest.c for (pass = 0; pass < num_passes; pass++) { # ifdef calc_pass_height -diff -Naru libpng-1.6.34.org/pngwrite.c libpng-1.6.34/pngwrite.c ---- libpng-1.6.34.org/pngwrite.c 2017-09-29 18:53:22.702692013 +0900 -+++ libpng-1.6.34/pngwrite.c 2017-09-29 18:56:30.288848552 +0900 +diff -Nru libpng-1.6.43.orig/pngwrite.c libpng-1.6.43/pngwrite.c +--- libpng-1.6.43.orig/pngwrite.c 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/pngwrite.c 2024-02-24 10:42:18.505062868 +0100 @@ -128,6 +128,10 @@ * the application continues writing the PNG. So check the 'invalid' * flag here too. @@ -1467,7 +1467,7 @@ diff -Naru libpng-1.6.34.org/pngwrite.c libpng-1.6.34/pngwrite.c #ifdef PNG_GAMMA_SUPPORTED # ifdef PNG_WRITE_gAMA_SUPPORTED if ((info_ptr->colorspace.flags & PNG_COLORSPACE_INVALID) == 0 && -@@ -370,6 +374,11 @@ +@@ -374,6 +378,11 @@ png_benign_error(png_ptr, "Wrote palette index exceeding num_palette"); #endif @@ -1479,7 +1479,7 @@ diff -Naru libpng-1.6.34.org/pngwrite.c libpng-1.6.34/pngwrite.c /* See if user wants us to write information chunks */ if (info_ptr != NULL) { -@@ -1461,6 +1470,43 @@ +@@ -1484,6 +1493,43 @@ } #endif @@ -1523,12 +1523,12 @@ diff -Naru libpng-1.6.34.org/pngwrite.c libpng-1.6.34/pngwrite.c #ifdef PNG_SIMPLIFIED_WRITE_SUPPORTED /* Initialize the write structure - general purpose utility. */ -diff -Naru libpng-1.6.34.org/pngwutil.c libpng-1.6.34/pngwutil.c ---- libpng-1.6.34.org/pngwutil.c 2017-09-29 18:53:22.703692099 +0900 -+++ libpng-1.6.34/pngwutil.c 2017-09-29 18:56:30.302849758 +0900 -@@ -822,6 +822,11 @@ +diff -Nru libpng-1.6.43.orig/pngwutil.c libpng-1.6.43/pngwutil.c +--- libpng-1.6.43.orig/pngwutil.c 2024-02-24 10:41:31.941729303 +0100 ++++ libpng-1.6.43/pngwutil.c 2024-02-24 10:42:18.505062868 +0100 +@@ -821,6 +821,11 @@ /* Write the chunk */ - png_write_complete_chunk(png_ptr, png_IHDR, buf, (png_size_t)13); + png_write_complete_chunk(png_ptr, png_IHDR, buf, 13); +#ifdef PNG_WRITE_APNG_SUPPORTED + png_ptr->first_frame_width = width; @@ -1538,7 +1538,7 @@ diff -Naru libpng-1.6.34.org/pngwutil.c libpng-1.6.34/pngwutil.c if ((png_ptr->do_filter) == PNG_NO_FILTERS) { if (png_ptr->color_type == PNG_COLOR_TYPE_PALETTE || -@@ -1003,8 +1008,17 @@ +@@ -1002,8 +1007,17 @@ optimize_cmf(data, png_image_size(png_ptr)); #endif @@ -1558,7 +1558,7 @@ diff -Naru libpng-1.6.34.org/pngwutil.c libpng-1.6.34/pngwutil.c png_ptr->mode |= PNG_HAVE_IDAT; png_ptr->zstream.next_out = data; -@@ -1051,7 +1065,17 @@ +@@ -1050,7 +1064,17 @@ #endif if (size > 0) @@ -1576,7 +1576,7 @@ diff -Naru libpng-1.6.34.org/pngwutil.c libpng-1.6.34/pngwutil.c png_ptr->zstream.avail_out = 0; png_ptr->zstream.next_out = NULL; png_ptr->mode |= PNG_HAVE_IDAT | PNG_AFTER_IDAT; -@@ -1887,6 +1911,82 @@ +@@ -1885,6 +1909,82 @@ } #endif @@ -1659,7 +1659,7 @@ diff -Naru libpng-1.6.34.org/pngwutil.c libpng-1.6.34/pngwutil.c /* Initializes the row writing capability of libpng */ void /* PRIVATE */ png_write_start_row(png_structrp png_ptr) -@@ -2781,4 +2881,39 @@ +@@ -2778,4 +2878,39 @@ } #endif /* WRITE_FLUSH */ } @@ -1699,10 +1699,10 @@ diff -Naru libpng-1.6.34.org/pngwutil.c libpng-1.6.34/pngwutil.c +} +#endif /* PNG_WRITE_APNG_SUPPORTED */ #endif /* WRITE */ -diff -Naru libpng-1.6.34.org/scripts/symbols.def libpng-1.6.34/scripts/symbols.def ---- libpng-1.6.34.org/scripts/symbols.def 2017-09-29 18:55:30.655712171 +0900 -+++ libpng-1.6.34/scripts/symbols.def 2017-09-29 18:56:30.289848638 +0900 -@@ -254,3 +254,23 @@ +diff -Nru libpng-1.6.43.orig/scripts/symbols.def libpng-1.6.43/scripts/symbols.def +--- libpng-1.6.43.orig/scripts/symbols.def 2024-02-24 10:41:31.945062636 +0100 ++++ libpng-1.6.43/scripts/symbols.def 2024-02-24 10:42:18.505062868 +0100 +@@ -253,3 +253,23 @@ png_set_eXIf @247 png_get_eXIf_1 @248 png_set_eXIf_1 @249 @@ -1726,3 +1726,262 @@ diff -Naru libpng-1.6.34.org/scripts/symbols.def libpng-1.6.34/scripts/symbols.d + png_set_progressive_frame_fn @267 + png_write_frame_head @268 + png_write_frame_tail @269 +diff -Nru libpng-1.6.43.orig/scripts/symbols.def.orig libpng-1.6.43/scripts/symbols.def.orig +--- libpng-1.6.43.orig/scripts/symbols.def.orig 1970-01-01 01:00:00.000000000 +0100 ++++ libpng-1.6.43/scripts/symbols.def.orig 2024-02-23 10:51:40.000000000 +0100 +@@ -0,0 +1,255 @@ ++;-------------------------------------------------------------- ++; LIBPNG symbol list as a Win32 DEF file ++; Contains all the symbols that can be exported from libpng ++;-------------------------------------------------------------- ++LIBRARY ++ ++EXPORTS ++ png_access_version_number @1 ++ png_set_sig_bytes @2 ++ png_sig_cmp @3 ++ png_create_read_struct @4 ++ png_create_write_struct @5 ++ png_get_compression_buffer_size @6 ++ png_set_compression_buffer_size @7 ++ png_set_longjmp_fn @8 ++ png_longjmp @9 ++ png_reset_zstream @10 ++ png_create_read_struct_2 @11 ++ png_create_write_struct_2 @12 ++ png_write_sig @13 ++ png_write_chunk @14 ++ png_write_chunk_start @15 ++ png_write_chunk_data @16 ++ png_write_chunk_end @17 ++ png_create_info_struct @18 ++ png_info_init_3 @19 ++ png_write_info_before_PLTE @20 ++ png_write_info @21 ++ png_read_info @22 ++ png_convert_to_rfc1123 @23 ++ png_convert_from_struct_tm @24 ++ png_convert_from_time_t @25 ++ png_set_expand @26 ++ png_set_expand_gray_1_2_4_to_8 @27 ++ png_set_palette_to_rgb @28 ++ png_set_tRNS_to_alpha @29 ++ png_set_bgr @30 ++ png_set_gray_to_rgb @31 ++ png_set_rgb_to_gray @32 ++ png_set_rgb_to_gray_fixed @33 ++ png_get_rgb_to_gray_status @34 ++ png_build_grayscale_palette @35 ++ png_set_strip_alpha @36 ++ png_set_swap_alpha @37 ++ png_set_invert_alpha @38 ++ png_set_filler @39 ++ png_set_add_alpha @40 ++ png_set_swap @41 ++ png_set_packing @42 ++ png_set_packswap @43 ++ png_set_shift @44 ++ png_set_interlace_handling @45 ++ png_set_invert_mono @46 ++ png_set_background @47 ++ png_set_strip_16 @48 ++ png_set_quantize @49 ++ png_set_gamma @50 ++ png_set_flush @51 ++ png_write_flush @52 ++ png_start_read_image @53 ++ png_read_update_info @54 ++ png_read_rows @55 ++ png_read_row @56 ++ png_read_image @57 ++ png_write_row @58 ++ png_write_rows @59 ++ png_write_image @60 ++ png_write_end @61 ++ png_read_end @62 ++ png_destroy_info_struct @63 ++ png_destroy_read_struct @64 ++ png_destroy_write_struct @65 ++ png_set_crc_action @66 ++ png_set_filter @67 ++ png_set_filter_heuristics @68 ++ png_set_compression_level @69 ++ png_set_compression_mem_level @70 ++ png_set_compression_strategy @71 ++ png_set_compression_window_bits @72 ++ png_set_compression_method @73 ++ png_init_io @74 ++ png_set_error_fn @75 ++ png_get_error_ptr @76 ++ png_set_write_fn @77 ++ png_set_read_fn @78 ++ png_get_io_ptr @79 ++ png_set_read_status_fn @80 ++ png_set_write_status_fn @81 ++ png_set_mem_fn @82 ++ png_get_mem_ptr @83 ++ png_set_read_user_transform_fn @84 ++ png_set_write_user_transform_fn @85 ++ png_set_user_transform_info @86 ++ png_get_user_transform_ptr @87 ++ png_set_read_user_chunk_fn @88 ++ png_get_user_chunk_ptr @89 ++ png_set_progressive_read_fn @90 ++ png_get_progressive_ptr @91 ++ png_process_data @92 ++ png_progressive_combine_row @93 ++ png_malloc @94 ++ png_calloc @95 ++ png_malloc_warn @96 ++ png_free @97 ++ png_free_data @98 ++ png_data_freer @99 ++ png_malloc_default @100 ++ png_free_default @101 ++ png_error @102 ++ png_chunk_error @103 ++ png_err @104 ++ png_warning @105 ++ png_chunk_warning @106 ++ png_benign_error @107 ++ png_chunk_benign_error @108 ++ png_set_benign_errors @109 ++ png_get_valid @110 ++ png_get_rowbytes @111 ++ png_get_rows @112 ++ png_set_rows @113 ++ png_get_channels @114 ++ png_get_image_width @115 ++ png_get_image_height @116 ++ png_get_bit_depth @117 ++ png_get_color_type @118 ++ png_get_filter_type @119 ++ png_get_interlace_type @120 ++ png_get_compression_type @121 ++ png_get_pixels_per_meter @122 ++ png_get_x_pixels_per_meter @123 ++ png_get_y_pixels_per_meter @124 ++ png_get_pixel_aspect_ratio @125 ++ png_get_x_offset_pixels @126 ++ png_get_y_offset_pixels @127 ++ png_get_x_offset_microns @128 ++ png_get_y_offset_microns @129 ++ png_get_signature @130 ++ png_get_bKGD @131 ++ png_set_bKGD @132 ++ png_get_cHRM @133 ++ png_get_cHRM_fixed @134 ++ png_set_cHRM @135 ++ png_set_cHRM_fixed @136 ++ png_get_gAMA @137 ++ png_get_gAMA_fixed @138 ++ png_set_gAMA @139 ++ png_set_gAMA_fixed @140 ++ png_get_hIST @141 ++ png_set_hIST @142 ++ png_get_IHDR @143 ++ png_set_IHDR @144 ++ png_get_oFFs @145 ++ png_set_oFFs @146 ++ png_get_pCAL @147 ++ png_set_pCAL @148 ++ png_get_pHYs @149 ++ png_set_pHYs @150 ++ png_get_PLTE @151 ++ png_set_PLTE @152 ++ png_get_sBIT @153 ++ png_set_sBIT @154 ++ png_get_sRGB @155 ++ png_set_sRGB @156 ++ png_set_sRGB_gAMA_and_cHRM @157 ++ png_get_iCCP @158 ++ png_set_iCCP @159 ++ png_get_sPLT @160 ++ png_set_sPLT @161 ++ png_get_text @162 ++ png_set_text @163 ++ png_get_tIME @164 ++ png_set_tIME @165 ++ png_get_tRNS @166 ++ png_set_tRNS @167 ++ png_get_sCAL @168 ++ png_get_sCAL_s @169 ++ png_set_sCAL @170 ++ png_set_sCAL_s @171 ++ png_set_keep_unknown_chunks @172 ++ png_handle_as_unknown @173 ++ png_set_unknown_chunks @174 ++ png_set_unknown_chunk_location @175 ++ png_get_unknown_chunks @176 ++ png_set_invalid @177 ++ png_read_png @178 ++ png_write_png @179 ++ png_get_copyright @180 ++ png_get_header_ver @181 ++ png_get_header_version @182 ++ png_get_libpng_ver @183 ++ png_permit_mng_features @184 ++ png_set_strip_error_numbers @185 ++ png_set_user_limits @186 ++ png_get_user_width_max @187 ++ png_get_user_height_max @188 ++ png_set_chunk_cache_max @189 ++ png_get_chunk_cache_max @190 ++ png_set_chunk_malloc_max @191 ++ png_get_chunk_malloc_max @192 ++ png_get_pixels_per_inch @193 ++ png_get_x_pixels_per_inch @194 ++ png_get_y_pixels_per_inch @195 ++ png_get_x_offset_inches @196 ++ png_get_y_offset_inches @197 ++ png_get_pHYs_dpi @198 ++ png_get_io_state @199 ++ png_get_uint_32 @201 ++ png_get_uint_16 @202 ++ png_get_int_32 @203 ++ png_get_uint_31 @204 ++ png_save_uint_32 @205 ++ png_save_int_32 @206 ++ png_save_uint_16 @207 ++ png_set_gamma_fixed @208 ++ png_set_filter_heuristics_fixed @209 ++ png_get_pixel_aspect_ratio_fixed @210 ++ png_get_x_offset_inches_fixed @211 ++ png_get_y_offset_inches_fixed @212 ++ png_set_sCAL_fixed @213 ++ png_get_sCAL_fixed @214 ++ png_set_background_fixed @215 ++ png_get_io_chunk_type @216 ++ png_get_current_row_number @217 ++ png_get_current_pass_number @218 ++ png_process_data_pause @219 ++ png_process_data_skip @220 ++ png_set_expand_16 @221 ++ png_set_text_compression_level @222 ++ png_set_text_compression_mem_level @223 ++ png_set_text_compression_strategy @224 ++ png_set_text_compression_window_bits @225 ++ png_set_text_compression_method @226 ++ png_set_alpha_mode @227 ++ png_set_alpha_mode_fixed @228 ++ png_set_scale_16 @229 ++ png_get_cHRM_XYZ @230 ++ png_get_cHRM_XYZ_fixed @231 ++ png_set_cHRM_XYZ @232 ++ png_set_cHRM_XYZ_fixed @233 ++ png_image_begin_read_from_file @234 ++ png_image_begin_read_from_stdio @235 ++ png_image_begin_read_from_memory @236 ++ png_image_finish_read @237 ++ png_image_free @238 ++ png_image_write_to_file @239 ++ png_image_write_to_stdio @240 ++ png_convert_to_rfc1123_buffer @241 ++ png_set_check_for_invalid_index @242 ++ png_get_palette_max @243 ++ png_set_option @244 ++ png_image_write_to_memory @245 ++ png_get_eXIf @246 ++ png_set_eXIf @247 ++ png_get_eXIf_1 @248 ++ png_set_eXIf_1 @249