mirror of
https://github.com/GRRLIB/GRRLIB.git
synced 2024-11-22 15:02:20 +00:00
[CHG] libpng updated to version 1.4.3
This commit is contained in:
parent
00c6b72867
commit
99d78c066f
9 changed files with 344 additions and 83 deletions
|
@ -37,7 +37,7 @@ THE SOFTWARE.
|
||||||
/**
|
/**
|
||||||
* Version information for GRRLIB.
|
* Version information for GRRLIB.
|
||||||
*/
|
*/
|
||||||
#define GRRLIB_VER_STRING "4.3.0"
|
#define GRRLIB_VER_STRING "4.3.1 BETA"
|
||||||
|
|
||||||
//==============================================================================
|
//==============================================================================
|
||||||
// Includes
|
// Includes
|
||||||
|
|
204
GRRLIB/lib/png/new_push_process_row.c
Normal file
204
GRRLIB/lib/png/new_push_process_row.c
Normal file
|
@ -0,0 +1,204 @@
|
||||||
|
void /* PRIVATE */
|
||||||
|
png_push_process_row(png_structp png_ptr)
|
||||||
|
{
|
||||||
|
png_ptr->row_info.color_type = png_ptr->color_type;
|
||||||
|
png_ptr->row_info.width = png_ptr->iwidth;
|
||||||
|
png_ptr->row_info.channels = png_ptr->channels;
|
||||||
|
png_ptr->row_info.bit_depth = png_ptr->bit_depth;
|
||||||
|
png_ptr->row_info.pixel_depth = png_ptr->pixel_depth;
|
||||||
|
|
||||||
|
png_ptr->row_info.rowbytes = PNG_ROWBYTES(png_ptr->row_info.pixel_depth,
|
||||||
|
png_ptr->row_info.width);
|
||||||
|
|
||||||
|
png_read_filter_row(png_ptr, &(png_ptr->row_info),
|
||||||
|
png_ptr->row_buf + 1, png_ptr->prev_row + 1,
|
||||||
|
(int)(png_ptr->row_buf[0]));
|
||||||
|
|
||||||
|
png_memcpy(png_ptr->prev_row, png_ptr->row_buf, png_ptr->rowbytes + 1);
|
||||||
|
|
||||||
|
if (png_ptr->transformations || (png_ptr->flags&PNG_FLAG_STRIP_ALPHA))
|
||||||
|
png_do_read_transformations(png_ptr);
|
||||||
|
|
||||||
|
#ifdef PNG_READ_INTERLACING_SUPPORTED
|
||||||
|
/* Blow up interlaced rows to full size */
|
||||||
|
if (png_ptr->interlaced && (png_ptr->transformations & PNG_INTERLACE))
|
||||||
|
{
|
||||||
|
if (png_ptr->pass < 6)
|
||||||
|
/* old interface (pre-1.0.9):
|
||||||
|
png_do_read_interlace(&(png_ptr->row_info),
|
||||||
|
png_ptr->row_buf + 1, png_ptr->pass, png_ptr->transformations);
|
||||||
|
*/
|
||||||
|
png_do_read_interlace(png_ptr);
|
||||||
|
|
||||||
|
switch (png_ptr->pass)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
for (i = 0; i < 8 && png_ptr->pass == 0; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, png_ptr->row_buf + 1);
|
||||||
|
png_read_push_finish_row(png_ptr); /* Updates png_ptr->pass */
|
||||||
|
}
|
||||||
|
|
||||||
|
if (png_ptr->pass == 2) /* Pass 1 might be empty */
|
||||||
|
{
|
||||||
|
for (i = 0; i < 4 && png_ptr->pass == 2; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, NULL);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (png_ptr->pass == 4 && png_ptr->height <= 4)
|
||||||
|
{
|
||||||
|
for (i = 0; i < 2 && png_ptr->pass == 4; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, NULL);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (png_ptr->pass == 6 && png_ptr->height <= 4)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, NULL);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case 1:
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
for (i = 0; i < 8 && png_ptr->pass == 1; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, png_ptr->row_buf + 1);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (png_ptr->pass == 2) /* Skip top 4 generated rows */
|
||||||
|
{
|
||||||
|
for (i = 0; i < 4 && png_ptr->pass == 2; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, NULL);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case 2:
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < 4 && png_ptr->pass == 2; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, png_ptr->row_buf + 1);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < 4 && png_ptr->pass == 2; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, NULL);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (png_ptr->pass == 4) /* Pass 3 might be empty */
|
||||||
|
{
|
||||||
|
for (i = 0; i < 2 && png_ptr->pass == 4; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, NULL);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case 3:
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < 4 && png_ptr->pass == 3; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, png_ptr->row_buf + 1);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (png_ptr->pass == 4) /* Skip top two generated rows */
|
||||||
|
{
|
||||||
|
for (i = 0; i < 2 && png_ptr->pass == 4; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, NULL);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case 4:
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < 2 && png_ptr->pass == 4; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, png_ptr->row_buf + 1);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < 2 && png_ptr->pass == 4; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, NULL);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (png_ptr->pass == 6) /* Pass 5 might be empty */
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, NULL);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case 5:
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < 2 && png_ptr->pass == 5; i++)
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, png_ptr->row_buf + 1);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (png_ptr->pass == 6) /* Skip top generated row */
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, NULL);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 6:
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, png_ptr->row_buf + 1);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
|
||||||
|
if (png_ptr->pass != 6)
|
||||||
|
break;
|
||||||
|
|
||||||
|
png_push_have_row(png_ptr, NULL);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
png_push_have_row(png_ptr, png_ptr->row_buf + 1);
|
||||||
|
png_read_push_finish_row(png_ptr);
|
||||||
|
}
|
||||||
|
}
|
|
@ -17,7 +17,7 @@
|
||||||
#include "pngpriv.h"
|
#include "pngpriv.h"
|
||||||
|
|
||||||
/* Generate a compiler error if there is an old png.h in the search path. */
|
/* Generate a compiler error if there is an old png.h in the search path. */
|
||||||
typedef version_1_4_2 Your_png_h_is_not_version_1_4_2;
|
typedef version_1_4_3 Your_png_h_is_not_version_1_4_3;
|
||||||
|
|
||||||
/* Version information for C files. This had better match the version
|
/* Version information for C files. This had better match the version
|
||||||
* string defined in png.h.
|
* string defined in png.h.
|
||||||
|
@ -551,13 +551,13 @@ png_get_copyright(png_structp png_ptr)
|
||||||
#else
|
#else
|
||||||
#ifdef __STDC__
|
#ifdef __STDC__
|
||||||
return ((png_charp) PNG_STRING_NEWLINE \
|
return ((png_charp) PNG_STRING_NEWLINE \
|
||||||
"libpng version 1.4.2 - May 6, 2010" PNG_STRING_NEWLINE \
|
"libpng version 1.4.3 - June 26, 2010" PNG_STRING_NEWLINE \
|
||||||
"Copyright (c) 1998-2010 Glenn Randers-Pehrson" PNG_STRING_NEWLINE \
|
"Copyright (c) 1998-2010 Glenn Randers-Pehrson" PNG_STRING_NEWLINE \
|
||||||
"Copyright (c) 1996-1997 Andreas Dilger" PNG_STRING_NEWLINE \
|
"Copyright (c) 1996-1997 Andreas Dilger" PNG_STRING_NEWLINE \
|
||||||
"Copyright (c) 1995-1996 Guy Eric Schalnat, Group 42, Inc." \
|
"Copyright (c) 1995-1996 Guy Eric Schalnat, Group 42, Inc." \
|
||||||
PNG_STRING_NEWLINE);
|
PNG_STRING_NEWLINE);
|
||||||
#else
|
#else
|
||||||
return ((png_charp) "libpng version 1.4.2 - May 6, 2010\
|
return ((png_charp) "libpng version 1.4.3 - June 26, 2010\
|
||||||
Copyright (c) 1998-2010 Glenn Randers-Pehrson\
|
Copyright (c) 1998-2010 Glenn Randers-Pehrson\
|
||||||
Copyright (c) 1996-1997 Andreas Dilger\
|
Copyright (c) 1996-1997 Andreas Dilger\
|
||||||
Copyright (c) 1995-1996 Guy Eric Schalnat, Group 42, Inc.");
|
Copyright (c) 1995-1996 Guy Eric Schalnat, Group 42, Inc.");
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
/* png.h - header file for PNG reference library
|
/* png.h - header file for PNG reference library
|
||||||
*
|
*
|
||||||
* libpng version 1.4.2 - May 6, 2010
|
* libpng version 1.4.3 - June 26, 2010
|
||||||
* Copyright (c) 1998-2010 Glenn Randers-Pehrson
|
* Copyright (c) 1998-2010 Glenn Randers-Pehrson
|
||||||
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
||||||
* (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
|
* (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
|
||||||
|
@ -11,7 +11,7 @@
|
||||||
* Authors and maintainers:
|
* Authors and maintainers:
|
||||||
* libpng versions 0.71, May 1995, through 0.88, January 1996: Guy Schalnat
|
* libpng versions 0.71, May 1995, through 0.88, January 1996: Guy Schalnat
|
||||||
* libpng versions 0.89c, June 1996, through 0.96, May 1997: Andreas Dilger
|
* libpng versions 0.89c, June 1996, through 0.96, May 1997: Andreas Dilger
|
||||||
* libpng versions 0.97, January 1998, through 1.4.2 - May 6, 2010: Glenn
|
* libpng versions 0.97, January 1998, through 1.4.3 - June 26, 2010: Glenn
|
||||||
* See also "Contributing Authors", below.
|
* See also "Contributing Authors", below.
|
||||||
*
|
*
|
||||||
* Note about libpng version numbers:
|
* Note about libpng version numbers:
|
||||||
|
@ -142,6 +142,9 @@
|
||||||
* 1.4.2beta01 14 10402 14.so.14.2[.0]
|
* 1.4.2beta01 14 10402 14.so.14.2[.0]
|
||||||
* 1.4.2rc02-06 14 10402 14.so.14.2[.0]
|
* 1.4.2rc02-06 14 10402 14.so.14.2[.0]
|
||||||
* 1.4.2 14 10402 14.so.14.2[.0]
|
* 1.4.2 14 10402 14.so.14.2[.0]
|
||||||
|
* 1.4.3beta01-05 14 10403 14.so.14.3[.0]
|
||||||
|
* 1.4.3rc01-03 14 10403 14.so.14.3[.0]
|
||||||
|
* 1.4.3 14 10403 14.so.14.3[.0]
|
||||||
*
|
*
|
||||||
* Henceforth the source version will match the shared-library major
|
* Henceforth the source version will match the shared-library major
|
||||||
* and minor numbers; the shared-library major version number will be
|
* and minor numbers; the shared-library major version number will be
|
||||||
|
@ -173,7 +176,7 @@
|
||||||
*
|
*
|
||||||
* This code is released under the libpng license.
|
* This code is released under the libpng license.
|
||||||
*
|
*
|
||||||
* libpng versions 1.2.6, August 15, 2004, through 1.4.2, May 6, 2010, are
|
* libpng versions 1.2.6, August 15, 2004, through 1.4.3, June 26, 2010, are
|
||||||
* Copyright (c) 2004, 2006-2010 Glenn Randers-Pehrson, and are
|
* Copyright (c) 2004, 2006-2010 Glenn Randers-Pehrson, and are
|
||||||
* distributed according to the same disclaimer and license as libpng-1.2.5
|
* distributed according to the same disclaimer and license as libpng-1.2.5
|
||||||
* with the following individual added to the list of Contributing Authors:
|
* with the following individual added to the list of Contributing Authors:
|
||||||
|
@ -285,13 +288,13 @@
|
||||||
* Y2K compliance in libpng:
|
* Y2K compliance in libpng:
|
||||||
* =========================
|
* =========================
|
||||||
*
|
*
|
||||||
* May 6, 2010
|
* June 26, 2010
|
||||||
*
|
*
|
||||||
* Since the PNG Development group is an ad-hoc body, we can't make
|
* Since the PNG Development group is an ad-hoc body, we can't make
|
||||||
* an official declaration.
|
* an official declaration.
|
||||||
*
|
*
|
||||||
* This is your unofficial assurance that libpng from version 0.71 and
|
* This is your unofficial assurance that libpng from version 0.71 and
|
||||||
* upward through 1.4.2 are Y2K compliant. It is my belief that earlier
|
* upward through 1.4.3 are Y2K compliant. It is my belief that earlier
|
||||||
* versions were also Y2K compliant.
|
* versions were also Y2K compliant.
|
||||||
*
|
*
|
||||||
* Libpng only has three year fields. One is a 2-byte unsigned integer
|
* Libpng only has three year fields. One is a 2-byte unsigned integer
|
||||||
|
@ -347,9 +350,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Version information for png.h - this should match the version in png.c */
|
/* Version information for png.h - this should match the version in png.c */
|
||||||
#define PNG_LIBPNG_VER_STRING "1.4.2"
|
#define PNG_LIBPNG_VER_STRING "1.4.3"
|
||||||
#define PNG_HEADER_VERSION_STRING \
|
#define PNG_HEADER_VERSION_STRING \
|
||||||
" libpng version 1.4.2 - May 6, 2010\n"
|
" libpng version 1.4.3 - June 26, 2010\n"
|
||||||
|
|
||||||
#define PNG_LIBPNG_VER_SONUM 14
|
#define PNG_LIBPNG_VER_SONUM 14
|
||||||
#define PNG_LIBPNG_VER_DLLNUM 14
|
#define PNG_LIBPNG_VER_DLLNUM 14
|
||||||
|
@ -357,7 +360,7 @@
|
||||||
/* These should match the first 3 components of PNG_LIBPNG_VER_STRING: */
|
/* These should match the first 3 components of PNG_LIBPNG_VER_STRING: */
|
||||||
#define PNG_LIBPNG_VER_MAJOR 1
|
#define PNG_LIBPNG_VER_MAJOR 1
|
||||||
#define PNG_LIBPNG_VER_MINOR 4
|
#define PNG_LIBPNG_VER_MINOR 4
|
||||||
#define PNG_LIBPNG_VER_RELEASE 2
|
#define PNG_LIBPNG_VER_RELEASE 3
|
||||||
/* This should match the numeric part of the final component of
|
/* This should match the numeric part of the final component of
|
||||||
* PNG_LIBPNG_VER_STRING, omitting any leading zero:
|
* PNG_LIBPNG_VER_STRING, omitting any leading zero:
|
||||||
*/
|
*/
|
||||||
|
@ -387,7 +390,7 @@
|
||||||
* version 1.0.0 was mis-numbered 100 instead of 10000). From
|
* version 1.0.0 was mis-numbered 100 instead of 10000). From
|
||||||
* version 1.0.1 it's xxyyzz, where x=major, y=minor, z=release
|
* version 1.0.1 it's xxyyzz, where x=major, y=minor, z=release
|
||||||
*/
|
*/
|
||||||
#define PNG_LIBPNG_VER 10402 /* 1.4.2 */
|
#define PNG_LIBPNG_VER 10403 /* 1.4.3 */
|
||||||
|
|
||||||
#ifndef PNG_VERSION_INFO_ONLY
|
#ifndef PNG_VERSION_INFO_ONLY
|
||||||
/* Include the compression library's header */
|
/* Include the compression library's header */
|
||||||
|
@ -1471,7 +1474,7 @@ struct png_struct_def
|
||||||
/* This triggers a compiler error in png.c, if png.c and png.h
|
/* This triggers a compiler error in png.c, if png.c and png.h
|
||||||
* do not agree upon the version number.
|
* do not agree upon the version number.
|
||||||
*/
|
*/
|
||||||
typedef png_structp version_1_4_2;
|
typedef png_structp version_1_4_3;
|
||||||
|
|
||||||
typedef png_struct FAR * FAR * png_structpp;
|
typedef png_struct FAR * FAR * png_structpp;
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
/* pngconf.h - machine configurable file for libpng
|
/* pngconf.h - machine configurable file for libpng
|
||||||
*
|
*
|
||||||
* libpng version 1.4.2 - May 6, 2010
|
* libpng version 1.4.3 - June 26, 2010
|
||||||
* For conditions of distribution and use, see copyright notice in png.h
|
* For conditions of distribution and use, see copyright notice in png.h
|
||||||
* Copyright (c) 1998-2010 Glenn Randers-Pehrson
|
* Copyright (c) 1998-2010 Glenn Randers-Pehrson
|
||||||
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
/* pngpread.c - read a png file in push mode
|
/* pngpread.c - read a png file in push mode
|
||||||
*
|
*
|
||||||
* Last changed in libpng 1.4.1 [February 25, 2010]
|
* Last changed in libpng 1.4.3 [June 26, 2010]
|
||||||
* Copyright (c) 1998-2010 Glenn Randers-Pehrson
|
* Copyright (c) 1998-2010 Glenn Randers-Pehrson
|
||||||
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
||||||
* (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
|
* (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
|
||||||
|
@ -779,7 +779,6 @@ png_push_read_IDAT(png_structp png_ptr)
|
||||||
|
|
||||||
png_calculate_crc(png_ptr, png_ptr->save_buffer_ptr, save_size);
|
png_calculate_crc(png_ptr, png_ptr->save_buffer_ptr, save_size);
|
||||||
|
|
||||||
if (!(png_ptr->flags & PNG_FLAG_ZLIB_FINISHED))
|
|
||||||
png_process_IDAT_data(png_ptr, png_ptr->save_buffer_ptr, save_size);
|
png_process_IDAT_data(png_ptr, png_ptr->save_buffer_ptr, save_size);
|
||||||
|
|
||||||
png_ptr->idat_size -= save_size;
|
png_ptr->idat_size -= save_size;
|
||||||
|
@ -803,7 +802,7 @@ png_push_read_IDAT(png_structp png_ptr)
|
||||||
save_size = png_ptr->current_buffer_size;
|
save_size = png_ptr->current_buffer_size;
|
||||||
|
|
||||||
png_calculate_crc(png_ptr, png_ptr->current_buffer_ptr, save_size);
|
png_calculate_crc(png_ptr, png_ptr->current_buffer_ptr, save_size);
|
||||||
if (!(png_ptr->flags & PNG_FLAG_ZLIB_FINISHED))
|
|
||||||
png_process_IDAT_data(png_ptr, png_ptr->current_buffer_ptr, save_size);
|
png_process_IDAT_data(png_ptr, png_ptr->current_buffer_ptr, save_size);
|
||||||
|
|
||||||
png_ptr->idat_size -= save_size;
|
png_ptr->idat_size -= save_size;
|
||||||
|
@ -829,62 +828,101 @@ void /* PRIVATE */
|
||||||
png_process_IDAT_data(png_structp png_ptr, png_bytep buffer,
|
png_process_IDAT_data(png_structp png_ptr, png_bytep buffer,
|
||||||
png_size_t buffer_length)
|
png_size_t buffer_length)
|
||||||
{
|
{
|
||||||
int ret;
|
/* The caller checks for a non-zero buffer length. */
|
||||||
|
if (!(buffer_length > 0) || buffer == NULL)
|
||||||
if ((png_ptr->flags & PNG_FLAG_ZLIB_FINISHED) && buffer_length)
|
png_error(png_ptr, "No IDAT data (internal error)");
|
||||||
png_benign_error(png_ptr, "Extra compression data");
|
|
||||||
|
|
||||||
|
/* This routine must process all the data it has been given
|
||||||
|
* before returning, calling the row callback as required to
|
||||||
|
* handle the uncompressed results.
|
||||||
|
*/
|
||||||
png_ptr->zstream.next_in = buffer;
|
png_ptr->zstream.next_in = buffer;
|
||||||
png_ptr->zstream.avail_in = (uInt)buffer_length;
|
png_ptr->zstream.avail_in = (uInt)buffer_length;
|
||||||
for (;;)
|
|
||||||
{
|
|
||||||
ret = inflate(&png_ptr->zstream, Z_PARTIAL_FLUSH);
|
|
||||||
if (ret != Z_OK)
|
|
||||||
{
|
|
||||||
if (ret == Z_STREAM_END)
|
|
||||||
{
|
|
||||||
if (png_ptr->zstream.avail_in)
|
|
||||||
png_benign_error(png_ptr, "Extra compressed data");
|
|
||||||
|
|
||||||
if (!(png_ptr->zstream.avail_out))
|
/* Keep going until the decompressed data is all processed
|
||||||
|
* or the stream marked as finished.
|
||||||
|
*/
|
||||||
|
while (png_ptr->zstream.avail_in > 0 &&
|
||||||
|
!(png_ptr->flags & PNG_FLAG_ZLIB_FINISHED))
|
||||||
{
|
{
|
||||||
png_push_process_row(png_ptr);
|
int ret;
|
||||||
}
|
|
||||||
|
|
||||||
png_ptr->mode |= PNG_AFTER_IDAT;
|
/* We have data for zlib, but we must check that zlib
|
||||||
png_ptr->flags |= PNG_FLAG_ZLIB_FINISHED;
|
* has somewhere to put the results. It doesn't matter
|
||||||
break;
|
* if we don't expect any results -- it may be the input
|
||||||
}
|
* data is just the LZ end code.
|
||||||
else if (ret == Z_BUF_ERROR)
|
*/
|
||||||
break;
|
if (!(png_ptr->zstream.avail_out > 0))
|
||||||
|
|
||||||
else
|
|
||||||
png_error(png_ptr, "Decompression Error");
|
|
||||||
}
|
|
||||||
if (!(png_ptr->zstream.avail_out))
|
|
||||||
{
|
{
|
||||||
if ((
|
|
||||||
#ifdef PNG_READ_INTERLACING_SUPPORTED
|
|
||||||
png_ptr->interlaced && png_ptr->pass > 6) ||
|
|
||||||
(!png_ptr->interlaced &&
|
|
||||||
#endif
|
|
||||||
png_ptr->row_number == png_ptr->num_rows))
|
|
||||||
{
|
|
||||||
if (png_ptr->zstream.avail_in)
|
|
||||||
png_warning(png_ptr, "Too much data in IDAT chunks");
|
|
||||||
png_ptr->flags |= PNG_FLAG_ZLIB_FINISHED;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
png_push_process_row(png_ptr);
|
|
||||||
png_ptr->zstream.avail_out =
|
png_ptr->zstream.avail_out =
|
||||||
(uInt) PNG_ROWBYTES(png_ptr->pixel_depth,
|
(uInt) PNG_ROWBYTES(png_ptr->pixel_depth,
|
||||||
png_ptr->iwidth) + 1;
|
png_ptr->iwidth) + 1;
|
||||||
png_ptr->zstream.next_out = png_ptr->row_buf;
|
png_ptr->zstream.next_out = png_ptr->row_buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Using Z_SYNC_FLUSH here means that an unterminated
|
||||||
|
* LZ stream can still be handled (a stream with a missing
|
||||||
|
* end code), otherwise (Z_NO_FLUSH) a future zlib
|
||||||
|
* implementation might defer output and, therefore,
|
||||||
|
* change the current behavior. (See comments in inflate.c
|
||||||
|
* for why this doesn't happen at present with zlib 1.2.5.)
|
||||||
|
*/
|
||||||
|
ret = inflate(&png_ptr->zstream, Z_SYNC_FLUSH);
|
||||||
|
|
||||||
|
/* Check for any failure before proceeding. */
|
||||||
|
if (ret != Z_OK && ret != Z_STREAM_END)
|
||||||
|
{
|
||||||
|
/* Terminate the decompression. */
|
||||||
|
png_ptr->flags |= PNG_FLAG_ZLIB_FINISHED;
|
||||||
|
|
||||||
|
/* This may be a truncated stream (missing or
|
||||||
|
* damaged end code). Treat that as a warning.
|
||||||
|
*/
|
||||||
|
if (png_ptr->row_number >= png_ptr->num_rows ||
|
||||||
|
png_ptr->pass > 6)
|
||||||
|
png_warning(png_ptr, "Truncated compressed data in IDAT");
|
||||||
else
|
else
|
||||||
break;
|
png_error(png_ptr, "Decompression error in IDAT");
|
||||||
|
|
||||||
|
/* Skip the check on unprocessed input */
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Did inflate output any data? */
|
||||||
|
if (png_ptr->zstream.next_out != png_ptr->row_buf)
|
||||||
|
{
|
||||||
|
/* Is this unexpected data after the last row?
|
||||||
|
* If it is, artificially terminate the LZ output
|
||||||
|
* here.
|
||||||
|
*/
|
||||||
|
if (png_ptr->row_number >= png_ptr->num_rows ||
|
||||||
|
png_ptr->pass > 6)
|
||||||
|
{
|
||||||
|
/* Extra data. */
|
||||||
|
png_warning(png_ptr, "Extra compressed data in IDAT");
|
||||||
|
png_ptr->flags |= PNG_FLAG_ZLIB_FINISHED;
|
||||||
|
/* Do no more processing; skip the unprocessed
|
||||||
|
* input check below.
|
||||||
|
*/
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Do we have a complete row? */
|
||||||
|
if (png_ptr->zstream.avail_out == 0)
|
||||||
|
png_push_process_row(png_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* And check for the end of the stream. */
|
||||||
|
if (ret == Z_STREAM_END)
|
||||||
|
png_ptr->flags |= PNG_FLAG_ZLIB_FINISHED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* All the data should have been processed, if anything
|
||||||
|
* is left at this point we have bytes of IDAT data
|
||||||
|
* after the zlib end code.
|
||||||
|
*/
|
||||||
|
if (png_ptr->zstream.avail_in > 0)
|
||||||
|
png_warning(png_ptr, "Extra compression data");
|
||||||
}
|
}
|
||||||
|
|
||||||
void /* PRIVATE */
|
void /* PRIVATE */
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
/* pngpriv.h - private declarations for use inside libpng
|
/* pngpriv.h - private declarations for use inside libpng
|
||||||
*
|
*
|
||||||
* libpng version 1.4.2 - May 6, 2010
|
* libpng version 1.4.3 - June 26, 2010
|
||||||
* For conditions of distribution and use, see copyright notice in png.h
|
* For conditions of distribution and use, see copyright notice in png.h
|
||||||
* Copyright (c) 1998-2010 Glenn Randers-Pehrson
|
* Copyright (c) 1998-2010 Glenn Randers-Pehrson
|
||||||
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
/* pngrutil.c - utilities to read a PNG file
|
/* pngrutil.c - utilities to read a PNG file
|
||||||
*
|
*
|
||||||
* Last changed in libpng 1.4.1 [February 25, 2010]
|
* Last changed in libpng 1.4.3 [June 26, 2010]
|
||||||
* Copyright (c) 1998-2010 Glenn Randers-Pehrson
|
* Copyright (c) 1998-2010 Glenn Randers-Pehrson
|
||||||
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
* (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
|
||||||
* (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
|
* (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
|
||||||
|
@ -254,7 +254,7 @@ png_inflate(png_structp png_ptr, const png_byte *data, png_size_t size,
|
||||||
* buffer if available.
|
* buffer if available.
|
||||||
*/
|
*/
|
||||||
{
|
{
|
||||||
char *msg;
|
PNG_CONST char *msg;
|
||||||
if (png_ptr->zstream.msg != 0)
|
if (png_ptr->zstream.msg != 0)
|
||||||
msg = png_ptr->zstream.msg;
|
msg = png_ptr->zstream.msg;
|
||||||
else
|
else
|
||||||
|
@ -326,8 +326,10 @@ png_decompress_chunk(png_structp png_ptr, int comp_type,
|
||||||
if (png_ptr->user_chunk_malloc_max &&
|
if (png_ptr->user_chunk_malloc_max &&
|
||||||
(prefix_size + expanded_size >= png_ptr->user_chunk_malloc_max - 1))
|
(prefix_size + expanded_size >= png_ptr->user_chunk_malloc_max - 1))
|
||||||
#else
|
#else
|
||||||
|
# ifdef PNG_USER_CHUNK_MALLOC_MAX
|
||||||
if ((PNG_USER_CHUNK_MALLOC_MAX > 0) &&
|
if ((PNG_USER_CHUNK_MALLOC_MAX > 0) &&
|
||||||
prefix_size + expanded_size >= PNG_USER_CHUNK_MALLOC_MAX - 1)
|
prefix_size + expanded_size >= PNG_USER_CHUNK_MALLOC_MAX - 1)
|
||||||
|
# endif
|
||||||
#endif
|
#endif
|
||||||
png_warning(png_ptr, "Exceeded size limit while expanding chunk");
|
png_warning(png_ptr, "Exceeded size limit while expanding chunk");
|
||||||
|
|
||||||
|
@ -1811,6 +1813,7 @@ png_handle_sCAL(png_structp png_ptr, png_infop info_ptr, png_uint_32 length)
|
||||||
if (png_ptr->chunkdata == NULL)
|
if (png_ptr->chunkdata == NULL)
|
||||||
{
|
{
|
||||||
png_warning(png_ptr, "Out of memory while processing sCAL chunk");
|
png_warning(png_ptr, "Out of memory while processing sCAL chunk");
|
||||||
|
png_crc_finish(png_ptr, length);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
slength = (png_size_t)length;
|
slength = (png_size_t)length;
|
||||||
|
@ -1832,6 +1835,8 @@ png_handle_sCAL(png_structp png_ptr, png_infop info_ptr, png_uint_32 length)
|
||||||
if (*vp)
|
if (*vp)
|
||||||
{
|
{
|
||||||
png_warning(png_ptr, "malformed width string in sCAL chunk");
|
png_warning(png_ptr, "malformed width string in sCAL chunk");
|
||||||
|
png_free(png_ptr, png_ptr->chunkdata);
|
||||||
|
png_ptr->chunkdata = NULL;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
@ -1840,6 +1845,8 @@ png_handle_sCAL(png_structp png_ptr, png_infop info_ptr, png_uint_32 length)
|
||||||
if (swidth == NULL)
|
if (swidth == NULL)
|
||||||
{
|
{
|
||||||
png_warning(png_ptr, "Out of memory while processing sCAL chunk width");
|
png_warning(png_ptr, "Out of memory while processing sCAL chunk width");
|
||||||
|
png_free(png_ptr, png_ptr->chunkdata);
|
||||||
|
png_ptr->chunkdata = NULL;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
png_memcpy(swidth, ep, png_strlen(ep));
|
png_memcpy(swidth, ep, png_strlen(ep));
|
||||||
|
@ -1853,8 +1860,7 @@ png_handle_sCAL(png_structp png_ptr, png_infop info_ptr, png_uint_32 length)
|
||||||
if (png_ptr->chunkdata + slength < ep)
|
if (png_ptr->chunkdata + slength < ep)
|
||||||
{
|
{
|
||||||
png_warning(png_ptr, "Truncated sCAL chunk");
|
png_warning(png_ptr, "Truncated sCAL chunk");
|
||||||
#if defined(PNG_FIXED_POINT_SUPPORTED) && \
|
#if defined(PNG_FIXED_POINT_SUPPORTED) && !defined(PNG_FLOATING_POINT_SUPPORTED)
|
||||||
!defined(PNG_FLOATING_POINT_SUPPORTED)
|
|
||||||
png_free(png_ptr, swidth);
|
png_free(png_ptr, swidth);
|
||||||
#endif
|
#endif
|
||||||
png_free(png_ptr, png_ptr->chunkdata);
|
png_free(png_ptr, png_ptr->chunkdata);
|
||||||
|
@ -1867,6 +1873,11 @@ png_handle_sCAL(png_structp png_ptr, png_infop info_ptr, png_uint_32 length)
|
||||||
if (*vp)
|
if (*vp)
|
||||||
{
|
{
|
||||||
png_warning(png_ptr, "malformed height string in sCAL chunk");
|
png_warning(png_ptr, "malformed height string in sCAL chunk");
|
||||||
|
png_free(png_ptr, png_ptr->chunkdata);
|
||||||
|
png_ptr->chunkdata = NULL;
|
||||||
|
#if defined(PNG_FIXED_POINT_SUPPORTED) && !defined(PNG_FLOATING_POINT_SUPPORTED)
|
||||||
|
png_free(png_ptr, swidth);
|
||||||
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
@ -1875,6 +1886,11 @@ png_handle_sCAL(png_structp png_ptr, png_infop info_ptr, png_uint_32 length)
|
||||||
if (sheight == NULL)
|
if (sheight == NULL)
|
||||||
{
|
{
|
||||||
png_warning(png_ptr, "Out of memory while processing sCAL chunk height");
|
png_warning(png_ptr, "Out of memory while processing sCAL chunk height");
|
||||||
|
png_free(png_ptr, png_ptr->chunkdata);
|
||||||
|
png_ptr->chunkdata = NULL;
|
||||||
|
#if defined(PNG_FIXED_POINT_SUPPORTED) && !defined(PNG_FLOATING_POINT_SUPPORTED)
|
||||||
|
png_free(png_ptr, swidth);
|
||||||
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
png_memcpy(sheight, ep, png_strlen(ep));
|
png_memcpy(sheight, ep, png_strlen(ep));
|
||||||
|
|
Loading…
Reference in a new issue