/*
We don't put pragma implement in this file because it is already present in
src/common/image.cpp
-
-#ifdef __GNUG__
-#pragma implementation "image.h"
-#endif
*/
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#ifdef __BORLANDC__
-#pragma hdrstop
+ #pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+ #include "wx/defs.h"
#endif
+#if wxUSE_LIBPNG
+
#include "wx/image.h"
#include "wx/bitmap.h"
#include "wx/debug.h"
#include "wx/log.h"
#include "wx/app.h"
-#if wxUSE_LIBPNG
-#include "../png/png.h"
-#endif
+#include "png.h"
#include "wx/filefn.h"
#include "wx/wfstream.h"
#include "wx/intl.h"
// wxPNGHandler
//-----------------------------------------------------------------------------
-#if wxUSE_LIBPNG
-
#if !USE_SHARED_LIBRARIES
IMPLEMENT_DYNAMIC_CLASS(wxPNGHandler,wxImageHandler)
#endif
-
#if wxUSE_STREAMS
+
static void _PNG_stream_reader( png_structp png_ptr, png_bytep data, png_size_t length )
{
((wxInputStream*) png_get_io_ptr( png_ptr )) -> Read(data, length);
// VZ: as this function uses setjmp() the only fool proof error handling
// method is to use goto (setjmp is not really C++ dtors friendly...)
- unsigned char **lines = (unsigned char **) NULL;
+ unsigned char **lines;
unsigned int i;
png_infop info_ptr = (png_infop) NULL;
(png_error_ptr) NULL,
(png_error_ptr) NULL );
if (!png_ptr)
- goto error;
+ goto error_nolines;
info_ptr = png_create_info_struct( png_ptr );
if (!info_ptr)
- goto error;
+ goto error_nolines;
if (setjmp(png_ptr->jmpbuf))
- goto error;
+ goto error_nolines;
if (info_ptr->color_type == PNG_COLOR_TYPE_RGB_ALPHA)
- goto error;
+ goto error_nolines;
png_set_read_fn( png_ptr, &stream, _PNG_stream_reader);
image->Create( width, height );
if (!image->Ok())
- goto error;
+ goto error_nolines;
lines = (unsigned char **)malloc( height * sizeof(unsigned char *) );
if (lines == NULL)
- goto error;
+ goto error_nolines;
for (i = 0; i < height; i++)
{
}
return TRUE;
-
-error:
+
+ error_nolines:
+ lines = NULL; // called from before it was set
+ error:
wxLogError(_("Couldn't load a PNG image - probably file is corrupted."));
if ( image->Ok() )
}
return TRUE;
}
-#endif // wxUSE_STREAMS
-#endif
+#endif
+ // wxUSE_STREAMS
-// wxUSE_LIBPNG
+#endif
+ // wxUSE_LIBPNG