]>
git.saurik.com Git - wxWidgets.git/blob - src/png/pngerror.c
2 /* pngerror.c - stub functions for i/o and memory allocation
5 * For conditions of distribution and use, see copyright notice in png.h
6 * Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.
7 * Copyright (c) 1996, 1997 Andreas Dilger
8 * Copyright (c) 1998, Glenn Randers-Pehrson
11 * This file provides a location for all error handling. Users which
12 * need special error handling are expected to write replacement functions
13 * and use png_set_error_fn() to use those functions. See the instructions
18 #include "../png/png.h"
20 static void png_default_error
PNGARG((png_structp png_ptr
,
21 png_const_charp message
));
22 static void png_default_warning
PNGARG((png_structp png_ptr
,
23 png_const_charp message
));
25 /* This function is called whenever there is a fatal error. This function
26 * should not be changed. If there is a need to handle errors differently,
27 * you should supply a replacement error function and use png_set_error_fn()
28 * to replace the error function at run-time.
31 png_error(png_structp png_ptr
, png_const_charp message
)
33 if (png_ptr
->error_fn
!= NULL
)
34 (*(png_ptr
->error_fn
))(png_ptr
, message
);
36 /* if the following returns or doesn't exist, use the default function,
37 which will not return */
38 png_default_error(png_ptr
, message
);
41 /* This function is called whenever there is a non-fatal error. This function
42 * should not be changed. If there is a need to handle warnings differently,
43 * you should supply a replacement warning function and use
44 * png_set_error_fn() to replace the warning function at run-time.
47 png_warning(png_structp png_ptr
, png_const_charp message
)
49 if (png_ptr
->warning_fn
!= NULL
)
50 (*(png_ptr
->warning_fn
))(png_ptr
, message
);
52 png_default_warning(png_ptr
, message
);
55 /* These utilities are used internally to build an error message which relates
56 * to the current chunk. The chunk name comes from png_ptr->chunk_name,
57 * this is used to prefix the message. The message is limited in length
58 * to 63 bytes, the name characters are output as hex digits wrapped in []
59 * if the character is invalid.
61 #define isnonalpha(c) ((c) < 41 || (c) > 122 || ((c) > 90 && (c) < 97))
62 static PNG_CONST
char png_digit
[16] = {
63 '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'
67 png_format_buffer(png_structp png_ptr
, png_charp buffer
, png_const_charp message
)
69 int iout
= 0, iin
= 0;
72 int c
= png_ptr
->chunk_name
[iin
++];
75 buffer
[iout
++] = png_digit
[(c
& 0xf0) >> 4];
76 buffer
[iout
++] = png_digit
[c
& 0xf];
88 png_memcpy(buffer
+iout
, message
, 64);
94 png_chunk_error(png_structp png_ptr
, png_const_charp message
)
97 png_format_buffer(png_ptr
, msg
, message
);
98 png_error(png_ptr
, msg
);
102 png_chunk_warning(png_structp png_ptr
, png_const_charp message
)
105 png_format_buffer(png_ptr
, msg
, message
);
106 png_warning(png_ptr
, msg
);
109 /* This is the default error handling function. Note that replacements for
110 * this function MUST NOT RETURN, or the program will likely crash. This
111 * function is used by default, or if the program supplies NULL for the
112 * error function pointer in png_set_error_fn().
115 png_default_error(png_structp png_ptr
, png_const_charp message
)
118 fprintf(stderr
, "libpng error: %s\n", message
);
121 #ifdef USE_FAR_KEYWORD
124 png_memcpy(jmpbuf
,png_ptr
->jmpbuf
,sizeof(jmp_buf));
128 longjmp(png_ptr
->jmpbuf
, 1);
132 /* This function is called when there is a warning, but the library thinks
133 * it can continue anyway. Replacement functions don't have to do anything
134 * here if you don't want to. In the default configuration, png_ptr is
135 * not used, but it is passed in case it may be useful.
138 png_default_warning(png_structp png_ptr
, png_const_charp message
)
144 fprintf(stderr
, "libpng warning: %s\n", message
);
148 /* This function is called when the application wants to use another method
149 * of handling errors and warnings. Note that the error function MUST NOT
150 * return to the calling routine or serious problems will occur. The return
151 * method used in the default routine calls longjmp(png_ptr->jmpbuf, 1)
154 png_set_error_fn(png_structp png_ptr
, png_voidp error_ptr
,
155 png_error_ptr error_fn
, png_error_ptr warning_fn
)
157 png_ptr
->error_ptr
= error_ptr
;
158 png_ptr
->error_fn
= error_fn
;
159 png_ptr
->warning_fn
= warning_fn
;
163 /* This function returns a pointer to the error_ptr associated with the user
164 * functions. The application should free any memory associated with this
165 * pointer before png_write_destroy and png_read_destroy are called.
168 png_get_error_ptr(png_structp png_ptr
)
170 return ((png_voidp
)png_ptr
->error_ptr
);