| 0 |      1 | <HTML>
 | 
|  |      2 | <HEAD>
 | 
|  |      3 | <TITLE>
 | 
|  |      4 | Modifying The TIFF Library
 | 
|  |      5 | </TITLE>
 | 
|  |      6 | </HEAD>
 | 
|  |      7 | <BODY BGCOLOR=white> 
 | 
|  |      8 | <FONT FACE="Arial, Helvetica, Sans">
 | 
|  |      9 | <H1>
 | 
|  |     10 | <IMG SRC=images/dave.gif WIDTH=107 HEIGHT=148 BORDER=2 ALIGN=left HSPACE=6>
 | 
|  |     11 | Modifying The TIFF Library
 | 
|  |     12 | </H1>
 | 
|  |     13 | 
 | 
|  |     14 | 
 | 
|  |     15 | <P>
 | 
|  |     16 | This chapter provides information about the internal structure of
 | 
|  |     17 | the library, how to control the configuration when building it, and
 | 
|  |     18 | how to add new support to the library.
 | 
|  |     19 | The following sections are found in this chapter:
 | 
|  |     20 | 
 | 
|  |     21 | <UL>
 | 
|  |     22 | <LI><A HREF=#Config>Library Configuration</A>
 | 
|  |     23 | <LI><A HREF=#Portability>General Portability Comments</A>
 | 
|  |     24 | <LI><A HREF="#Types">Types and Portability</A>
 | 
|  |     25 | <LI><A HREF="addingtags.html">Adding New Tags</A>
 | 
|  |     26 | <LI><A HREF=#AddingCODECS>Adding New Builtin Codecs</A>
 | 
|  |     27 | <LI><A HREF="addingtags.html#AddingCODECTags">Adding New Codec-private Tags</A>
 | 
|  |     28 | <LI><A HREF=#Other>Other Comments</A>
 | 
|  |     29 | </UL>
 | 
|  |     30 | 
 | 
|  |     31 | 
 | 
|  |     32 | <A NAME="Config"><P><HR WIDTH=65% ALIGN=right><H3>Library Configuration</H3></A>
 | 
|  |     33 | 
 | 
|  |     34 | Information on compiling the library is given
 | 
|  |     35 | <A HREF=build.html>elsewhere in this documentation</A>.
 | 
|  |     36 | This section describes the low-level mechanisms used to control
 | 
|  |     37 | the optional parts of the library that are configured at build
 | 
|  |     38 | time.   Control is based on
 | 
|  |     39 | a collection of C defines that are specified either on the compiler
 | 
|  |     40 | command line or in a configuration file such as <TT>port.h</TT>
 | 
|  |     41 | (as generated by the <TT>configure</TT> script for UNIX systems)
 | 
|  |     42 | or <B>tiffconf.h</B>.
 | 
|  |     43 | 
 | 
|  |     44 | <P>
 | 
|  |     45 | Configuration defines are split into three areas:
 | 
|  |     46 | <UL>
 | 
|  |     47 | <LI>those that control which compression schemes are
 | 
|  |     48 |     configured as part of the builtin codecs,
 | 
|  |     49 | <LI>those that control support for groups of tags that
 | 
|  |     50 |     are considered optional, and
 | 
|  |     51 | <LI>those that control operating system or machine-specific support.
 | 
|  |     52 | </UL>
 | 
|  |     53 | 
 | 
|  |     54 | <P>
 | 
|  |     55 | If the define <TT>COMPRESSION_SUPPORT</TT> is <STRONG>not defined</STRONG>
 | 
|  |     56 | then a default set of compression schemes is automatically
 | 
|  |     57 | configured:
 | 
|  |     58 | <UL>
 | 
|  |     59 | <LI>CCITT Group 3 and 4 algorithms (compression codes 2, 3, 4, and 32771),
 | 
|  |     60 | <LI>the Macintosh PackBits algorithm (compression 32773),
 | 
|  |     61 | <LI>a 4-bit run-length encoding scheme from ThunderScan (compression 32809),
 | 
|  |     62 | <LI>a 2-bit encoding scheme used by NeXT (compression 32766), and
 | 
|  |     63 | <LI>two experimental schemes intended for images with high dynamic range
 | 
|  |     64 | (compression 34676 and 34677).
 | 
|  |     65 | </UL>
 | 
|  |     66 | 
 | 
|  |     67 | <P>
 | 
|  |     68 | 
 | 
|  |     69 | To override the default compression behaviour define
 | 
|  |     70 | <TT>COMPRESSION_SUPPORT</TT> and then one or more additional defines
 | 
|  |     71 | to enable configuration of the appropriate codecs (see the table
 | 
|  |     72 | below); e.g.
 | 
|  |     73 | 
 | 
|  |     74 | <UL><PRE>
 | 
|  |     75 | #define	COMPRESSION_SUPPORT
 | 
|  |     76 | #define	CCITT_SUPPORT
 | 
|  |     77 | #define	PACKBITS_SUPPORT
 | 
|  |     78 | </PRE></UL>
 | 
|  |     79 | 
 | 
|  |     80 | Several other compression schemes are configured separately from
 | 
|  |     81 | the default set because they depend on ancillary software
 | 
|  |     82 | packages that are not distributed with <TT>libtiff</TT>.
 | 
|  |     83 | 
 | 
|  |     84 | <P>
 | 
|  |     85 | Support for JPEG compression is controlled by <TT>JPEG_SUPPORT</TT>.
 | 
|  |     86 | The JPEG codec that comes with <TT>libtiff</TT> is designed for
 | 
|  |     87 | use with release 5 or later of the Independent JPEG Group's freely
 | 
|  |     88 | available software distribution.
 | 
|  |     89 | This software can be retrieved from the directory
 | 
|  |     90 | <A HREF=ftp://ftp.uu.net/graphics/jpeg>ftp.uu.net:/graphics/jpeg/</A>.
 | 
|  |     91 | 
 | 
|  |     92 | 
 | 
|  |     93 | <P>
 | 
|  |     94 | <IMG SRC="images/info.gif" ALT="NOTE: " ALIGN=left HSPACE=8>
 | 
|  |     95 | <EM>Enabling JPEG support automatically enables support for
 | 
|  |     96 | the TIFF 6.0 colorimetry and YCbCr-related tags.</EM>
 | 
|  |     97 | 
 | 
|  |     98 | <P>
 | 
|  |     99 | Experimental support for the deflate algorithm is controlled by
 | 
|  |    100 | <TT>DEFLATE_SUPPORT</TT>.
 | 
|  |    101 | The deflate codec that comes with <TT>libtiff</TT> is designed
 | 
|  |    102 | for use with version 0.99 or later of the freely available
 | 
|  |    103 | <TT>libz</TT> library written by Jean-loup Gailly and Mark Adler.
 | 
|  |    104 | The data format used by this library is described
 | 
|  |    105 | in the files
 | 
|  |    106 | <A HREF=ftp://ftp.uu.net/pub/archiving/zip/doc/zlib-3.1.doc>zlib-3.1.doc</A>,
 | 
|  |    107 | and
 | 
|  |    108 | <A HREF=ftp://ftp.uu.net/pub/archiving/zip/doc/deflate-1.1.doc>deflate-1.1.doc</A>,
 | 
|  |    109 | available in the directory
 | 
|  |    110 | <A HREF=ftp://ftp.uu.net/pub/archiving/zip/doc>ftp.uu.net:/pub/archiving/zip/doc</A>.</EM>
 | 
|  |    111 | The library can be retried from the directory
 | 
|  |    112 | <A HREF=ftp://ftp.uu.net/pub/archiving/zip/zlib/>ftp.uu.net:/pub/archiving/zip/zlib/</A>
 | 
|  |    113 | (or try <A HREF=ftp://quest.jpl.nasa.gov/beta/zlib/>quest.jpl.nasa.gov:/beta/zlib/</A>).
 | 
|  |    114 | 
 | 
|  |    115 | <P>
 | 
|  |    116 | <IMG SRC="images/warning.gif" ALT="NOTE: " ALIGN=left HSPACE=8 VSPACE=6>
 | 
|  |    117 | <EM>The deflate algorithm is experimental.  Do not expect
 | 
|  |    118 | to exchange files using this compression scheme;
 | 
|  |    119 | it is included only because the similar, and more common,
 | 
|  |    120 | LZW algorithm is claimed to be governed by licensing restrictions.</EM>
 | 
|  |    121 | 
 | 
|  |    122 | 
 | 
|  |    123 | <P>
 | 
|  |    124 | By default <B>tiffconf.h</B> defines
 | 
|  |    125 | <TT>COLORIMETRY_SUPPORT</TT>, 
 | 
|  |    126 | <TT>YCBCR_SUPPORT</TT>,
 | 
|  |    127 | and 
 | 
|  |    128 | <TT>CMYK_SUPPORT</TT>.
 | 
|  |    129 | 
 | 
|  |    130 | <P>
 | 
|  |    131 | <TABLE BORDER CELLPADDING=3>
 | 
|  |    132 | 
 | 
|  |    133 | <TR><TH ALIGN=left>Define</TH><TH ALIGN=left>Description</TH></TR>
 | 
|  |    134 | 
 | 
|  |    135 | <TR>
 | 
|  |    136 | <TD VALIGN=top><TT>CCITT_SUPPORT</TT></TD>
 | 
|  |    137 | <TD>CCITT Group 3 and 4 algorithms (compression codes 2, 3, 4,
 | 
|  |    138 |     and 32771)</TD>
 | 
|  |    139 | </TR>
 | 
|  |    140 | 
 | 
|  |    141 | <TR>
 | 
|  |    142 | <TD VALIGN=top><TT>PACKBITS_SUPPORT</TT></TD>
 | 
|  |    143 | <TD>Macintosh PackBits algorithm (compression 32773)</TD>
 | 
|  |    144 | </TR>
 | 
|  |    145 | 
 | 
|  |    146 | <TR>
 | 
|  |    147 | <TD VALIGN=top><TT>LZW_SUPPORT</TT></TD>
 | 
|  |    148 | <TD>Lempel-Ziv & Welch (LZW) algorithm (compression 5)</TD>
 | 
|  |    149 | </TR>
 | 
|  |    150 | 
 | 
|  |    151 | <TR>
 | 
|  |    152 | <TD VALIGN=top><TT>THUNDER_SUPPORT</TT></TD>
 | 
|  |    153 | <TD>4-bit
 | 
|  |    154 | run-length encoding scheme from ThunderScan (compression 32809)</TD>
 | 
|  |    155 | </TR>
 | 
|  |    156 | 
 | 
|  |    157 | <TR>
 | 
|  |    158 | <TD VALIGN=top><TT>NEXT_SUPPORT</TT></TD>
 | 
|  |    159 | <TD>2-bit encoding scheme used by NeXT (compression 32766)</TD>
 | 
|  |    160 | </TR>
 | 
|  |    161 | 
 | 
|  |    162 | <TR>
 | 
|  |    163 | <TD VALIGN=top><TT>OJPEG_SUPPORT</TT></TD>
 | 
|  |    164 | <TD>obsolete JPEG scheme defined in the 6.0 spec (compression 6)</TD>
 | 
|  |    165 | </TR>
 | 
|  |    166 | 
 | 
|  |    167 | <TR>
 | 
|  |    168 | <TD VALIGN=top><TT>JPEG_SUPPORT</TT></TD>
 | 
|  |    169 | <TD>current JPEG scheme defined in TTN2 (compression 7)</TD>
 | 
|  |    170 | </TR>
 | 
|  |    171 | 
 | 
|  |    172 | <TR>
 | 
|  |    173 | <TD VALIGN=top><TT>ZIP_SUPPORT</TT></TD>
 | 
|  |    174 | <TD>experimental Deflate scheme (compression 32946)</TD>
 | 
|  |    175 | </TR>
 | 
|  |    176 | 
 | 
|  |    177 | <TR>
 | 
|  |    178 | <TD VALIGN=top><TT>PIXARLOG_SUPPORT</TT></TD>
 | 
|  |    179 | <TD>Pixar's compression scheme for high-resolution color images (compression 32909)</TD>
 | 
|  |    180 | </TR>
 | 
|  |    181 | 
 | 
|  |    182 | <TR>
 | 
|  |    183 | <TD VALIGN=top><TT>SGILOG_SUPPORT</TT></TD>
 | 
|  |    184 | <TD>SGI's compression scheme for high-resolution color images (compression 34676 and 34677)</TD>
 | 
|  |    185 | </TR>
 | 
|  |    186 | 
 | 
|  |    187 | <TR>
 | 
|  |    188 | <TD VALIGN=top><TT>COLORIMETRY_SUPPORT</TT></TD>
 | 
|  |    189 | <TD>support for the TIFF 6.0 colorimetry tags</TD>
 | 
|  |    190 | </TR>
 | 
|  |    191 | 
 | 
|  |    192 | <TR>
 | 
|  |    193 | <TD VALIGN=top><TT>YCBCR_SUPPORT</TT></TD>
 | 
|  |    194 | <TD>support for the TIFF 6.0 YCbCr-related tags</TD>
 | 
|  |    195 | </TR>
 | 
|  |    196 | 
 | 
|  |    197 | <TR>
 | 
|  |    198 | <TD VALIGN=top><TT>CMYK_SUPPORT</TT></TD>
 | 
|  |    199 | <TD>support for the TIFF 6.0 CMYK-related tags</TD>
 | 
|  |    200 | </TR>
 | 
|  |    201 | 
 | 
|  |    202 | <TR>
 | 
|  |    203 | <TD VALIGN=top><TT>ICC_SUPPORT</TT></TD>
 | 
|  |    204 | <TD>support for the ICC Profile tag; see
 | 
|  |    205 | <I>The ICC Profile Format Specification</I>,
 | 
|  |    206 | Annex B.3 "Embedding ICC Profiles in TIFF Files";
 | 
|  |    207 | available at
 | 
|  |    208 | <A HREF=http://www.color.org>http://www.color.org</A>
 | 
|  |    209 | </TD>
 | 
|  |    210 | </TR>
 | 
|  |    211 | 
 | 
|  |    212 | </TABLE>
 | 
|  |    213 | 
 | 
|  |    214 | 
 | 
|  |    215 | <A NAME="Portability"><P><HR WIDTH=65% ALIGN=right><H3>General Portability Comments</H3></A>
 | 
|  |    216 | 
 | 
|  |    217 | This software is developed on Silicon Graphics UNIX
 | 
|  |    218 | systems (big-endian, MIPS CPU, 32-bit ints,
 | 
|  |    219 | IEEE floating point). 
 | 
|  |    220 | The <TT>configure</TT> shell script generates the appropriate
 | 
|  |    221 | include files and make files for UNIX systems.
 | 
|  |    222 | Makefiles exist for non-UNIX platforms that the
 | 
|  |    223 | code runs on -- this work has mostly been done by other people.
 | 
|  |    224 | 
 | 
|  |    225 | <P>
 | 
|  |    226 | In general, the code is guaranteed to work only on SGI machines.
 | 
|  |    227 | In practice it is highly portable to any 32-bit or 64-bit system and much
 | 
|  |    228 | work has been done to insure portability to 16-bit systems.
 | 
|  |    229 | If you encounter portability problems please return fixes so
 | 
|  |    230 | that future distributions can be improved.
 | 
|  |    231 | 
 | 
|  |    232 | <P>
 | 
|  |    233 | The software is written to assume an ANSI C compilation environment.
 | 
|  |    234 | If your compiler does not support ANSI function prototypes, <TT>const</TT>,
 | 
|  |    235 | and <TT><stdarg.h></TT> then you will have to make modifications to the
 | 
|  |    236 | software.  In the past I have tried to support compilers without <TT>const</TT>
 | 
|  |    237 | and systems without <TT><stdarg.h></TT>, but I am
 | 
|  |    238 | <EM>no longer interested in these
 | 
|  |    239 | antiquated environments</EM>.  With the general availability of
 | 
|  |    240 | the freely available GCC compiler, I
 | 
|  |    241 | see no reason to incorporate modifications to the software for these
 | 
|  |    242 | purposes.
 | 
|  |    243 | 
 | 
|  |    244 | <P>
 | 
|  |    245 | An effort has been made to isolate as many of the
 | 
|  |    246 | operating system-dependencies
 | 
|  |    247 | as possible in two files: <B>tiffcomp.h</B> and
 | 
|  |    248 | <B>libtiff/tif_<os>.c</B>.  The latter file contains
 | 
|  |    249 | operating system-specific routines to do I/O and I/O-related operations.
 | 
|  |    250 | The UNIX (<B>tif_unix.c</B>),
 | 
|  |    251 | Macintosh (<B>tif_apple.c</B>),
 | 
|  |    252 | and VMS (<B>tif_vms.c</B>)
 | 
|  |    253 | code has had the most use;
 | 
|  |    254 | the MS/DOS support (<B>tif_msdos.c</B>) assumes
 | 
|  |    255 | some level of UNIX system call emulation (i.e.
 | 
|  |    256 | <TT>open</TT>,
 | 
|  |    257 | <TT>read</TT>,
 | 
|  |    258 | <TT>write</TT>,
 | 
|  |    259 | <TT>fstat</TT>,
 | 
|  |    260 | <TT>malloc</TT>,
 | 
|  |    261 | <TT>free</TT>).
 | 
|  |    262 | 
 | 
|  |    263 | <P>
 | 
|  |    264 | Native CPU byte order is determined on the fly by
 | 
|  |    265 | the library and does not need to be specified.
 | 
|  |    266 | The <TT>HOST_FILLORDER</TT> and <TT>HOST_BIGENDIAN</TT>
 | 
|  |    267 | definitions are not currently used, but may be employed by
 | 
|  |    268 | codecs for optimization purposes.
 | 
|  |    269 | 
 | 
|  |    270 | <P>
 | 
|  |    271 | The following defines control general portability:
 | 
|  |    272 | 
 | 
|  |    273 | <P>
 | 
|  |    274 | <TABLE BORDER CELLPADDING=3 WIDTH=100%>
 | 
|  |    275 | 
 | 
|  |    276 | <TR>
 | 
|  |    277 | <TD VALIGN=top><TT>BSDTYPES</TT></TD>
 | 
|  |    278 | <TD>Define this if your system does NOT define the
 | 
|  |    279 | 		usual BSD typedefs: <TT>u_char</TT>,
 | 
|  |    280 | 		<TT>u_short</TT>, <TT>u_int</TT>, <TT>u_long</TT>.</TD>
 | 
|  |    281 | </TR>
 | 
|  |    282 | 
 | 
|  |    283 | <TR>
 | 
|  |    284 | <TD VALIGN=top><TT>HAVE_IEEEFP</TT></TD>
 | 
|  |    285 | <TD>Define this as 0 or 1 according to the floating point
 | 
|  |    286 | 		format suported by the machine.  If your machine does
 | 
|  |    287 | 		not support IEEE floating point then you will need to
 | 
|  |    288 | 		add support to tif_machdep.c to convert between the
 | 
|  |    289 | 		native format and IEEE format.</TD>
 | 
|  |    290 | </TR>
 | 
|  |    291 | 
 | 
|  |    292 | <TR>
 | 
|  |    293 | <TD VALIGN=top><TT>HAVE_MMAP</TT></TD>
 | 
|  |    294 | <TD>Define this if there is <I>mmap-style</I> support for
 | 
|  |    295 | mapping files into memory (used only to read data).</TD>
 | 
|  |    296 | </TR>
 | 
|  |    297 | 
 | 
|  |    298 | <TR>
 | 
|  |    299 | <TD VALIGN=top><TT>HOST_FILLORDER</TT></TD>
 | 
|  |    300 | <TD>Define the native CPU bit order: one of <TT>FILLORDER_MSB2LSB</TT>
 | 
|  |    301 |  or <TT>FILLORDER_LSB2MSB</TT></TD>
 | 
|  |    302 | </TR>
 | 
|  |    303 | 
 | 
|  |    304 | <TR>
 | 
|  |    305 | <TD VALIGN=top><TT>HOST_BIGENDIAN</TT></TD>
 | 
|  |    306 | <TD>Define the native CPU byte order: 1 if big-endian (Motorola)
 | 
|  |    307 |  or 0 if little-endian (Intel); this may be used
 | 
|  |    308 |  in codecs to optimize code</TD>
 | 
|  |    309 | </TR>
 | 
|  |    310 | </TABLE>
 | 
|  |    311 | 
 | 
|  |    312 | <P>
 | 
|  |    313 | On UNIX systems <TT>HAVE_MMAP</TT> is defined through the running of
 | 
|  |    314 | the <TT>configure</TT> script; otherwise support for memory-mapped
 | 
|  |    315 | files is disabled.
 | 
|  |    316 | Note that <B>tiffcomp.h</B> defines <TT>HAVE_IEEEFP</TT> to be
 | 
|  |    317 | 1 (<TT>BSDTYPES</TT> is not defined).
 | 
|  |    318 | 
 | 
|  |    319 | 
 | 
|  |    320 | <A NAME="Types"><P><HR WIDTH=65% ALIGN=right><H3>Types and Portability</H3></A>
 | 
|  |    321 | 
 | 
|  |    322 | The software makes extensive use of C typedefs to promote portability.
 | 
|  |    323 | Two sets of typedefs are used, one for communication with clients
 | 
|  |    324 | of the library and one for internal data structures and parsing of the
 | 
|  |    325 | TIFF format.  There are interactions between these two to be careful
 | 
|  |    326 | of, but for the most part you should be able to deal with portability
 | 
|  |    327 | purely by fiddling with the following machine-dependent typedefs:
 | 
|  |    328 | 
 | 
|  |    329 | 
 | 
|  |    330 | <P>
 | 
|  |    331 | <TABLE BORDER CELLPADDING=3 WIDTH=100%>
 | 
|  |    332 | 
 | 
|  |    333 | <TR>
 | 
|  |    334 | <TD>uint8</TD>
 | 
|  |    335 | <TD>8-bit unsigned integer</TD>
 | 
|  |    336 | <TD>tiff.h</TD>
 | 
|  |    337 | </TR>
 | 
|  |    338 | 
 | 
|  |    339 | <TR>
 | 
|  |    340 | <TD>int8</TD>
 | 
|  |    341 | <TD>8-bit signed integer</TD>
 | 
|  |    342 | <TD>tiff.h</TD>
 | 
|  |    343 | </TR>
 | 
|  |    344 | 
 | 
|  |    345 | <TR>
 | 
|  |    346 | <TD>uint16</TD>
 | 
|  |    347 | <TD>16-bit unsigned integer</TD>
 | 
|  |    348 | <TD>tiff.h</TD>
 | 
|  |    349 | </TR>
 | 
|  |    350 | 
 | 
|  |    351 | <TR>
 | 
|  |    352 | <TD>int16</TD>
 | 
|  |    353 | <TD>16-bit signed integer</TD>
 | 
|  |    354 | <TD>tiff.h</TD>
 | 
|  |    355 | </TR>
 | 
|  |    356 | 
 | 
|  |    357 | <TR>
 | 
|  |    358 | <TD>uint32</TD>
 | 
|  |    359 | <TD>32-bit unsigned integer</TD>
 | 
|  |    360 | <TD>tiff.h</TD>
 | 
|  |    361 | </TR>
 | 
|  |    362 | 
 | 
|  |    363 | <TR>
 | 
|  |    364 | <TD>int32</TD>
 | 
|  |    365 | <TD>32-bit signed integer</TD>
 | 
|  |    366 | <TD>tiff.h</TD>
 | 
|  |    367 | </TR>
 | 
|  |    368 | 
 | 
|  |    369 | <TR>
 | 
|  |    370 | <TD>dblparam_t</TD>
 | 
|  |    371 | <TD>promoted type for floats</TD>
 | 
|  |    372 | <TD>tiffcomp.h</TD>
 | 
|  |    373 | </TR>
 | 
|  |    374 | 
 | 
|  |    375 | </TABLE>
 | 
|  |    376 | 
 | 
|  |    377 | <P>
 | 
|  |    378 | (to clarify <TT>dblparam_t</TT>, it is the type that float parameters are
 | 
|  |    379 | promoted to when passed by value in a function call.)
 | 
|  |    380 | 
 | 
|  |    381 | <P>
 | 
|  |    382 | The following typedefs are used throughout the library and interfaces
 | 
|  |    383 | to refer to certain objects whose size is dependent on the TIFF image
 | 
|  |    384 | structure:
 | 
|  |    385 | 
 | 
|  |    386 | 
 | 
|  |    387 | <P>
 | 
|  |    388 | <TABLE BORDER CELLPADDING=3 WIDTH=100%>
 | 
|  |    389 | 
 | 
|  |    390 | <TR>
 | 
|  |    391 | <TD WIDTH=25%>typedef unsigned int ttag_t;</TD>	<TD>directory tag</TD>
 | 
|  |    392 | </TR>
 | 
|  |    393 | 
 | 
|  |    394 | <TR>
 | 
|  |    395 | <TD>typedef uint16 tdir_t;</TD>		<TD>directory index</TD>
 | 
|  |    396 | </TR>
 | 
|  |    397 | 
 | 
|  |    398 | <TR>
 | 
|  |    399 | <TD>typedef uint16 tsample_t;</TD>	<TD>sample number</TD>
 | 
|  |    400 | </TR>
 | 
|  |    401 | 
 | 
|  |    402 | <TR>
 | 
|  |    403 | <TD>typedef uint32 tstrip_t;</TD>	<TD>strip number</TD>
 | 
|  |    404 | </TR>
 | 
|  |    405 | 
 | 
|  |    406 | <TR>
 | 
|  |    407 | <TD>typedef uint32 ttile_t;</TD>		<TD>tile number</TD>
 | 
|  |    408 | </TR>
 | 
|  |    409 | 
 | 
|  |    410 | <TR>
 | 
|  |    411 | <TD>typedef int32 tsize_t;</TD>		<TD>i/o size in bytes</TD>
 | 
|  |    412 | </TR>
 | 
|  |    413 | 
 | 
|  |    414 | <TR>
 | 
|  |    415 | <TD>typedef void* tdata_t;</TD>		<TD>image data ref</TD>
 | 
|  |    416 | </TR>
 | 
|  |    417 | 
 | 
|  |    418 | <TR>
 | 
|  |    419 | <TD>typedef void* thandle_t;</TD>	<TD>client data handle</TD>
 | 
|  |    420 | </TR>
 | 
|  |    421 | 
 | 
|  |    422 | <TR>
 | 
|  |    423 | <TD>typedef int32 toff_t;</TD>		<TD>file offset (should be off_t)</TD>
 | 
|  |    424 | </TR>
 | 
|  |    425 | 
 | 
|  |    426 | <TR>
 | 
|  |    427 | <TD>typedef unsigned char* tidata_t;</TD> <TD>internal image data</TD>
 | 
|  |    428 | </TR>
 | 
|  |    429 | 
 | 
|  |    430 | </TABLE>
 | 
|  |    431 | 
 | 
|  |    432 | <P>
 | 
|  |    433 | Note that <TT>tstrip_t</TT>, <TT>ttile_t</TT>, and <TT>tsize_t</TT>
 | 
|  |    434 | are constrained to be
 | 
|  |    435 | no more than 32-bit quantities by 32-bit fields they are stored
 | 
|  |    436 | in in the TIFF image.  Likewise <TT>tsample_t</TT> is limited by the 16-bit
 | 
|  |    437 | field used to store the <TT>SamplesPerPixel</TT> tag.  <TT>tdir_t</TT>
 | 
|  |    438 | constrains
 | 
|  |    439 | the maximum number of IFDs that may appear in an image and may
 | 
|  |    440 | be an arbitrary size (without penalty).  <TT>ttag_t</TT> must be either
 | 
|  |    441 | <TT>int</TT>, <TT>unsigned int</TT>, pointer, or <TT>double</TT>
 | 
|  |    442 | because the library uses a varargs
 | 
|  |    443 | interface and ANSI C restricts the type of the parameter before an
 | 
|  |    444 | ellipsis to be a promoted type.  <TT>toff_t</TT> is defined as
 | 
|  |    445 | <TT>int32</TT> because
 | 
|  |    446 | TIFF file offsets are (unsigned) 32-bit quantities.  A signed
 | 
|  |    447 | value is used because some interfaces return -1 on error (sigh).
 | 
|  |    448 | Finally, note that <TT>tidata_t</TT> is used internally to the library to
 | 
|  |    449 | manipulate internal data.  User-specified data references are
 | 
|  |    450 | passed as opaque handles and only cast at the lowest layers where
 | 
|  |    451 | their type is presumed.
 | 
|  |    452 | 
 | 
|  |    453 | 
 | 
|  |    454 | <P><HR WIDTH=65% ALIGN=right><H3>General Comments</H3></A>
 | 
|  |    455 | 
 | 
|  |    456 | The library is designed to hide as much of the details of TIFF from
 | 
|  |    457 | applications as
 | 
|  |    458 | possible.  In particular, TIFF directories are read in their entirety
 | 
|  |    459 | into an internal format.  Only the tags known by the library are
 | 
|  |    460 | available to a user and certain tag data may be maintained that a user
 | 
|  |    461 | does not care about (e.g. transfer function tables).
 | 
|  |    462 | 
 | 
|  |    463 | <A NAME=AddingCODECS><P><HR WIDTH=65% ALIGN=right><H3>Adding New Builtin Codecs</H3></A>
 | 
|  |    464 | 
 | 
|  |    465 | To add builtin support for a new compression algorithm, you can either
 | 
|  |    466 | use the "tag-extension" trick to override the handling of the
 | 
|  |    467 | TIFF Compression tag (see <A HREF=addingtags.html>Adding New Tags</A>), 
 | 
|  |    468 | or do the following to add support directly to the core library:
 | 
|  |    469 | 
 | 
|  |    470 | <OL>
 | 
|  |    471 | <LI>Define the tag value in <B>tiff.h</B>.
 | 
|  |    472 | <LI>Edit the file <B>tif_codec.c</B> to add an entry to the
 | 
|  |    473 |    _TIFFBuiltinCODECS array (see how other algorithms are handled).
 | 
|  |    474 | <LI>Add the appropriate function prototype declaration to
 | 
|  |    475 |    <B>tiffiop.h</B> (close to the bottom).
 | 
|  |    476 | <LI>Create a file with the compression scheme code, by convention files
 | 
|  |    477 |    are named <B>tif_*.c</B> (except perhaps on some systems where the
 | 
|  |    478 |    tif_ prefix pushes some filenames over 14 chars.
 | 
|  |    479 | <LI>Edit <B>Makefile.in</B> (and any other Makefiles)
 | 
|  |    480 |    to include the new source file.
 | 
|  |    481 | </OL>
 | 
|  |    482 | 
 | 
|  |    483 | <P>
 | 
|  |    484 | A codec, say <TT>foo</TT>, can have many different entry points:
 | 
|  |    485 | 
 | 
|  |    486 | <PRE>
 | 
|  |    487 | TIFFInitfoo(tif, scheme)/* initialize scheme and setup entry points in tif */
 | 
|  |    488 | fooSetupDecode(tif)	/* called once per IFD after tags has been frozen */
 | 
|  |    489 | fooPreDecode(tif, sample)/* called once per strip/tile, after data is read,
 | 
|  |    490 | 			    but before the first row is decoded */
 | 
|  |    491 | fooDecode*(tif, bp, cc, sample)/* decode cc bytes of data into the buffer */
 | 
|  |    492 |     fooDecodeRow(...)	/* called to decode a single scanline */
 | 
|  |    493 |     fooDecodeStrip(...)	/* called to decode an entire strip */
 | 
|  |    494 |     fooDecodeTile(...)	/* called to decode an entire tile */
 | 
|  |    495 | fooSetupEncode(tif)	/* called once per IFD after tags has been frozen */
 | 
|  |    496 | fooPreEncode(tif, sample)/* called once per strip/tile, before the first row in
 | 
|  |    497 | 			    a strip/tile is encoded */
 | 
|  |    498 | fooEncode*(tif, bp, cc, sample)/* encode cc bytes of user data (bp) */
 | 
|  |    499 |     fooEncodeRow(...)	/* called to decode a single scanline */
 | 
|  |    500 |     fooEncodeStrip(...)	/* called to decode an entire strip */
 | 
|  |    501 |     fooEncodeTile(...)	/* called to decode an entire tile */
 | 
|  |    502 | fooPostEncode(tif)	/* called once per strip/tile, just before data is written */
 | 
|  |    503 | fooSeek(tif, row)	/* seek forwards row scanlines from the beginning
 | 
|  |    504 | 			   of a strip (row will always be >0 and <rows/strip */
 | 
|  |    505 | fooCleanup(tif)		/* called when compression scheme is replaced by user */
 | 
|  |    506 | </PRE>
 | 
|  |    507 | 
 | 
|  |    508 | <P>
 | 
|  |    509 | Note that the encoding and decoding variants are only needed when
 | 
|  |    510 | a compression algorithm is dependent on the structure of the data.
 | 
|  |    511 | For example, Group 3 2D encoding and decoding maintains a reference
 | 
|  |    512 | scanline.  The sample parameter identifies which sample is to be
 | 
|  |    513 | encoded or decoded if the image is organized with <TT>PlanarConfig</TT>=2
 | 
|  |    514 | (separate planes).  This is important for algorithms such as JPEG.
 | 
|  |    515 | If <TT>PlanarConfig</TT>=1 (interleaved), then sample will always be 0.
 | 
|  |    516 | 
 | 
|  |    517 | <A NAME=Other><P><HR WIDTH=65% ALIGN=right><H3>Other Comments</H3></A>
 | 
|  |    518 | 
 | 
|  |    519 | The library handles most I/O buffering.  There are two data buffers
 | 
|  |    520 | when decoding data: a raw data buffer that holds all the data in a
 | 
|  |    521 | strip, and a user-supplied scanline buffer that compression schemes
 | 
|  |    522 | place decoded data into.  When encoding data the data in the
 | 
|  |    523 | user-supplied scanline buffer is encoded into the raw data buffer (from
 | 
|  |    524 | where it is written).  Decoding routines should never have to explicitly
 | 
|  |    525 | read data -- a full strip/tile's worth of raw data is read and scanlines
 | 
|  |    526 | never cross strip boundaries.  Encoding routines must be cognizant of
 | 
|  |    527 | the raw data buffer size and call <TT>TIFFFlushData1()</TT> when necessary.
 | 
|  |    528 | Note that any pending data is automatically flushed when a new strip/tile is
 | 
|  |    529 | started, so there's no need do that in the tif_postencode routine (if
 | 
|  |    530 | one exists).  Bit order is automatically handled by the library when
 | 
|  |    531 | a raw strip or tile is filled.  If the decoded samples are interpreted
 | 
|  |    532 | by the decoding routine before they are passed back to the user, then
 | 
|  |    533 | the decoding logic must handle byte-swapping by overriding the
 | 
|  |    534 | <TT>tif_postdecode</TT>
 | 
|  |    535 | routine (set it to <TT>TIFFNoPostDecode</TT>) and doing the required work
 | 
|  |    536 | internally.  For an example of doing this look at the horizontal
 | 
|  |    537 | differencing code in the routines in <B>tif_predict.c</B>.
 | 
|  |    538 | 
 | 
|  |    539 | <P>
 | 
|  |    540 | The variables <TT>tif_rawcc</TT>, <TT>tif_rawdata</TT>, and
 | 
|  |    541 | <TT>tif_rawcp</TT> in a <TT>TIFF</TT> structure
 | 
|  |    542 | are associated with the raw data buffer.  <TT>tif_rawcc</TT> must be non-zero
 | 
|  |    543 | for the library to automatically flush data.  The variable
 | 
|  |    544 | <TT>tif_scanlinesize</TT> is the size a user's scanline buffer should be.  The
 | 
|  |    545 | variable <TT>tif_tilesize</TT> is the size of a tile for tiled images.  This
 | 
|  |    546 | should not normally be used by compression routines, except where it
 | 
|  |    547 | relates to the compression algorithm.  That is, the <TT>cc</TT> parameter to the
 | 
|  |    548 | <TT>tif_decode*</TT> and <TT>tif_encode*</TT>
 | 
|  |    549 | routines should be used in terminating
 | 
|  |    550 | decompression/compression.  This ensures these routines can be used,
 | 
|  |    551 | for example, to decode/encode entire strips of data.
 | 
|  |    552 | 
 | 
|  |    553 | <P>
 | 
|  |    554 | In general, if you have a new compression algorithm to add, work from
 | 
|  |    555 | the code for an existing routine.  In particular,
 | 
|  |    556 | <B>tif_dumpmode.c</B>
 | 
|  |    557 | has the trivial code for the "nil" compression scheme,
 | 
|  |    558 | <B>tif_packbits.c</B> is a
 | 
|  |    559 | simple byte-oriented scheme that has to watch out for buffer
 | 
|  |    560 | boundaries, and <B>tif_lzw.c</B> has the LZW scheme that has the most
 | 
|  |    561 | complexity -- it tracks the buffer boundary at a bit level.
 | 
|  |    562 | Of course, using a private compression scheme (or private tags) limits
 | 
|  |    563 | the portability of your TIFF files.
 | 
|  |    564 | 
 | 
|  |    565 | <P>
 | 
|  |    566 | <HR>
 | 
|  |    567 | 
 | 
|  |    568 | Last updated: $Date: 2004/09/10 14:47:31 $
 | 
|  |    569 | 
 | 
|  |    570 | </BODY>
 | 
|  |    571 | 
 | 
|  |    572 | </HTML>
 |