1 | |
2 | /* pngdebug.h - Debugging macros for libpng, also used in pngtest.c |
3 | * |
4 | * Copyright (c) 2018 Cosmin Truta |
5 | * Copyright (c) 1998-2002,2004,2006-2013 Glenn Randers-Pehrson |
6 | * Copyright (c) 1996-1997 Andreas Dilger |
7 | * Copyright (c) 1995-1996 Guy Eric Schalnat, Group 42, Inc. |
8 | * |
9 | * This code is released under the libpng license. |
10 | * For conditions of distribution and use, see the disclaimer |
11 | * and license in png.h |
12 | */ |
13 | |
14 | /* Define PNG_DEBUG at compile time for debugging information. Higher |
15 | * numbers for PNG_DEBUG mean more debugging information. This has |
16 | * only been added since version 0.95 so it is not implemented throughout |
17 | * libpng yet, but more support will be added as needed. |
18 | * |
19 | * png_debug[1-2]?(level, message ,arg{0-2}) |
20 | * Expands to a statement (either a simple expression or a compound |
21 | * do..while(0) statement) that outputs a message with parameter |
22 | * substitution if PNG_DEBUG is defined to 2 or more. If PNG_DEBUG |
23 | * is undefined, 0 or 1 every png_debug expands to a simple expression |
24 | * (actually ((void)0)). |
25 | * |
26 | * level: level of detail of message, starting at 0. A level 'n' |
27 | * message is preceded by 'n' 3-space indentations (not implemented |
28 | * on Microsoft compilers unless PNG_DEBUG_FILE is also |
29 | * defined, to allow debug DLL compilation with no standard IO). |
30 | * message: a printf(3) style text string. A trailing '\n' is added |
31 | * to the message. |
32 | * arg: 0 to 2 arguments for printf(3) style substitution in message. |
33 | */ |
34 | #ifndef PNGDEBUG_H |
35 | #define PNGDEBUG_H |
36 | /* These settings control the formatting of messages in png.c and pngerror.c */ |
37 | /* Moved to pngdebug.h at 1.5.0 */ |
38 | # ifndef PNG_LITERAL_SHARP |
39 | # define PNG_LITERAL_SHARP 0x23 |
40 | # endif |
41 | # ifndef PNG_LITERAL_LEFT_SQUARE_BRACKET |
42 | # define PNG_LITERAL_LEFT_SQUARE_BRACKET 0x5b |
43 | # endif |
44 | # ifndef PNG_LITERAL_RIGHT_SQUARE_BRACKET |
45 | # define PNG_LITERAL_RIGHT_SQUARE_BRACKET 0x5d |
46 | # endif |
47 | # ifndef PNG_STRING_NEWLINE |
48 | # define PNG_STRING_NEWLINE "\n" |
49 | # endif |
50 | |
51 | #ifdef PNG_DEBUG |
52 | # if (PNG_DEBUG > 0) |
53 | # if !defined(PNG_DEBUG_FILE) && defined(_MSC_VER) |
54 | # include <crtdbg.h> |
55 | # if (PNG_DEBUG > 1) |
56 | # ifndef _DEBUG |
57 | # define _DEBUG |
58 | # endif |
59 | # ifndef png_debug |
60 | # define png_debug(l,m) _RPT0(_CRT_WARN,m PNG_STRING_NEWLINE) |
61 | # endif |
62 | # ifndef png_debug1 |
63 | # define png_debug1(l,m,p1) _RPT1(_CRT_WARN,m PNG_STRING_NEWLINE,p1) |
64 | # endif |
65 | # ifndef png_debug2 |
66 | # define png_debug2(l,m,p1,p2) \ |
67 | _RPT2(_CRT_WARN,m PNG_STRING_NEWLINE,p1,p2) |
68 | # endif |
69 | # endif |
70 | # else /* PNG_DEBUG_FILE || !_MSC_VER */ |
71 | # ifndef PNG_STDIO_SUPPORTED |
72 | # include <stdio.h> /* not included yet */ |
73 | # endif |
74 | # ifndef PNG_DEBUG_FILE |
75 | # define PNG_DEBUG_FILE stderr |
76 | # endif /* PNG_DEBUG_FILE */ |
77 | |
78 | # if (PNG_DEBUG > 1) |
79 | # ifdef __STDC__ |
80 | # ifndef png_debug |
81 | # define png_debug(l,m) \ |
82 | do { \ |
83 | int num_tabs=l; \ |
84 | fprintf(PNG_DEBUG_FILE,"%s" m PNG_STRING_NEWLINE,(num_tabs==1 ? " " : \ |
85 | (num_tabs==2 ? " " : (num_tabs>2 ? " " : "")))); \ |
86 | } while (0) |
87 | # endif |
88 | # ifndef png_debug1 |
89 | # define png_debug1(l,m,p1) \ |
90 | do { \ |
91 | int num_tabs=l; \ |
92 | fprintf(PNG_DEBUG_FILE,"%s" m PNG_STRING_NEWLINE,(num_tabs==1 ? " " : \ |
93 | (num_tabs==2 ? " " : (num_tabs>2 ? " " : ""))),p1); \ |
94 | } while (0) |
95 | # endif |
96 | # ifndef png_debug2 |
97 | # define png_debug2(l,m,p1,p2) \ |
98 | do { \ |
99 | int num_tabs=l; \ |
100 | fprintf(PNG_DEBUG_FILE,"%s" m PNG_STRING_NEWLINE,(num_tabs==1 ? " " : \ |
101 | (num_tabs==2 ? " " : (num_tabs>2 ? " " : ""))),p1,p2);\ |
102 | } while (0) |
103 | # endif |
104 | # else /* __STDC __ */ |
105 | # ifndef png_debug |
106 | # define png_debug(l,m) \ |
107 | do { \ |
108 | int num_tabs=l; \ |
109 | char format[256]; \ |
110 | snprintf(format,256,"%s%s%s",(num_tabs==1 ? "\t" : \ |
111 | (num_tabs==2 ? "\t\t":(num_tabs>2 ? "\t\t\t":""))), \ |
112 | m,PNG_STRING_NEWLINE); \ |
113 | fprintf(PNG_DEBUG_FILE,format); \ |
114 | } while (0) |
115 | # endif |
116 | # ifndef png_debug1 |
117 | # define png_debug1(l,m,p1) \ |
118 | do { \ |
119 | int num_tabs=l; \ |
120 | char format[256]; \ |
121 | snprintf(format,256,"%s%s%s",(num_tabs==1 ? "\t" : \ |
122 | (num_tabs==2 ? "\t\t":(num_tabs>2 ? "\t\t\t":""))), \ |
123 | m,PNG_STRING_NEWLINE); \ |
124 | fprintf(PNG_DEBUG_FILE,format,p1); \ |
125 | } while (0) |
126 | # endif |
127 | # ifndef png_debug2 |
128 | # define png_debug2(l,m,p1,p2) \ |
129 | do { \ |
130 | int num_tabs=l; \ |
131 | char format[256]; \ |
132 | snprintf(format,256,"%s%s%s",(num_tabs==1 ? "\t" : \ |
133 | (num_tabs==2 ? "\t\t":(num_tabs>2 ? "\t\t\t":""))), \ |
134 | m,PNG_STRING_NEWLINE); \ |
135 | fprintf(PNG_DEBUG_FILE,format,p1,p2); \ |
136 | } while (0) |
137 | # endif |
138 | # endif /* __STDC __ */ |
139 | # endif /* (PNG_DEBUG > 1) */ |
140 | |
141 | # endif /* _MSC_VER */ |
142 | # endif /* (PNG_DEBUG > 0) */ |
143 | #endif /* PNG_DEBUG */ |
144 | #ifndef png_debug |
145 | # define png_debug(l, m) ((void)0) |
146 | #endif |
147 | #ifndef png_debug1 |
148 | # define png_debug1(l, m, p1) ((void)0) |
149 | #endif |
150 | #ifndef png_debug2 |
151 | # define png_debug2(l, m, p1, p2) ((void)0) |
152 | #endif |
153 | #endif /* PNGDEBUG_H */ |
154 | |