pngconf.h 44.6 KB
Newer Older
1

2
/* pngconf.h - machine configurable file for libpng
3
 *
4
 * libpng version 1.5.0beta17 - April 1, 2010
5
 *
6
 * Copyright (c) 1998-2010 Glenn Randers-Pehrson
7 8
 * (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
 * (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
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
 */
G
Guy Schalnat 已提交
15 16

/* Any machine specific code is near the front of this file, so if you
17 18 19 20
 * are configuring libpng for a machine, you may want to read the section
 * starting here down to where it starts to typedef png_color, png_text,
 * and png_info.
 */
G
Guy Schalnat 已提交
21 22 23 24

#ifndef PNGCONF_H
#define PNGCONF_H

25
#ifndef PNG_NO_LIMITS_H
26
#  include <limits.h>
27 28
#endif

29 30
/*
 * Added at libpng-1.2.8
31
 *
32 33 34 35 36 37 38
 * PNG_USER_CONFIG has to be defined on the compiler command line. This
 * includes the resource compiler for Windows DLL configurations.
 */
#ifdef PNG_USER_CONFIG
#  ifndef PNG_USER_PRIVATEBUILD
#    define PNG_USER_PRIVATEBUILD
#  endif
39
#  include "pngusr.h"
40 41
#endif

42
/*
43 44 45 46 47 48 49 50 51 52
 * If you create a private DLL you need to define in "pngusr.h" the followings:
 * #define PNG_USER_PRIVATEBUILD <Describes by whom and why this version of
 *        the DLL was built>
 *  e.g. #define PNG_USER_PRIVATEBUILD "Build by MyCompany for xyz reasons."
 * #define PNG_USER_DLLFNAME_POSTFIX <two-letter postfix that serve to
 *        distinguish your DLL from those of the official release. These
 *        correspond to the trailing letters that come after the version
 *        number and must match your private DLL name>
 *  e.g. // private DLL "libpng13gx.dll"
 *       #define PNG_USER_DLLFNAME_POSTFIX "gx"
53 54
 *
 * The following macros are also at your disposal if you want to complete the
55 56 57 58 59 60 61
 * DLL VERSIONINFO structure.
 * - PNG_USER_VERSIONINFO_COMMENTS
 * - PNG_USER_VERSIONINFO_COMPANYNAME
 * - PNG_USER_VERSIONINFO_LEGALTRADEMARKS
 */

#ifdef __STDC__
62
#  ifdef SPECIALBUILD
63 64
#    pragma message("PNG_LIBPNG_SPECIALBUILD (and deprecated SPECIALBUILD) \
       are now LIBPNG reserved macros. Use PNG_USER_PRIVATEBUILD instead.")
65
#  endif
66

67 68
#  ifdef PRIVATEBUILD
#    pragma message("PRIVATEBUILD is deprecated.\
69
       Use PNG_USER_PRIVATEBUILD instead.")
70 71
#    define PNG_USER_PRIVATEBUILD PRIVATEBUILD
#  endif
72 73 74
#endif /* __STDC__ */

/* End of material added to libpng-1.2.8 */
75

76 77
#ifndef PNG_VERSION_INFO_ONLY

A
Andreas Dilger 已提交
78
/* This is the size of the compression buffer, and thus the size of
79 80 81
 * an IDAT chunk.  Make this whatever size you feel is best for your
 * machine.  One of these will be allocated per png_struct.  When this
 * is full, it writes the data to the disk, and does some other
82
 * calculations.  Making this an extremely small size will slow
83 84 85 86
 * the library down, but you may want to experiment to determine
 * where it becomes significant, if you are concerned with memory
 * usage.  Note that zlib allocates at least 32Kb also.  For readers,
 * this describes the size of the buffer available to read the data in.
87
 * Unless this gets smaller than the size of a row (compressed),
88 89
 * it should not make much difference how big this is.
 */
G
Guy Schalnat 已提交
90

91
#ifndef PNG_ZBUF_SIZE
92
#  define PNG_ZBUF_SIZE 8192
93
#endif
G
Guy Schalnat 已提交
94

95 96 97 98 99 100 101 102 103 104 105 106
/* Enable if you want a write-only libpng */

#ifndef PNG_NO_READ_SUPPORTED
#  define PNG_READ_SUPPORTED
#endif

/* Enable if you want a read-only libpng */

#ifndef PNG_NO_WRITE_SUPPORTED
#  define PNG_WRITE_SUPPORTED
#endif

107 108 109 110 111 112 113 114 115 116 117
/* Enabled in 1.4.0. */
#ifdef PNG_ALLOW_BENIGN_ERRORS
#  define png_benign_error png_warning
#  define png_chunk_benign_error png_chunk_warning
#else
#  ifndef PNG_BENIGN_ERRORS_SUPPORTED
#    define png_benign_error png_error
#    define png_chunk_benign_error png_chunk_error
#  endif
#endif

118 119 120 121 122
/* Added at libpng version 1.4.0 */
#if !defined(PNG_NO_WARNINGS) && !defined(PNG_WARNINGS_SUPPORTED)
#  define PNG_WARNINGS_SUPPORTED
#endif

123
/* Added at libpng version 1.4.0 */
124 125 126 127
#if !defined(PNG_NO_ERROR_TEXT) && !defined(PNG_ERROR_TEXT_SUPPORTED)
#  define PNG_ERROR_TEXT_SUPPORTED
#endif

128
/* Added at libpng version 1.4.0 */
129 130 131 132
#if !defined(PNG_NO_CHECK_cHRM) && !defined(PNG_CHECK_cHRM_SUPPORTED)
#  define PNG_CHECK_cHRM_SUPPORTED
#endif

133 134 135 136 137
/* Added at libpng version 1.4.0 */
#if !defined(PNG_NO_ALIGNED_MEMORY) && !defined(PNG_ALIGNED_MEMORY_SUPPORTED)
#  define PNG_ALIGNED_MEMORY_SUPPORTED
#endif

138
/* Enabled by default in 1.2.0.  You can disable this if you don't need to
139 140
 * support PNGs that are embedded in MNG datastreams
 */
141
#ifndef PNG_NO_MNG_FEATURES
142 143 144 145 146
#  ifndef PNG_MNG_FEATURES_SUPPORTED
#    define PNG_MNG_FEATURES_SUPPORTED
#  endif
#endif

147
/* Added at libpng version 1.4.0 */
148
#ifndef PNG_NO_FLOATING_POINT_SUPPORTED
149 150 151
#  ifndef PNG_FLOATING_POINT_SUPPORTED
#    define PNG_FLOATING_POINT_SUPPORTED
#  endif
152 153
#endif

154
/* Added at libpng-1.4.0beta49 for testing (this test is no longer used
155
 * in libpng and png_calloc() is always present)
156
 */
157 158
#define PNG_CALLOC_SUPPORTED

A
Andreas Dilger 已提交
159
/* If you are running on a machine where you cannot allocate more
160 161 162 163 164
 * than 64K of memory at once, uncomment this.  While libpng will not
 * normally need that much memory in a chunk (unless you load up a very
 * large file), zlib needs to know how big of a chunk it can use, and
 * libpng thus makes sure to check any memory allocation to verify it
 * will fit into memory.
A
Andreas Dilger 已提交
165
#define PNG_MAX_MALLOC_64K
166
 */
A
Andreas Dilger 已提交
167
#if defined(MAXSEG_64K) && !defined(PNG_MAX_MALLOC_64K)
168
#  define PNG_MAX_MALLOC_64K
G
Guy Schalnat 已提交
169 170
#endif

171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210
/* This macro protects us against machines that don't have function
 * prototypes (ie K&R style headers).  If your compiler does not handle
 * function prototypes, define this macro and use the included ansi2knr.
 * I've always been able to use _NO_PROTO as the indicator, but you may
 * need to drag the empty declaration out in front of here, or change the
 * ifdef to suit your own needs.
 */
#ifndef PNGARG

#  ifdef OF /* zlib prototype munger */
#    define PNGARG(arglist) OF(arglist)
#  else

#    ifdef _NO_PROTO
#      define PNGARG(arglist) ()
#    else
#      define PNGARG(arglist) arglist
#    endif /* _NO_PROTO */

#  endif /* OF */

#endif /* PNGARG */

/* Function calling conventions.
 * =============================
 * Normally it is not necessary to specify to the compiler how to call
 * a function - it just does it - however on x86 systems derived from
 * Microsoft and Borland C compilers ('IBM PC', 'DOS', 'Windows' systems
 * and some others) there are multiple ways to call a function and the
 * default can be changed on the compiler command line.  For this reason
 * libpng allows the calling convention of every exported function and
 * every function called via a user supplied function pointer to be
 * specified.  This is done by defining the following macros:
 *
 * PNGAPI    Calling convention for exported functions.
 * PNGCBAPI  Calling convention for user provided (callback) functions.
 * PNGCAPI   Calling convention used by the ANSI-C library (required
 *           for longjmp callbacks and sometimes used internally to
 *           specify the calling convention for zlib).
 *
211
 *
212
 * Two common cases are supported:
213
 *
214 215 216 217 218 219 220 221 222 223 224 225
 * PNGAPI_RULE=0  Use the operating system convention for PNGAPI and
 *                the 'C' calling convention (from PNGCAPI) for
 *                callbacks (PNGCBAPI).
 * PNGAPI_RULE=1  Use PNGCAPI - the 'C' calling convention - throughout.
 *                This is correct on Cygwin implementations, assumed to
 *                be correct on MingW compilations and likely to work
 *                in C/C++ only environments everywhere else.
 *
 * These cases only differ if the operating system does not use the C
 * calling convention, at present this just means the above cases
 * (x86 DOS/Windows sytems) and, even then, this does not apply to
 * Cygwin running on those systems.
226
 */
227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248
#ifndef PNGAPI_RULE
#  define PNGAPI_RULE 0
#endif

/* Symbol export
 * =============
 * When building a shared library it is almost always necessary to tell
 * the compiler which symbols to export.  The png.h macro 'PNG_EXPORT'
 * is used to mark the symbols.  On some systems these symbols can be
 * extracted at link time and need no special processing by the compiler,
 * on other systems the symbols are flagged by the compiler and just
 * the declaration requires a special tag applied (unfortunately) in a
 * compiler dependent way.  Some systems can do either.
 *
 * A small number of older systems also require a symbol from a DLL to
 * be flagged to the program that calls it.  This is a problem because
 * we do not know in the header file included by application code that
 * the symbol will come from a shared library, as opposed to a statically
 * linked one.  For this reason the application must tell us by setting
 * the magic flag PNG_USE_DLL to turn on the special processing before
 * it includes png.h.
 * 
249
 * Four additional macros are used to make this happen:
250 251 252 253 254 255 256
 *
 * PNG_IMPEXP The magic (if any) to cause a symbol to be exported from
 *            the build or imported if PNG_USE_DLL is set - compiler
 *            and system specific.
 *
 * PNG_EXPORT_TYPE(type) A macro that pre or appends PNG_IMPEXP to
 *                       'type', compiler specific.
257 258 259 260 261 262 263
 *
 * PNG_DLL_EXPORT Set to the magic to use during a libpng build to
 *                make a symbol exported from the DLL.
 *
 * PNG_DLL_IMPORT Set to the magic to force the libpng symbols to come
 *                from a DLL - used to define PNG_IMPEXP when
 *                PNG_USE_DLL is set.
264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281
 */

/* System specific discovery.
 * ==========================
 * This code is used at build time to find PNG_IMPEXP, the API settings
 * and PNG_EXPORT_TYPE(), it may also set a macro to indicate the DLL
 * import processing is possible.
 *
 * NOTE: this is poorly tested and may miss many cases, the default
 * (everything empty) is harmless unless the result is a DLL that is
 * intended to be distributed!
 */
#if defined(__CYGWIN__)
  /* Cygwin: force PNGCAPI to cdecl. */
#  ifndef PNGCAPI
#    define PNGCAPI __cdecl
#  endif

282 283 284 285 286 287
  /* Provide the appropriate defaults for exporting a symbol from
   * the DLL and forcing import.  Always set these - the choice to
   * use them is made below.
   */
#  ifndef PNG_DLL_EXPORT
#    define PNG_DLL_EXPORT __declspec(dllexport)
288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303
#  endif
#  ifndef PNG_DLL_IMPORT
#    define PNG_DLL_IMPORT __declspec(dllimport)
#  endif

#else /* !Cygwin */
#  if ( defined(_Windows) || defined(_WINDOWS) || defined(WIN32) ||\
        defined(_WIN32) || defined(__WIN32__) ) &&\
      ( defined(_X86_) || defined(_X64_) || defined(_M_IX86) ||\
        defined(_M_X64) || defined(_M_IA64) )
    /* Windows system (DOS doesn't support DLLs) running on x86/x64 and
     * not being built under Cygwin or by a MingW compiler.
     */
#    if defined(__GNUC__) || (defined (_MSC_VER) && (_MSC_VER >= 800))
#      ifndef PNGCAPI
#        define PNGCAPI __cdecl
304
#      endif
305 306
#      if PNGAPI_RULE == 0 && !defined(PNGAPI)
#        define PNGAPI __stdcall
307 308
#      endif
#    else
309 310 311 312 313 314 315 316 317 318
      /* An older compiler, or one not detected (erroneously) above. */
#      ifndef PNGCAPI
#        define PNGCAPI _cdecl
#      endif
#      if PNGAPI_RULE == 0 && !defined(PNGAPI)
#        define PNGAPI _stdcall
#      endif
#    endif /* compiler/api */
    /* NOTE: PNGCBAPI always defaults to PNGCAPI. */

319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334
#    if (defined(_MSC_VER) && _MSC_VER < 800) ||\
        (defined(__BORLANDC__) && __BORLANDC__ < 0x500)
      /* older Borland and MSC
       * compilers used '__export' and required this to be after
       * the type.
       */
#      ifndef PNG_EXPORT_TYPE
#        define PNG_EXPORT_TYPE(type) type PNG_IMPEXP
#      endif
#      define PNG_DLL_EXPORT __export
#    else /* newer compiler */
#      define PNG_DLL_EXPORT __declspec(dllexport)
#      ifndef PNG_DLL_IMPORT
#        define PNG_DLL_IMPORT __declspec(dllimport)
#      endif
#    endif /* compiler */
335 336 337 338 339

#  else /* !Cygwin && !Windows/x86 */
#    if (defined(__IBMC__) || defined(__IBMCPP__)) && defined(__OS2__)
#      ifndef PNGAPI
#        define PNGAPI _System
340
#      endif
341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357
#    else /* !Cygwin && !Windows/x86 && !OS/2 */
      /* Use the defaults */
#    endif /* other system, !OS/2 */
#  endif /* !Windows/x86 */
#endif /* !Cygwin */

/* Now do all the defaulting . */
#ifndef PNGCAPI
#  define PNGCAPI
#endif
#ifndef PNGCBAPI
#  define PNGCBAPI PNGCAPI
#endif
#ifndef PNGAPI
#  define PNGAPI PNGCAPI
#endif

358 359 360
/* The default for PNG_IMPEXP depends on whether the library is
 * being built or used.
 */
361
#ifndef PNG_IMPEXP
362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380
#  ifdef PNGLIB_BUILD
    /* Building the library */
#    if (defined(DLL_EXPORT)/*from libtool*/ ||\
	defined(_WINDLL) || defined(_DLL) || defined(__DLL__) ||\
	defined(PNG_BUILD_DLL)) && defined(PNG_DLL_EXPORT)
      /* Building a DLL. */
#      define PNG_IMPEXP PNG_DLL_EXPORT
#    endif /* DLL */
#  else
    /* Using the library */
#    if defined(PNG_USE_DLL) && defined(PNG_DLL_IMPORT)
      /* This forces use of a DLL, disallowing static linking */
#      define PNG_IMPEXP PNG_DLL_IMPORT
#    endif
#  endif

#  ifndef PNG_IMPEXP
#    define PNG_IMPEXP
#  endif
381
#endif
382

383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408
#ifndef PNG_EXPORT_TYPE
#  define PNG_EXPORT_TYPE(type) PNG_IMPEXP type
#endif
#ifndef PNG_EXPORT
#  define PNG_EXPORT(type, name, args, attributes, ordinal)\
     PNG_EXPORT_TYPE(type) (PNGAPI name) PNGARG(args) attributes
#endif

/* Use PNG_REMOVED to comment out a removed interface. */
#ifndef PNG_REMOVED
#  define PNG_REMOVED(name, ordinal)
#endif

#ifndef PNG_CALLBACK
#  define PNG_CALLBACK(type, name, args, attributes)\
   type (PNGCBAPI name) PNGARG(args) attributes
#endif

/* Support for compiler specific function attributes.  These are used
 * so that where compiler support is available incorrect use of API
 * functions in png.h will generate compiler warnings.
 *
 * Added at libpng-1.2.41.
 */

#ifndef PNG_NO_PEDANTIC_WARNINGS
409 410 411
#  ifndef PNG_PEDANTIC_WARNINGS_SUPPORTED
#    define PNG_PEDANTIC_WARNINGS_SUPPORTED
#  endif
412 413 414
#endif

#ifdef PNG_PEDANTIC_WARNINGS_SUPPORTED
415 416 417 418 419
  /* Support for compiler specific function attributes.  These are used
   * so that where compiler support is available incorrect use of API
   * functions in png.h will generate compiler warnings.  Added at libpng
   * version 1.2.41.
   */
420 421 422
#  ifdef __GNUC__
#    ifndef PNG_USE_RESULT
#      define PNG_USE_RESULT __attribute__((__warn_unused_result__))
423
#    endif
424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471
#    ifndef PNG_NORETURN
#      define PNG_NORETURN   __attribute__((__noreturn__))
#    endif
#    ifndef PNG_ALLOCATED
#      define PNG_ALLOCATED  __attribute__((__malloc__))
#    endif

    /* This specifically protects structure members that should only be
     * accessed from within the library, therefore should be empty during
     * a library build.
     */
#    ifndef PNGLIB_BUILD
#      ifndef PNG_DEPRECATED
#        define PNG_DEPRECATED __attribute__((__deprecated__))
#      endif
#      ifndef PNG_DEPSTRUCT
#        define PNG_DEPSTRUCT  __attribute__((__deprecated__))
#      endif
#      ifndef PNG_PRIVATE
#        if 0 /* Doesn't work so we use deprecated instead*/
#          define PNG_PRIVATE \
            __attribute__((warning("This function is not exported by libpng.")))
#        else
#          define PNG_PRIVATE \
            __attribute__((__deprecated__))
#        endif
#      endif /* PNG_PRIVATE */
#    endif /* PNGLIB_BUILD */
#  endif /* __GNUC__ */
#endif /* PNG_PEDANTIC_WARNINGS */

#ifndef PNG_DEPRECATED
#  define PNG_DEPRECATED  /* Use of this function is deprecated */
#endif
#ifndef PNG_USE_RESULT
#  define PNG_USE_RESULT  /* The result of this function must be checked */
#endif
#ifndef PNG_NORETURN
#  define PNG_NORETURN    /* This function does not return */
#endif
#ifndef PNG_ALLOCATED
#  define PNG_ALLOCATED   /* The result of the function is new memory */
#endif
#ifndef PNG_DEPSTRUCT
#  define PNG_DEPSTRUCT   /* Access to this struct member is deprecated */
#endif
#ifndef PNG_PRIVATE
#  define PNG_PRIVATE     /* This is a private libpng function */
472 473
#endif

474
/* This protects us against compilers that run on a windowing system
475 476
 * and thus don't have or would rather us not use the stdio types:
 * stdin, stdout, and stderr.  The only one currently used is stderr
477 478 479 480
 * in png_error() and png_warning().  #defining PNG_NO_CONSOLE_IO will
 * prevent these from being compiled and used. #defining PNG_NO_STDIO
 * will also prevent these, plus will prevent the entire set of stdio
 * macros and functions (FILE *, printf, etc.) from being compiled and used,
481
 * unless (PNG_DEBUG > 0) has been #defined.
482 483
 *
 * #define PNG_NO_CONSOLE_IO
484 485
 * #define PNG_NO_STDIO
 */
G
Guy Schalnat 已提交
486

487 488 489 490
#if !defined(PNG_NO_STDIO) && !defined(PNG_STDIO_SUPPORTED)
#  define PNG_STDIO_SUPPORTED
#endif

491 492 493 494 495 496 497
#ifdef PNG_NO_STDIO
#  ifndef PNG_NO_CONSOLE_IO
#    define PNG_NO_CONSOLE_IO
#  endif
#  ifdef PNG_DEBUG
#    if (PNG_DEBUG > 0)
#      include <stdio.h>
498
#    endif
499
#  endif
500 501 502
#else
#  include <stdio.h>
#endif
A
Andreas Dilger 已提交
503

504 505 506 507 508 509 510
#if !(defined PNG_NO_CONSOLE_IO) && !defined(PNG_CONSOLE_IO_SUPPORTED)
#  define PNG_CONSOLE_IO_SUPPORTED
#endif

/* PNG_SETJMP_NOT_SUPPORTED and PNG_NO_SETJMP_SUPPORTED are deprecated. */
#if !defined(PNG_NO_SETJMP) && \
    !defined(PNG_SETJMP_NOT_SUPPORTED) && !defined(PNG_NO_SETJMP_SUPPORTED)
511 512 513 514
#  define PNG_SETJMP_SUPPORTED
#endif

#ifdef PNG_SETJMP_SUPPORTED
515
#  include <setjmp.h>
516
#endif
A
Andreas Dilger 已提交
517

G
Guy Schalnat 已提交
518
#ifdef BSD
519
#  include <strings.h>
G
Guy Schalnat 已提交
520
#else
521
#  include <string.h>
G
Guy Schalnat 已提交
522 523
#endif

A
Andreas Dilger 已提交
524
/* Other defines for things like memory and the like can go here.  */
G
Guy Schalnat 已提交
525

526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556
/* This controls how fine the dithering gets.  As this allocates
 * a largish chunk of memory (32K), those who are not as concerned
 * with dithering quality can decrease some or all of these.
 */
#ifndef PNG_DITHER_RED_BITS
#  define PNG_DITHER_RED_BITS 5
#endif
#ifndef PNG_DITHER_GREEN_BITS
#  define PNG_DITHER_GREEN_BITS 5
#endif
#ifndef PNG_DITHER_BLUE_BITS
#  define PNG_DITHER_BLUE_BITS 5
#endif

/* This controls how fine the gamma correction becomes when you
 * are only interested in 8 bits anyway.  Increasing this value
 * results in more memory being used, and more pow() functions
 * being called to fill in the gamma tables.  Don't set this value
 * less then 8, and even that may not work (I haven't tested it).
 */
#ifndef PNG_MAX_GAMMA_8
#  define PNG_MAX_GAMMA_8 11
#endif

/* This controls how much a difference in gamma we can tolerate before
 * we actually start doing gamma conversion.
 */
#ifndef PNG_GAMMA_THRESHOLD
#  define PNG_GAMMA_THRESHOLD 0.05
#endif

A
Andreas Dilger 已提交
557
/* The following uses const char * instead of char * for error
558
 * and warning message functions, so some compilers won't complain.
559
 * If you do not want to use const, define PNG_NO_CONST here.
560
 */
561 562 563 564 565 566
#ifndef PNG_CONST
#  ifndef PNG_NO_CONST
#    define PNG_CONST const
#  else
#    define PNG_CONST
#  endif
G
Guy Schalnat 已提交
567 568
#endif

A
Andreas Dilger 已提交
569
/* The following defines give you the ability to remove code from the
570 571 572 573 574 575 576 577 578 579 580 581
 * library that you will not be using.  I wish I could figure out how to
 * automate this, but I can't do that without making it seriously hard
 * on the users.  So if you are not using an ability, change the #define
 * to and #undef, and that part of the library will not be compiled.  If
 * your linker can't find a function, you may want to make sure the
 * ability is defined here.  Some of these depend upon some others being
 * defined.  I haven't figured out all the interactions here, so you may
 * have to experiment awhile to get everything to compile.  If you are
 * creating or using a shared library, you probably shouldn't touch this,
 * as it will affect the size of the structures, and this will cause bad
 * things to happen if the library and/or application ever change.
 */
G
Guy Schalnat 已提交
582

583
/* Any features you will not be using can be undef'ed here */
584

585
/* GR-P, 0.96a: Set "*TRANSFORMS_SUPPORTED as default but allow user
586 587 588
 * to turn it off with PNG_NO_READ|WRITE_TRANSFORMS on the compile line,
 * then pick and choose which ones to define without having to edit this
 * file. It is safe to use the PNG_NO_READ|WRITE_TRANSFORMS
589 590 591
 * if you only want to have a png-compliant reader/writer but don't need
 * any of the extra transformations.  This saves about 80 kbytes in a
 * typical installation of the library. (PNG_NO_* form added in version
592 593
 * 1.0.1c, for consistency; PNG_*_TRANSFORMS_NOT_SUPPORTED deprecated in
 * 1.4.0)
594
 */
595

596
/* Ignore attempt to turn off both floating and fixed point support */
597
#if !defined(PNG_FLOATING_POINT_SUPPORTED) || \
598 599
    !defined(PNG_NO_FIXED_POINT_SUPPORTED)
#  define PNG_FIXED_POINT_SUPPORTED
600
#endif
601

602
#ifdef PNG_READ_SUPPORTED
603

604
/* PNG_READ_TRANSFORMS_NOT_SUPPORTED is deprecated. */
605
#  if !defined(PNG_READ_TRANSFORMS_NOT_SUPPORTED) && \
606
      !defined(PNG_NO_READ_TRANSFORMS)
607
#    define PNG_READ_TRANSFORMS_SUPPORTED
608
#  endif
609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662

#  ifdef PNG_READ_TRANSFORMS_SUPPORTED
#    ifndef PNG_NO_READ_EXPAND
#      define PNG_READ_EXPAND_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_SHIFT
#      define PNG_READ_SHIFT_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_PACK
#      define PNG_READ_PACK_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_BGR
#      define PNG_READ_BGR_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_SWAP
#      define PNG_READ_SWAP_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_PACKSWAP
#      define PNG_READ_PACKSWAP_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_INVERT
#      define PNG_READ_INVERT_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_BACKGROUND
#      define PNG_READ_BACKGROUND_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_16_TO_8
#      define PNG_READ_16_TO_8_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_FILLER
#      define PNG_READ_FILLER_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_GAMMA
#      define PNG_READ_GAMMA_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_GRAY_TO_RGB
#      define PNG_READ_GRAY_TO_RGB_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_SWAP_ALPHA
#      define PNG_READ_SWAP_ALPHA_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_INVERT_ALPHA
#      define PNG_READ_INVERT_ALPHA_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_STRIP_ALPHA
#      define PNG_READ_STRIP_ALPHA_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_USER_TRANSFORM
#      define PNG_READ_USER_TRANSFORM_SUPPORTED
#    endif
#    ifndef PNG_NO_READ_RGB_TO_GRAY
#      define PNG_READ_RGB_TO_GRAY_SUPPORTED
#    endif
#  endif /* PNG_READ_TRANSFORMS_SUPPORTED */
663

664 665 666 667 668 669 670 671
#  ifndef PNG_NO_PROGRESSIVE_READ
#    define PNG_PROGRESSIVE_READ_SUPPORTED
#  endif
/* You can define PNG_NO_PROGRESSIVE_READ if you don't do progressive reading.
 * This is not talking about interlacing capability!  You'll still have
 * interlacing unless you change the following define which is required
 * for PNG-compliant decoders:
 */
672

673
#  define PNG_READ_INTERLACING_SUPPORTED
674

675
  /* PNG_NO_SEQUENTIAL_READ_SUPPORTED is deprecated. */
676
#  if !defined(PNG_NO_SEQUENTIAL_READ) && \
677 678
      !defined(PNG_SEQUENTIAL_READ_SUPPORTED) && \
      !defined(PNG_NO_SEQUENTIAL_READ_SUPPORTED)
679 680
#    define PNG_SEQUENTIAL_READ_SUPPORTED
#  endif
681

682 683
#  ifndef PNG_NO_READ_COMPOSITE_NODIV
#    ifndef PNG_NO_READ_COMPOSITED_NODIV  /* libpng-1.0.x misspelling */
684
      /* well tested on Intel, SGI */
685
#      define PNG_READ_COMPOSITE_NODIV_SUPPORTED
686
#    endif
687
#  endif
G
Guy Schalnat 已提交
688

689
#  if !defined(PNG_NO_GET_INT_32) || defined(PNG_READ_oFFS_SUPPORTED) || \
690
      defined(PNG_READ_pCAL_SUPPORTED)
691 692 693
#    ifndef PNG_GET_INT_32_SUPPORTED
#      define PNG_GET_INT_32_SUPPORTED
#    endif
694 695
#  endif

696 697
#endif /* PNG_READ_SUPPORTED */

698
#ifdef PNG_WRITE_SUPPORTED
699

700
/* PNG_WRITE_TRANSFORMS_NOT_SUPPORTED is deprecated. */
701
#  if !defined(PNG_WRITE_TRANSFORMS_NOT_SUPPORTED) && \
702
      !defined(PNG_NO_WRITE_TRANSFORMS)
703
#    define PNG_WRITE_TRANSFORMS_SUPPORTED
704
#  endif
705

706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739
#  ifdef PNG_WRITE_TRANSFORMS_SUPPORTED
#    ifndef PNG_NO_WRITE_SHIFT
#      define PNG_WRITE_SHIFT_SUPPORTED
#    endif
#    ifndef PNG_NO_WRITE_PACK
#      define PNG_WRITE_PACK_SUPPORTED
#    endif
#    ifndef PNG_NO_WRITE_BGR
#      define PNG_WRITE_BGR_SUPPORTED
#    endif
#    ifndef PNG_NO_WRITE_SWAP
#      define PNG_WRITE_SWAP_SUPPORTED
#    endif
#    ifndef PNG_NO_WRITE_PACKSWAP
#      define PNG_WRITE_PACKSWAP_SUPPORTED
#    endif
#    ifndef PNG_NO_WRITE_INVERT
#      define PNG_WRITE_INVERT_SUPPORTED
#    endif
#    ifndef PNG_NO_WRITE_FILLER
#      define PNG_WRITE_FILLER_SUPPORTED   /* same as WRITE_STRIP_ALPHA */
#    endif
#    ifndef PNG_NO_WRITE_SWAP_ALPHA
#      define PNG_WRITE_SWAP_ALPHA_SUPPORTED
#    endif
#    ifndef PNG_NO_WRITE_INVERT_ALPHA
#      define PNG_WRITE_INVERT_ALPHA_SUPPORTED
#    endif
#    ifndef PNG_NO_WRITE_USER_TRANSFORM
#      define PNG_WRITE_USER_TRANSFORM_SUPPORTED
#    endif
#  endif /* PNG_WRITE_TRANSFORMS_SUPPORTED */

#  if !defined(PNG_NO_WRITE_INTERLACING_SUPPORTED) && \
740
      !defined(PNG_WRITE_INTERLACING_SUPPORTED)
741 742
    /* This is not required for PNG-compliant encoders, but can cause
     * trouble if left undefined
743
     */
744 745
#    define PNG_WRITE_INTERLACING_SUPPORTED
#  endif
746

747
#  if !defined(PNG_NO_WRITE_WEIGHTED_FILTER) && \
748 749
      !defined(PNG_WRITE_WEIGHTED_FILTER) && \
      defined(PNG_FLOATING_POINT_SUPPORTED)
750 751
#    define PNG_WRITE_WEIGHTED_FILTER_SUPPORTED
#  endif
752

753 754 755
#  ifndef PNG_NO_WRITE_FLUSH
#    define PNG_WRITE_FLUSH_SUPPORTED
#  endif
756

757
#  if !defined(PNG_NO_SAVE_INT_32) || defined(PNG_WRITE_oFFS_SUPPORTED) || \
758
      defined(PNG_WRITE_pCAL_SUPPORTED)
759 760 761
#    ifndef PNG_SAVE_INT_32_SUPPORTED
#      define PNG_SAVE_INT_32_SUPPORTED
#    endif
762 763
#  endif

764 765
#endif /* PNG_WRITE_SUPPORTED */

766
#define PNG_NO_ERROR_NUMBERS
767 768 769 770 771 772 773 774

#if defined(PNG_READ_USER_TRANSFORM_SUPPORTED) || \
    defined(PNG_WRITE_USER_TRANSFORM_SUPPORTED)
#  ifndef PNG_NO_USER_TRANSFORM_PTR
#    define PNG_USER_TRANSFORM_PTR_SUPPORTED
#  endif
#endif

775
#if defined(PNG_STDIO_SUPPORTED) && !defined(PNG_TIME_RFC1123_SUPPORTED)
776
#  define PNG_TIME_RFC1123_SUPPORTED
777
#endif
A
Andreas Dilger 已提交
778

779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794
/* This adds extra functions in pngget.c for accessing data from the
 * info pointer (added in version 0.99)
 * png_get_image_width()
 * png_get_image_height()
 * png_get_bit_depth()
 * png_get_color_type()
 * png_get_compression_type()
 * png_get_filter_type()
 * png_get_interlace_type()
 * png_get_pixel_aspect_ratio()
 * png_get_pixels_per_meter()
 * png_get_x_offset_pixels()
 * png_get_y_offset_pixels()
 * png_get_x_offset_microns()
 * png_get_y_offset_microns()
 */
795
#if !defined(PNG_NO_EASY_ACCESS) && !defined(PNG_EASY_ACCESS_SUPPORTED)
796
#  define PNG_EASY_ACCESS_SUPPORTED
797 798
#endif

799
/* Added at libpng-1.2.0 */
800 801 802 803
#if !defined(PNG_NO_USER_MEM) && !defined(PNG_USER_MEM_SUPPORTED)
#  define PNG_USER_MEM_SUPPORTED
#endif

804
/* Added at libpng-1.2.6 */
805 806
#ifndef PNG_NO_SET_USER_LIMITS
#  ifndef PNG_SET_USER_LIMITS_SUPPORTED
807
#    define PNG_SET_USER_LIMITS_SUPPORTED
808 809 810 811 812 813 814 815 816 817 818 819 820 821 822
#  endif
  /* Feature added at libpng-1.4.0, this flag added at 1.4.1 */
#  ifndef PNG_SET_CHUNK_CACHE_LIMIT_SUPPORTED
#    define PNG_SET_CHUNK_CACHE_LIMIT_SUPPORTED
#  endif
  /* Feature added at libpng-1.4.1, this flag added at 1.4.1 */
#  ifndef PNG_SET_CHUNK_MALLOC_LIMIT_SUPPORTED
#    define PNG_SET_CHUNK_MALLOC_LIMIT_SUPPORTED
#  endif
#endif

/* Added at libpng-1.2.43 */
#ifndef PNG_NO_USER_LIMITS
#  ifndef PNG_USER_LIMITS_SUPPORTED
#    define PNG_USER_LIMITS_SUPPORTED
823
#  endif
824 825
#endif

826
/* Added at libpng-1.0.16 and 1.2.6.  To accept all valid PNGs no matter
827
 * how large, set these two limits to 0x7fffffffL
828 829 830 831 832 833 834 835
 */
#ifndef PNG_USER_WIDTH_MAX
#  define PNG_USER_WIDTH_MAX 1000000L
#endif
#ifndef PNG_USER_HEIGHT_MAX
#  define PNG_USER_HEIGHT_MAX 1000000L
#endif

836 837 838
/* Added at libpng-1.2.43.  To accept all valid PNGs no matter
 * how large, set these two limits to 0.
 */
839
#ifndef PNG_USER_CHUNK_CACHE_MAX
840 841 842 843 844 845
#  define PNG_USER_CHUNK_CACHE_MAX 0
#endif

/* Added at libpng-1.2.43 */
#ifndef PNG_USER_CHUNK_MALLOC_MAX
#  define PNG_USER_CHUNK_MALLOC_MAX 0
846 847
#endif

848
/* Added at libpng-1.4.0 */
849
#if !defined(PNG_NO_IO_STATE) && !defined(PNG_IO_STATE_SUPPORTED)
850 851 852
#  define PNG_IO_STATE_SUPPORTED
#endif

853 854 855
#ifndef PNG_LITERAL_SHARP
#  define PNG_LITERAL_SHARP 0x23
#endif
856
#ifndef PNG_LITERAL_LEFT_SQUARE_BRACKET
857
#  define PNG_LITERAL_LEFT_SQUARE_BRACKET 0x5b
858 859
#endif
#ifndef PNG_LITERAL_RIGHT_SQUARE_BRACKET
860
#  define PNG_LITERAL_RIGHT_SQUARE_BRACKET 0x5d
861
#endif
862
#ifndef PNG_STRING_NEWLINE
863
#  define PNG_STRING_NEWLINE "\n"
864
#endif
865

866 867
/* These are currently experimental features, define them if you want */

868
/* Very little testing, not enabled by default. */
869
/*
870
#ifdef PNG_READ_SUPPORTED
871 872 873
#  ifndef PNG_READ_16_TO_8_ACCURATE_SCALE_SUPPORTED
#    define PNG_READ_16_TO_8_ACCURATE_SCALE_SUPPORTED
#  endif
874
#endif
875
*/
A
Andreas Dilger 已提交
876 877

/* This is only for PowerPC big-endian and 680x0 systems */
878
/* some testing, not enabled by default. */
879
/*
880
#ifndef PNG_READ_BIG_ENDIAN_SUPPORTED
881
#  define PNG_READ_BIG_ENDIAN_SUPPORTED
882
#endif
883
*/
G
Guy Schalnat 已提交
884

885 886 887 888
#if !defined(PNG_NO_USE_READ_MACROS) && !defined(PNG_USE_READ_MACROS)
#  define PNG_USE_READ_MACROS
#endif

889 890 891 892 893
/* Buggy compilers (e.g., gcc 2.7.2.2) need PNG_NO_POINTER_INDEXING */
#if !defined(PNG_NO_POINTER_INDEXING) && \
    !defined(PNG_POINTER_INDEXING_SUPPORTED)
#  define PNG_POINTER_INDEXING_SUPPORTED
#endif
894

A
Andreas Dilger 已提交
895

A
Andreas Dilger 已提交
896 897 898
/* Any chunks you are not interested in, you can undef here.  The
 * ones that allocate memory may be expecially important (hIST,
 * tEXt, zTXt, tRNS, pCAL).  Others will just save time and make png_info
899
 * a bit smaller.
A
Andreas Dilger 已提交
900
 */
G
Guy Schalnat 已提交
901

902 903 904 905 906 907 908 909
/* The size of the png_text structure changed in libpng-1.0.6 when
 * iTXt support was added.  iTXt support was turned off by default through
 * libpng-1.2.x, to support old apps that malloc the png_text structure
 * instead of calling png_set_text() and letting libpng malloc it.  It
 * was turned on by default in libpng-1.4.0.
 */

/* PNG_READ_ANCILLARY_CHUNKS_NOT_SUPPORTED is deprecated. */
910 911
#if defined(PNG_READ_SUPPORTED) && \
    !defined(PNG_READ_ANCILLARY_CHUNKS_NOT_SUPPORTED) && \
912
    !defined(PNG_NO_READ_ANCILLARY_CHUNKS)
913
#  define PNG_READ_ANCILLARY_CHUNKS_SUPPORTED
914
#endif
915

916
/* PNG_WRITE_ANCILLARY_CHUNKS_NOT_SUPPORTED is deprecated. */
917 918
#if defined(PNG_WRITE_SUPPORTED) && \
    !defined(PNG_WRITE_ANCILLARY_CHUNKS_NOT_SUPPORTED) && \
919
    !defined(PNG_NO_WRITE_ANCILLARY_CHUNKS)
920
#  define PNG_WRITE_ANCILLARY_CHUNKS_SUPPORTED
921 922 923
#endif

#ifdef PNG_READ_ANCILLARY_CHUNKS_SUPPORTED
924

925 926 927 928
#  ifdef PNG_NO_READ_TEXT
#    define PNG_NO_READ_iTXt
#    define PNG_NO_READ_tEXt
#    define PNG_NO_READ_zTXt
929
#  endif
930

931 932
#  ifndef PNG_NO_READ_bKGD
#    define PNG_READ_bKGD_SUPPORTED
933 934
#    define PNG_bKGD_SUPPORTED
#  endif
935 936
#  ifndef PNG_NO_READ_cHRM
#    define PNG_READ_cHRM_SUPPORTED
937 938
#    define PNG_cHRM_SUPPORTED
#  endif
939 940
#  ifndef PNG_NO_READ_gAMA
#    define PNG_READ_gAMA_SUPPORTED
941 942
#    define PNG_gAMA_SUPPORTED
#  endif
943 944
#  ifndef PNG_NO_READ_hIST
#    define PNG_READ_hIST_SUPPORTED
945 946
#    define PNG_hIST_SUPPORTED
#  endif
947 948
#  ifndef PNG_NO_READ_iCCP
#    define PNG_READ_iCCP_SUPPORTED
949 950
#    define PNG_iCCP_SUPPORTED
#  endif
951 952 953 954 955 956 957
#  ifndef PNG_NO_READ_iTXt
#    ifndef PNG_READ_iTXt_SUPPORTED
#      define PNG_READ_iTXt_SUPPORTED
#    endif
#    ifndef PNG_iTXt_SUPPORTED
#      define PNG_iTXt_SUPPORTED
#    endif
958
#  endif
959 960
#  ifndef PNG_NO_READ_oFFs
#    define PNG_READ_oFFs_SUPPORTED
961 962
#    define PNG_oFFs_SUPPORTED
#  endif
963 964
#  ifndef PNG_NO_READ_pCAL
#    define PNG_READ_pCAL_SUPPORTED
965 966
#    define PNG_pCAL_SUPPORTED
#  endif
967 968
#  ifndef PNG_NO_READ_sCAL
#    define PNG_READ_sCAL_SUPPORTED
969 970
#    define PNG_sCAL_SUPPORTED
#  endif
971 972
#  ifndef PNG_NO_READ_pHYs
#    define PNG_READ_pHYs_SUPPORTED
973 974
#    define PNG_pHYs_SUPPORTED
#  endif
975 976
#  ifndef PNG_NO_READ_sBIT
#    define PNG_READ_sBIT_SUPPORTED
977 978
#    define PNG_sBIT_SUPPORTED
#  endif
979 980
#  ifndef PNG_NO_READ_sPLT
#    define PNG_READ_sPLT_SUPPORTED
981 982
#    define PNG_sPLT_SUPPORTED
#  endif
983 984
#  ifndef PNG_NO_READ_sRGB
#    define PNG_READ_sRGB_SUPPORTED
985 986
#    define PNG_sRGB_SUPPORTED
#  endif
987 988
#  ifndef PNG_NO_READ_tEXt
#    define PNG_READ_tEXt_SUPPORTED
989 990
#    define PNG_tEXt_SUPPORTED
#  endif
991 992
#  ifndef PNG_NO_READ_tIME
#    define PNG_READ_tIME_SUPPORTED
993 994
#    define PNG_tIME_SUPPORTED
#  endif
995 996
#  ifndef PNG_NO_READ_tRNS
#    define PNG_READ_tRNS_SUPPORTED
997 998
#    define PNG_tRNS_SUPPORTED
#  endif
999 1000
#  ifndef PNG_NO_READ_zTXt
#    define PNG_READ_zTXt_SUPPORTED
1001 1002
#    define PNG_zTXt_SUPPORTED
#  endif
1003
#  ifndef PNG_NO_READ_OPT_PLTE
1004 1005 1006 1007 1008
    /* This only affects support of the optional PLTE chunk in RGB and RGBA
     * images.
     */
#    define PNG_READ_OPT_PLTE_SUPPORTED
#  endif
1009
#  if defined(PNG_READ_iTXt_SUPPORTED) || defined(PNG_READ_tEXt_SUPPORTED) || \
1010
      defined(PNG_READ_zTXt_SUPPORTED)
1011
#    define PNG_READ_TEXT_SUPPORTED
1012 1013 1014
#    define PNG_TEXT_SUPPORTED
#  endif

1015
#endif /* PNG_READ_ANCILLARY_CHUNKS_SUPPORTED */
1016

1017 1018 1019
#ifndef PNG_NO_READ_UNKNOWN_CHUNKS
#  ifndef PNG_READ_UNKNOWN_CHUNKS_SUPPORTED
#    define PNG_READ_UNKNOWN_CHUNKS_SUPPORTED
1020
#  endif
1021 1022 1023
#  ifndef PNG_UNKNOWN_CHUNKS_SUPPORTED
#    define PNG_UNKNOWN_CHUNKS_SUPPORTED
#  endif
1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034
#  ifndef PNG_READ_USER_CHUNKS_SUPPORTED
#    define PNG_READ_USER_CHUNKS_SUPPORTED
#  endif
#endif
#ifndef PNG_NO_READ_USER_CHUNKS
#  ifndef PNG_READ_USER_CHUNKS_SUPPORTED
#    define PNG_READ_USER_CHUNKS_SUPPORTED
#  endif
#  ifndef PNG_USER_CHUNKS_SUPPORTED
#    define PNG_USER_CHUNKS_SUPPORTED
#  endif
1035 1036 1037 1038
#endif
#ifndef PNG_NO_HANDLE_AS_UNKNOWN
#  ifndef PNG_HANDLE_AS_UNKNOWN_SUPPORTED
#    define PNG_HANDLE_AS_UNKNOWN_SUPPORTED
1039
#  endif
1040
#endif
1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153

#ifdef PNG_WRITE_SUPPORTED
#  ifdef PNG_WRITE_ANCILLARY_CHUNKS_SUPPORTED

#    ifdef PNG_NO_WRITE_TEXT
#      define PNG_NO_WRITE_iTXt
#      define PNG_NO_WRITE_tEXt
#      define PNG_NO_WRITE_zTXt
#    endif
#    ifndef PNG_NO_WRITE_bKGD
#      define PNG_WRITE_bKGD_SUPPORTED
#      ifndef PNG_bKGD_SUPPORTED
#        define PNG_bKGD_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_cHRM
#      define PNG_WRITE_cHRM_SUPPORTED
#      ifndef PNG_cHRM_SUPPORTED
#        define PNG_cHRM_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_gAMA
#      define PNG_WRITE_gAMA_SUPPORTED
#      ifndef PNG_gAMA_SUPPORTED
#        define PNG_gAMA_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_hIST
#      define PNG_WRITE_hIST_SUPPORTED
#      ifndef PNG_hIST_SUPPORTED
#        define PNG_hIST_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_iCCP
#      define PNG_WRITE_iCCP_SUPPORTED
#      ifndef PNG_iCCP_SUPPORTED
#        define PNG_iCCP_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_iTXt
#      ifndef PNG_WRITE_iTXt_SUPPORTED
#        define PNG_WRITE_iTXt_SUPPORTED
#      endif
#      ifndef PNG_iTXt_SUPPORTED
#        define PNG_iTXt_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_oFFs
#      define PNG_WRITE_oFFs_SUPPORTED
#      ifndef PNG_oFFs_SUPPORTED
#        define PNG_oFFs_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_pCAL
#      define PNG_WRITE_pCAL_SUPPORTED
#      ifndef PNG_pCAL_SUPPORTED
#        define PNG_pCAL_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_sCAL
#      define PNG_WRITE_sCAL_SUPPORTED
#      ifndef PNG_sCAL_SUPPORTED
#        define PNG_sCAL_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_pHYs
#      define PNG_WRITE_pHYs_SUPPORTED
#      ifndef PNG_pHYs_SUPPORTED
#        define PNG_pHYs_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_sBIT
#      define PNG_WRITE_sBIT_SUPPORTED
#      ifndef PNG_sBIT_SUPPORTED
#        define PNG_sBIT_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_sPLT
#      define PNG_WRITE_sPLT_SUPPORTED
#      ifndef PNG_sPLT_SUPPORTED
#        define PNG_sPLT_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_sRGB
#      define PNG_WRITE_sRGB_SUPPORTED
#      ifndef PNG_sRGB_SUPPORTED
#        define PNG_sRGB_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_tEXt
#      define PNG_WRITE_tEXt_SUPPORTED
#      ifndef PNG_tEXt_SUPPORTED
#        define PNG_tEXt_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_tIME
#      define PNG_WRITE_tIME_SUPPORTED
#      ifndef PNG_tIME_SUPPORTED
#        define PNG_tIME_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_tRNS
#      define PNG_WRITE_tRNS_SUPPORTED
#      ifndef PNG_tRNS_SUPPORTED
#        define PNG_tRNS_SUPPORTED
#      endif
#    endif
#    ifndef PNG_NO_WRITE_zTXt
#      define PNG_WRITE_zTXt_SUPPORTED
#      ifndef PNG_zTXt_SUPPORTED
#        define PNG_zTXt_SUPPORTED
#      endif
#    endif
1154 1155 1156
#    if defined(PNG_WRITE_iTXt_SUPPORTED) || \
        defined(PNG_WRITE_tEXt_SUPPORTED) || \
        defined(PNG_WRITE_zTXt_SUPPORTED)
1157 1158 1159 1160 1161 1162 1163 1164
#      define PNG_WRITE_TEXT_SUPPORTED
#      ifndef PNG_TEXT_SUPPORTED
#        define PNG_TEXT_SUPPORTED
#      endif
#    endif

#    ifdef PNG_WRITE_tIME_SUPPORTED
#      ifndef PNG_NO_CONVERT_tIME
1165
        /* The "tm" structure is not supported on WindowsCE */
1166 1167 1168 1169 1170 1171 1172 1173 1174 1175 1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192
#        ifndef _WIN32_WCE
#          ifndef PNG_CONVERT_tIME_SUPPORTED
#            define PNG_CONVERT_tIME_SUPPORTED
#          endif
#        endif
#      endif
#    endif

#  endif /* PNG_WRITE_ANCILLARY_CHUNKS_SUPPORTED */

#  ifndef PNG_NO_WRITE_FILTER
#    ifndef PNG_WRITE_FILTER_SUPPORTED
#      define PNG_WRITE_FILTER_SUPPORTED
#    endif
#  endif

#  ifndef PNG_NO_WRITE_UNKNOWN_CHUNKS
#    define PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED
#    ifndef PNG_UNKNOWN_CHUNKS_SUPPORTED
#      define PNG_UNKNOWN_CHUNKS_SUPPORTED
#    endif
#  endif
#  ifndef PNG_NO_HANDLE_AS_UNKNOWN
#    ifndef PNG_HANDLE_AS_UNKNOWN_SUPPORTED
#      define PNG_HANDLE_AS_UNKNOWN_SUPPORTED
#    endif
#  endif
1193
#endif /* PNG_WRITE_SUPPORTED */
G
Guy Schalnat 已提交
1194

1195 1196
/* Turn this off to disable png_read_png() and png_write_png() and
 * leave the row_pointers member out of the info structure.
1197 1198 1199 1200 1201
 */
#ifndef PNG_NO_INFO_IMAGE
#  define PNG_INFO_IMAGE_SUPPORTED
#endif

1202 1203
/* Need the time information for converting tIME chunks */
#ifdef PNG_CONVERT_tIME_SUPPORTED
1204
  /* "time.h" functions are not supported on WindowsCE */
1205
#  include <time.h>
A
Andreas Dilger 已提交
1206 1207
#endif

A
Andreas Dilger 已提交
1208
/* Some typedefs to get us started.  These should be safe on most of the
A
Andreas Dilger 已提交
1209 1210 1211 1212
 * common platforms.  The typedefs should be at least as large as the
 * numbers suggest (a png_uint_32 must be at least 32 bits long), but they
 * don't have to be exactly that size.  Some compilers dislike passing
 * unsigned shorts as function parameters, so you may be better off using
1213
 * unsigned int for png_uint_16.
A
Andreas Dilger 已提交
1214
 */
G
Guy Schalnat 已提交
1215

1216 1217 1218 1219
#if defined(INT_MAX) && (INT_MAX > 0x7ffffffeL)
typedef unsigned int png_uint_32;
typedef int png_int_32;
#else
G
Guy Schalnat 已提交
1220 1221
typedef unsigned long png_uint_32;
typedef long png_int_32;
1222
#endif
G
Guy Schalnat 已提交
1223 1224 1225 1226
typedef unsigned short png_uint_16;
typedef short png_int_16;
typedef unsigned char png_byte;

1227
#ifdef PNG_NO_SIZE_T
1228
typedef unsigned int png_size_t;
1229
#else
1230
typedef size_t png_size_t;
1231
#endif
1232
#define png_sizeof(x) sizeof(x)
G
Guy Schalnat 已提交
1233

A
Andreas Dilger 已提交
1234
/* The following is needed for medium model support.  It cannot be in the
1235
 * pngpriv.h header.  Needs modification for other compilers besides
A
Andreas Dilger 已提交
1236 1237 1238 1239 1240 1241
 * MSC.  Model independent support declares all arrays and pointers to be
 * large using the far keyword.  The zlib version used must also support
 * model independent data.  As of version zlib 1.0.4, the necessary changes
 * have been made in zlib.  The USE_FAR_KEYWORD define triggers other
 * changes that are needed. (Tim Wegner)
 */
G
Guy Schalnat 已提交
1242

A
Andreas Dilger 已提交
1243
/* Separate compiler dependencies (problem here is that zlib.h always
1244 1245
 * defines FAR. (SJT)
 */
G
Guy Schalnat 已提交
1246
#ifdef __BORLANDC__
1247 1248 1249 1250 1251
#  if defined(__LARGE__) || defined(__HUGE__) || defined(__COMPACT__)
#    define LDATA 1
#  else
#    define LDATA 0
#  endif
1252
  /* GRR:  why is Cygwin in here?  Cygwin is not Borland C... */
1253 1254 1255 1256 1257 1258 1259 1260
#  if !defined(__WIN32__) && !defined(__FLAT__) && !defined(__CYGWIN__)
#    define PNG_MAX_MALLOC_64K
#    if (LDATA != 1)
#      ifndef FAR
#        define FAR __far
#      endif
#      define USE_FAR_KEYWORD
#    endif   /* LDATA != 1 */
1261 1262 1263
         /* Possibly useful for moving data out of default segment.
          * Uncomment it if you want. Could also define FARDATA as
          * const if your compiler supports it. (SJT)
1264
#        define FARDATA FAR
1265
          */
1266
#  endif  /* __WIN32__, __FLAT__, __CYGWIN__ */
G
Guy Schalnat 已提交
1267
#endif   /* __BORLANDC__ */
G
Guy Schalnat 已提交
1268 1269


A
Andreas Dilger 已提交
1270
/* Suggest testing for specific compiler first before testing for
1271 1272 1273
 * FAR.  The Watcom compiler defines both __MEDIUM__ and M_I86MM,
 * making reliance oncertain keywords suspect. (SJT)
 */
G
Guy Schalnat 已提交
1274 1275

/* MSC Medium model */
1276 1277
#ifdef FAR
#  ifdef M_I86MM
1278 1279 1280
#    define USE_FAR_KEYWORD
#    define FARDATA FAR
#    include <dos.h>
G
Guy Schalnat 已提交
1281 1282 1283 1284 1285
#  endif
#endif

/* SJT: default case */
#ifndef FAR
1286
#  define FAR
G
Guy Schalnat 已提交
1287 1288
#endif

A
Andreas Dilger 已提交
1289
/* At this point FAR is always defined */
G
Guy Schalnat 已提交
1290
#ifndef FARDATA
1291
#  define FARDATA
G
Guy Schalnat 已提交
1292 1293
#endif

1294
/* Typedef for floating-point numbers that are converted
1295 1296
 * to fixed-point with a multiple of 100,000, e.g., int_gamma
 */
1297 1298
typedef png_int_32 png_fixed_point;

A
Andreas Dilger 已提交
1299
/* Add typedefs for pointers */
A
Andreas Dilger 已提交
1300
typedef void            FAR * png_voidp;
G
Guy Schalnat 已提交
1301 1302 1303 1304 1305 1306 1307
typedef png_byte        FAR * png_bytep;
typedef png_uint_32     FAR * png_uint_32p;
typedef png_int_32      FAR * png_int_32p;
typedef png_uint_16     FAR * png_uint_16p;
typedef png_int_16      FAR * png_int_16p;
typedef PNG_CONST char  FAR * png_const_charp;
typedef char            FAR * png_charp;
1308
typedef png_fixed_point FAR * png_fixed_point_p;
1309 1310

#ifndef PNG_NO_STDIO
1311
typedef FILE            * png_FILE_p;
1312 1313
#endif

1314
#ifdef PNG_FLOATING_POINT_SUPPORTED
A
Andreas Dilger 已提交
1315
typedef double          FAR * png_doublep;
1316
#endif
G
Guy Schalnat 已提交
1317

A
Andreas Dilger 已提交
1318
/* Pointers to pointers; i.e. arrays */
G
Guy Schalnat 已提交
1319 1320 1321 1322 1323 1324 1325
typedef png_byte        FAR * FAR * png_bytepp;
typedef png_uint_32     FAR * FAR * png_uint_32pp;
typedef png_int_32      FAR * FAR * png_int_32pp;
typedef png_uint_16     FAR * FAR * png_uint_16pp;
typedef png_int_16      FAR * FAR * png_int_16pp;
typedef PNG_CONST char  FAR * FAR * png_const_charpp;
typedef char            FAR * FAR * png_charpp;
1326
typedef png_fixed_point FAR * FAR * png_fixed_point_pp;
1327
#ifdef PNG_FLOATING_POINT_SUPPORTED
A
Andreas Dilger 已提交
1328
typedef double          FAR * FAR * png_doublepp;
1329
#endif
G
Guy Schalnat 已提交
1330

1331
/* Pointers to pointers to pointers; i.e., pointer to array */
A
Andreas Dilger 已提交
1332
typedef char            FAR * FAR * FAR * png_charppp;
G
Guy Schalnat 已提交
1333

1334 1335
#define PNG_USE_LOCAL_ARRAYS /* Not used in libpng, defined for legacy apps */

1336 1337
/* Users may want to use these so they are not private.  Any library
 * functions that are passed far data must be model-independent.
1338
 */
A
Andreas Dilger 已提交
1339

1340
/* Memory model/platform independent fns */
1341 1342
#ifndef PNG_ABORT
#  ifdef _WINDOWS_
1343
#    define PNG_ABORT() ExitProcess(0)
1344
#  else
1345
#    define PNG_ABORT() abort()
1346 1347 1348
#  endif
#endif

1349
#ifdef USE_FAR_KEYWORD
1350
/* Use this to make far-to-near assignments */
1351 1352 1353 1354
#  define CHECK   1
#  define NOCHECK 0
#  define CVT_PTR(ptr) (png_far_to_near(png_ptr,ptr,CHECK))
#  define CVT_PTR_NOCHECK(ptr) (png_far_to_near(png_ptr,ptr,NOCHECK))
1355 1356 1357 1358 1359
#  define png_strcpy  _fstrcpy
#  define png_strncpy _fstrncpy   /* Added to v 1.2.6 */
#  define png_strlen  _fstrlen
#  define png_memcmp  _fmemcmp    /* SJT: added */
#  define png_memcpy  _fmemcpy
1360
#  define png_memset  _fmemset
1361 1362
#  define png_sprintf sprintf
#else
1363
#  ifdef _WINDOWS_  /* Favor Windows over C runtime fns */
1364 1365 1366 1367 1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382
#    define CVT_PTR(ptr)         (ptr)
#    define CVT_PTR_NOCHECK(ptr) (ptr)
#    define png_strcpy  lstrcpyA
#    define png_strncpy lstrcpynA
#    define png_strlen  lstrlenA
#    define png_memcmp  memcmp
#    define png_memcpy  CopyMemory
#    define png_memset  memset
#    define png_sprintf wsprintfA
#  else
#    define CVT_PTR(ptr)         (ptr)
#    define CVT_PTR_NOCHECK(ptr) (ptr)
#    define png_strcpy  strcpy
#    define png_strncpy strncpy     /* Added to v 1.2.6 */
#    define png_strlen  strlen
#    define png_memcmp  memcmp      /* SJT: added */
#    define png_memcpy  memcpy
#    define png_memset  memset
#    define png_sprintf sprintf
1383 1384 1385 1386 1387 1388 1389 1390 1391 1392
#    ifndef PNG_NO_SNPRINTF
#      ifdef _MSC_VER
#        define png_snprintf _snprintf   /* Added to v 1.2.19 */
#        define png_snprintf2 _snprintf
#        define png_snprintf6 _snprintf
#      else
#        define png_snprintf snprintf   /* Added to v 1.2.19 */
#        define png_snprintf2 snprintf
#        define png_snprintf6 snprintf
#      endif
1393
#    else
1394 1395 1396 1397 1398 1399
      /* You don't have or don't want to use snprintf().  Caution: Using
       * sprintf instead of snprintf exposes your application to accidental
       * or malevolent buffer overflows.  If you don't have snprintf()
       * as a general rule you should provide one (you can get one from
       * Portable OpenSSH).
       */
1400 1401 1402 1403
#      define png_snprintf(s1,n,fmt,x1) sprintf(s1,fmt,x1)
#      define png_snprintf2(s1,n,fmt,x1,x2) sprintf(s1,fmt,x1,x2)
#      define png_snprintf6(s1,n,fmt,x1,x2,x3,x4,x5,x6) \
          sprintf(s1,fmt,x1,x2,x3,x4,x5,x6)
1404
#    endif
1405 1406 1407
#  endif
#endif

1408 1409 1410 1411 1412 1413 1414 1415 1416
/* png_alloc_size_t is guaranteed to be no smaller than png_size_t,
 * and no smaller than png_uint_32.  Casts from png_size_t or png_uint_32
 * to png_alloc_size_t are not necessary; in fact, it is recommended
 * not to use them at all so that the compiler can complain when something
 * turns out to be problematic.
 * Casts in the other direction (from png_alloc_size_t to png_size_t or
 * png_uint_32) should be explicitly applied; however, we do not expect
 * to encounter practical situations that require such conversions.
 */
1417
#if defined(__TURBOC__) && !defined(__FLAT__)
1418 1419
#  define png_mem_alloc farmalloc
#  define png_mem_free  farfree
1420
   typedef unsigned long png_alloc_size_t;
1421 1422
#else
#  if defined(_MSC_VER) && defined(MAXSEG_64K)
1423 1424
#    define png_mem_alloc(s) halloc(s, 1)
#    define png_mem_free     hfree
1425 1426 1427
     typedef unsigned long    png_alloc_size_t;
#  else
#    if defined(_WINDOWS_) && (!defined(INT_MAX) || INT_MAX <= 0x7ffffffeL)
1428 1429
#      define png_mem_alloc(s) HeapAlloc(GetProcessHeap(), 0, s)
#      define png_mem_free(p)  HeapFree(GetProcessHeap(), 0, p)
1430
       typedef DWORD            png_alloc_size_t;
1431
#    else
1432 1433
#      define png_mem_alloc malloc
#      define png_mem_free  free
1434
       typedef png_size_t    png_alloc_size_t;
1435 1436 1437 1438
#    endif
#  endif
#endif
/* End of memory model/platform independent support */
G
Guy Schalnat 已提交
1439

1440
/* Just a little check that someone hasn't tried to define something
1441
 * contradictory.
A
Andreas Dilger 已提交
1442
 */
1443
#if (PNG_ZBUF_SIZE > 65536L) && defined(PNG_MAX_MALLOC_64K)
1444
#  undef PNG_ZBUF_SIZE
1445
#  define PNG_ZBUF_SIZE 65536L
1446 1447 1448
#endif


1449 1450
/* Added at libpng-1.2.8 */
#endif /* PNG_VERSION_INFO_ONLY */
1451

G
Guy Schalnat 已提交
1452
#endif /* PNGCONF_H */