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