]>
Commit | Line | Data |
---|---|---|
1 | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> | |
2 | <html> | |
3 | <head> | |
4 | <meta name="generator" content= | |
5 | "HTML Tidy for Solaris (vers 12 April 2005), see www.w3.org"> | |
6 | <title>Building the TIFF Software Distribution</title> | |
7 | </head> | |
8 | <body bgcolor="white"> | |
9 | <h1><font face="Arial, Helvetica, Sans"><img src= | |
10 | "images/cramps.gif" width="159" height="203" align="left" border= | |
11 | "1" hspace="6"> Building the Software Distribution</font></h1> | |
12 | <ul> | |
13 | <li><a href="#UNIX">Building on a UNIX system</a>.</li> | |
14 | <li><a href="#MacMPW">Building on a Macintosh system with | |
15 | MPW</a>.</li> | |
16 | <li><a href="#MacCW">Building on a Macintosh system with | |
17 | CodeWarrior</a>.</li> | |
18 | <li><a href="#PC">Building on an MS-DOS or Windows system</a>.</li> | |
19 | <li><a href="#DJGPP">Building on MS-DOS with the DJGPP v2 | |
20 | compiler</a>.</li> | |
21 | <li><a href="#VMS">Building on a VMS system</a>.</li> | |
22 | <li><a href="#Acorn">Building on an Acorn RISC OS system</a>.</li> | |
23 | <li><a href="#Other">Building the Software on Other | |
24 | Systems</a></li> | |
25 | </ul> | |
26 | <br clear="left"> | |
27 | This chapter contains step-by-step instructions on how to configure | |
28 | and build the TIFF software distribution. The software is most | |
29 | easily built on a UNIX system, but with a little bit of work it can | |
30 | easily be built and used on other non-UNIX platforms. <a name= | |
31 | "UNIX" id="UNIX"></a> | |
32 | <hr> | |
33 | <h2>Building on a UNIX System</h2> | |
34 | To build the software on a UNIX system you need to first run the | |
35 | configure shell script that is located in the top level of the | |
36 | source directory. This script probes the target system for | |
37 | necessary tools and functions and constructs a build environment in | |
38 | which the software may be compiled. Once configuration is done, you | |
39 | simply run <tt>make</tt> (or <tt>gmake</tt>) to build the software | |
40 | and then <tt>make install</tt> to do the installation; for example: | |
41 | <div style="margin-left: 2em"> | |
42 | <pre> | |
43 | hyla% <b>cd tiff-v3.4beta099</b> | |
44 | hyla% <b>./configure</b> | |
45 | <i>...lots of messages...</i> | |
46 | hyla% <b>make</b> | |
47 | <i>...lots of messages...</i> | |
48 | hyla# <b>make install</b> | |
49 | </pre></div> | |
50 | Supplied makefiles are depend on GNU <tt>make</tt> utility, so you | |
51 | will need the one. Depending on your installation <b>make</b> | |
52 | command may invoke standard system <tt>make</tt> and <b>gmake</b> | |
53 | invoke GNU make. In this case you should use former. If you don't | |
54 | have <tt>make</tt> at all, but only <tt>gmake</tt>, you should | |
55 | export environment variable <tt>MAKE=gmake</tt> before | |
56 | <b>./configure</b>. | |
57 | <p>In general, the software is designed such that the following | |
58 | should be ``<i>make-able</i>'' in each directory:</p> | |
59 | <div style="margin-left: 2em"> | |
60 | <pre> | |
61 | make [all] build stuff | |
62 | make install build&install stuff | |
63 | make clean remove .o files, executables and cruft | |
64 | make distclean remove everything, that can be recreated | |
65 | </pre></div> | |
66 | Note that after running "<tt>make distclean</tt>" the | |
67 | <tt>configure</tt> script must be run again to create the Makefiles | |
68 | and other make-related files. <a name="BuildTrees" id= | |
69 | "BuildTrees"></a> | |
70 | <hr width="65%" align="right"> | |
71 | <h3>Build Trees</h3> | |
72 | There are two schemes for configuring and building the software. If | |
73 | you intend to build the software for only one target system, you | |
74 | can configure the software so that it is built in the same | |
75 | directories as the source code. | |
76 | <div style="margin-left: 2em"> | |
77 | <pre> | |
78 | hyla% <b>cd tiff-v3.4beta099</b> | |
79 | hyla% <b>ls</b> | |
80 | COPYRIGHT VERSION config.sub dist man | |
81 | Makefile.in config.guess configure html port | |
82 | README config.site contrib libtiff tools | |
83 | hyla% <b>./configure</b> | |
84 | </pre></div> | |
85 | <p>Otherwise, you can configure a build tree that is parallel to | |
86 | the source tree hierarchy but which contains only configured files | |
87 | and files created during the build procedure.</p> | |
88 | <div style="margin-left: 2em"> | |
89 | <pre> | |
90 | hyla% <b>cd tiff-v3.4beta099</b> | |
91 | hyla% <b>mkdir obj obj/mycpu</b> | |
92 | hyla% <b>cd obj/mycpu</b> | |
93 | hyla% <b>../../configure</b> | |
94 | </pre></div> | |
95 | This second scheme is useful for: | |
96 | <ul> | |
97 | <li>building multiple targets from a single source tree</li> | |
98 | <li>building from a read-only source tree (e.g. if you receive the | |
99 | distribution on CD-ROM)</li> | |
100 | </ul> | |
101 | <a name="ConfigOptions" id="ConfigOptions"></a> | |
102 | <hr width="65%" align="right"> | |
103 | <h3>Configuration Options</h3> | |
104 | The configuration process is critical to the proper compilation, | |
105 | installation, and operation of the software. The configure script | |
106 | runs a series of tests to decide whether or not the target system | |
107 | supports required functionality and, if it does not, whether it can | |
108 | emulate or workaround the missing functions. This procedure is | |
109 | fairly complicated and, due to the nonstandard nature of most UNIX | |
110 | systems, prone to error. The first time that you configure the | |
111 | software for use you should check the output from the configure | |
112 | script and look for anything that does not make sense for your | |
113 | system. | |
114 | <p>A second function of the configure script is to set the default | |
115 | configuration parameters for the software. Of particular note are | |
116 | the directories where the software is to be installed. By default | |
117 | the software is installed in the <b>/usr/local</b> hierarchy. To | |
118 | change this behaviour the appropriate parameters can be specified | |
119 | on the command line to configure. Run <b>./configure --help</b> to | |
120 | get a list of possible options. Installation related options are | |
121 | shown below.</p> | |
122 | <pre> | |
123 | <tt> | |
124 | Installation directories: | |
125 | --prefix=PREFIX install architecture-independent files in PREFIX | |
126 | [/usr/local] | |
127 | --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX | |
128 | [PREFIX] | |
129 | ||
130 | By default, `make install' will install all the files in | |
131 | `/usr/local/bin', `/usr/local/lib' etc. You can specify | |
132 | an installation prefix other than `/usr/local' using `--prefix', | |
133 | for instance `--prefix=$HOME'. | |
134 | ||
135 | For better control, use the options below. | |
136 | ||
137 | Fine tuning of the installation directories: | |
138 | --bindir=DIR user executables [EPREFIX/bin] | |
139 | --sbindir=DIR system admin executables [EPREFIX/sbin] | |
140 | --libexecdir=DIR program executables [EPREFIX/libexec] | |
141 | --datadir=DIR read-only architecture-independent data [PREFIX/share] | |
142 | --sysconfdir=DIR read-only single-machine data [PREFIX/etc] | |
143 | --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] | |
144 | --localstatedir=DIR modifiable single-machine data [PREFIX/var] | |
145 | --libdir=DIR object code libraries [EPREFIX/lib] | |
146 | --includedir=DIR C header files [PREFIX/include] | |
147 | --oldincludedir=DIR C header files for non-gcc [/usr/include] | |
148 | --infodir=DIR info documentation [PREFIX/info] | |
149 | --mandir=DIR man documentation [PREFIX/man] | |
150 | ||
151 | Program names: | |
152 | --program-prefix=PREFIX prepend PREFIX to installed program names | |
153 | --program-suffix=SUFFIX append SUFFIX to installed program names | |
154 | --program-transform-name=PROGRAM run sed PROGRAM on installed program names | |
155 | </tt> | |
156 | </pre> | |
157 | <a name="Packages" id="Packages"></a> | |
158 | <hr width="65%" align="right"> | |
159 | <h3>Configuring Optional Packages/Support</h3> | |
160 | The TIFF software comes with several packages that are installed | |
161 | only as needed, or only if specifically configured at the time the | |
162 | configure script is run. Packages can be configured via the | |
163 | <b>configure</b> script commandline parameters. | |
164 | <dl> | |
165 | <dt><i>Static/Shared Objects Support</i></dt> | |
166 | <dd><tt>--enable-shared[=PKGS] build shared | |
167 | libraries [default=yes]<br> | |
168 | --enable-static[=PKGS] build static | |
169 | libraries [default=yes]</tt> | |
170 | <p>These options control whether or not to configure the software | |
171 | to build a shared and static binaries for the TIFF library. Use of | |
172 | shared libraries can significantly reduce the disk space needed for | |
173 | users of the TIFF software. If shared libarries are not used then | |
174 | the code is statically linked into each application that uses it. | |
175 | By default both types of binaries is configured.</p> | |
176 | <p><tt>--enable-rpath Enable runtime linker | |
177 | paths (-R libtool option)</tt></p> | |
178 | <p>Add library directories (see other options below) to the TIFF | |
179 | library run-time linker path.</p> | |
180 | </dd> | |
181 | <dt><i>JPEG Support</i></dt> | |
182 | <dd><tt>--disable-jpeg disable IJG JPEG | |
183 | library usage (required for JPEG compression, enabled by default) | |
184 | --with-jpeg-include-dir=DIR location of IJG | |
185 | JPEG library headers | |
186 | --with-jpeg-lib-dir=DIR location of IJG JPEG | |
187 | library binary)</tt></dd> | |
188 | <dd>The <tt>JPEG</tt> package enables support for the handling of | |
189 | TIFF images with JPEG-encoded data. Support for JPEG-encoded data | |
190 | requires the Independent JPEG Group (IJG) <tt>libjpeg</tt> | |
191 | distribution; this software is available at <a href= | |
192 | "ftp://ftp.uu.net/graphics/jpeg/">ftp.uu.net:/graphics/jpeg/</a>. | |
193 | <b>configure</b> script automatically tries to search the working | |
194 | IJG JPEG installation. If it fails to find library, JPEG support | |
195 | will be automatically disabled.If you want specify the exact paths | |
196 | to library binary and headers, use above switches for that.</dd> | |
197 | <dt><i>ZIP Support</i></dt> | |
198 | <dd>The <tt>ZIP</tt> support enables support for the handling of | |
199 | TIFF images with deflate-encoded data. Support for deflate-encoded | |
200 | data requires the freely available <tt>zlib</tt> distribution | |
201 | written by Jean-loup Gailly and Mark Adler; this software is | |
202 | available at <a href= | |
203 | "ftp://ftp.uu.net/pub/archiving/zip/zlib/">ftp.uu.net:/pub/archiving/zip/zlib/</a> | |
204 | (or try <a href= | |
205 | "ftp://quest.jpl.nasa.gov/beta/zlib/">quest.jpl.nasa.gov:/beta/zlib/</a>). | |
206 | If ZIP support is enabled the <tt>DIRS_LIBINC</tt> and | |
207 | <tt>DIR_GZLIB</tt> parameters should also be set (see below). By | |
208 | default this package is not configured.</dd> | |
209 | </dl> | |
210 | <a name="Sample" id="Sample"></a> | |
211 | <hr width="65%" align="right"> | |
212 | <h3>A Sample Configuration Session</h3> | |
213 | This section shows a sample configuration session and describes the | |
214 | work done. The session is shown indented in a <tt>fixed width | |
215 | font</tt> with user-supplied input in a <tt><b>bold font</b></tt>. | |
216 | Comments are shown in a normal or <i>italic</i> font. This session | |
217 | was collected on a 486 machine running BSDI 1.1. | |
218 | <div style="margin-left: 2em"> | |
219 | <pre> | |
220 | <tt> | |
221 | wullbrandt% <b>mkdir tiff</b> | |
222 | wullbrandt% <b>cd tiff</b> | |
223 | wullbrandt% <b>ln -s /hosts/oxford/usr/people/sam/tiff src</b> | |
224 | </tt> | |
225 | </pre></div> | |
226 | A build tree separate from the source tree is used here. In fact, | |
227 | in this case the distribution is accessed from a read-only | |
228 | NFS-mounted filesystem. | |
229 | <div style="margin-left: 2em"> | |
230 | <pre> | |
231 | <tt> | |
232 | wullbrandt% <b>src/configure</b> | |
233 | Configuring TIFF Software v3.4beta015. | |
234 | ||
235 | Reading site-wide parameters from ../tiff-v3.4beta015/config.site. | |
236 | Reading local parameters from config.local. | |
237 | Gosh, aren't you lucky to have a i386-unknown-bsdi1.1 system! | |
238 | </tt> | |
239 | </pre></div> | |
240 | Note that configure announces the distribution version and the | |
241 | deduced target configuration (<tt>i386-unknown-bsdi1.1</tt> here). | |
242 | <div style="margin-left: 2em"> | |
243 | <pre> | |
244 | <tt> | |
245 | Using /usr/local/bin/gcc for a C compiler (set CC to override). | |
246 | Looks like /usr/local/bin/gcc supports the -g option. | |
247 | Using " -g" for C compiler options. | |
248 | </tt> | |
249 | </pre></div> | |
250 | configure checked the normal shell search path for potential ANSI C | |
251 | compilers. The compiler is selected according to it properly | |
252 | compiling a small ANSI C test program. A specific compiler may be | |
253 | requested by setting the <tt>CC</tt> environment variable to the | |
254 | appropriate pathname, by supplying the parameter on the command | |
255 | line, e.g. <tt>-with-CC=gcc</tt>, or by setting <tt>CC</tt> in a | |
256 | configuration file. | |
257 | <p><img src="images/info.gif" align="left" hspace="10"> <em>Note | |
258 | that an ANSI C compiler is required to build the software. If a C | |
259 | compiler requires options to enable ANSI C compilation, they can be | |
260 | specified with the <tt>ENVOPTS</tt> parameter.</em></p> | |
261 | <p>Once a compiler is selected configure checks to see if the | |
262 | compiler accepts a -g option to enable the generation of debugging | |
263 | symbols, and if the compiler includes an ANSI C preprocessor.</p> | |
264 | <div style="margin-left: 2em"> | |
265 | <pre> | |
266 | <tt> | |
267 | Using /usr/ucb/make to configure the software. | |
268 | </tt> | |
269 | </pre></div> | |
270 | Next various system-specific libraries that may or may not be | |
271 | needed are checked for (none are needed in this case). If your | |
272 | system requires a library that is not automatically included it can | |
273 | be specified by setting the <tt>MACHDEPLIBS</tt> parameter. | |
274 | <p><i>Creating port.h.</i> The <b>port.h</b> file is included by | |
275 | all the C code in the library (but not the tools). It includes | |
276 | definitions for functions and type definitions that are missing | |
277 | from system include files, <tt>#defines</tt> to enable or disable | |
278 | system-specific functionality, and other odds and ends.</p> | |
279 | <div style="margin-left: 2em"> | |
280 | <pre> | |
281 | <tt> | |
282 | Creating libtiff/port.h with necessary definitions. | |
283 | ... using LSB2MSB bit order for your i386 cpu | |
284 | ... using big-endian byte order for your i386 cpu | |
285 | ... configure use of mmap for memory-mapped files | |
286 | ... O_RDONLY is in <fcntl.h> | |
287 | ... using double for promoted floating point parameters | |
288 | ... enabling use of inline functions | |
289 | Done creating libtiff/port.h. | |
290 | </tt> | |
291 | </pre></div> | |
292 | This file can take a long time to create so configure generates the | |
293 | file only when it is needed, either because the file does not exist | |
294 | or because a different target or compiler is to be used. Note that | |
295 | running "<tt>make distclean</tt>" in the top-level directory of the | |
296 | build tree will remove the <b>port.h</b> file (along with all the | |
297 | other files generated by configure). | |
298 | <p><i>Selecting emulated library functions.</i> Certain library | |
299 | functions used by the tools are not present on all systems and can | |
300 | be emulated using other system functionality. configure checks for | |
301 | the presence of such functions and if they are missing, will | |
302 | configure emulation code from the <b>port</b> directory to use | |
303 | instead. Building the TIFF software on unsupported systems may | |
304 | require adding to the code to the <b>port</b> directory.</p> | |
305 | <div style="margin-left: 2em"> | |
306 | <pre> | |
307 | <tt> | |
308 | Checking system libraries for functionality to emulate. | |
309 | Done checking system libraries. | |
310 | </tt> | |
311 | </pre></div> | |
312 | If a routine must be emulated and configure does not automatically | |
313 | check for it, the routine name can be specified using the | |
314 | <tt>PORTFUNCS</tt> parameter. To add emulation support for a new | |
315 | function <tt>foo</tt>, create a file <b>port/foo.c</b> that | |
316 | contains the emulation code and then set <tt>PORTFUNCS=foo</tt> in | |
317 | a configuration file or modify the configure script to | |
318 | automatically check for the missing function. | |
319 | <div style="margin-left: 2em"> | |
320 | <pre> | |
321 | <tt> | |
322 | Checking for Dynamic Shared Object (DSO) support. | |
323 | Done checking for DSO support. | |
324 | </tt> | |
325 | </pre></div> | |
326 | If the <tt>DSO</tt> package is enabled (<tt>DSO=auto</tt> or | |
327 | <tt>DSO=yes</tt>), then configure will verify the system and | |
328 | compiler are capable of constructing SVR4-style DSO's in the | |
329 | expected way. Note that while a system may support DSO's the | |
330 | compiler may not be capable of generating the required | |
331 | position-independent code and/or the compiler may not pass the | |
332 | needed options through to the loader. | |
333 | <p><i>Selecting utility programs.</i> configure locates various | |
334 | system utility programs that are used during installation of the | |
335 | software.</p> | |
336 | <div style="margin-left: 2em"> | |
337 | <pre> | |
338 | <tt> | |
339 | Selecting programs used during installation. | |
340 | Looks like mv supports the -f option to force a move. | |
341 | Looks like /bin/ln supports the -s option to create a symbolic link. | |
342 | Done selecting programs. | |
343 | </tt> | |
344 | </pre></div> | |
345 | <p><i>Selecting default configuration parameters.</i> The remainder | |
346 | of the work done by configure involves setting up configuration | |
347 | parameters that control the placement and setup of files during the | |
348 | installation procedure.</p> | |
349 | <div style="margin-left: 2em"> | |
350 | <pre> | |
351 | <tt> | |
352 | Selecting default TIFF configuration parameters. | |
353 | ||
354 | Looks like manual pages go in /usr/contrib/man. | |
355 | Looks like manual pages should be installed with bsd-nroff-gzip-0.gz. | |
356 | ||
357 | TIFF configuration parameters are: | |
358 | ||
359 | [ 1] Directory for tools: /usr/contrib/bin | |
360 | [ 2] Directory for libraries: /usr/contrib/lib | |
361 | [ 3] Directory for include files: /usr/contrib/include | |
362 | [ 4] Directory for manual pages: /usr/contrib/man | |
363 | [ 5] Manual page installation scheme: bsd-nroff-gzip-0.gz | |
364 | ||
365 | Are these ok [yes]? | |
366 | </tt> | |
367 | </pre></div> | |
368 | At this point you can interactively modify any of the displayed | |
369 | parameters. Hitting a carriage return or typing <tt>yes</tt> will | |
370 | accept the current parameters. Typing one of the number displayed | |
371 | along the left hand side causes configure to prompt for a new value | |
372 | of the specified parameter. Typing anything else causes configure | |
373 | to prompt for a new value <em>for each parameter</em>. In general | |
374 | hitting carriage return will accept the current value and typing | |
375 | anything that is unacceptable will cause a help message to be | |
376 | displayed. A description of each of the configuration parameters is | |
377 | given below. | |
378 | <p>Once acceptable parameters are setup configure will generate all | |
379 | the files that depend on these parameters. Note that certain files | |
380 | may or may not be created based on the configuration of optional | |
381 | packages and/or the functions supported by target system.</p> | |
382 | <div style="margin-left: 2em"> | |
383 | <pre> | |
384 | <tt> | |
385 | Creating Makefile from ../tiff-v3.4beta015/Makefile.in | |
386 | Creating libtiff/Makefile from ../tiff-v3.4beta015/libtiff/Makefile.in | |
387 | Creating man/Makefile from ../tiff-v3.4beta015/man/Makefile.in | |
388 | Creating tools/Makefile from ../tiff-v3.4beta015/tools/Makefile.in | |
389 | Creating port/install.sh from ../tiff-v3.4beta015/port/install.sh.in | |
390 | Done. | |
391 | </tt> | |
392 | </pre></div> | |
393 | <a name="DSOSupport" id="DSOSupport"></a> | |
394 | <hr> | |
395 | <h3>Shared Library Support</h3> | |
396 | It is desirable to make the TIFF library be a shared object on | |
397 | systems that have support for shared libraries. Unfortunately the | |
398 | rules to use to build a shared library vary between operating | |
399 | systems and even compilers. The distributed software includes | |
400 | support for building a shared version of the library on a number of | |
401 | different systems. This support is split between rules in the file | |
402 | <b>libtiff/Makefile.in</b> that construct the shared library and | |
403 | checks done by the <tt>configure</tt> script to verify that the | |
404 | expected rules are supported by compilation tools for the target | |
405 | system. | |
406 | <p>To add new support for building a shared library both these | |
407 | files must be updated. In the configure script search for the | |
408 | section where the autoconfiguration setting of the <tt>DSO</tt> | |
409 | parameter is handled and add a new case for the target system that | |
410 | sets the <tt>DSOSUF</tt>, <tt>DSOLD</tt>, <tt>DSOOPTS</tt>, and | |
411 | <tt>LIBCOPTS</tt> options as appropriate for the system. | |
412 | <tt>DSOSUF</tt> specifies the filename suffix used for the shared | |
413 | library (e.g. ``.so'' for Dynamic Shared Objects on most SVR4-based | |
414 | systems). <tt>DSOLD</tt> specifies the program to use to build the | |
415 | shared library from a compiled object file; typically ``${LD}'' | |
416 | though on some systems it is better to use the C compiler directly | |
417 | so system-dependent options and libraries are automatically | |
418 | supplied. <tt>DSOOPTS</tt> are options that must be specified to | |
419 | <tt>DSOLD</tt> when building the shared library. <tt>LIBCOPTS</tt> | |
420 | are options to pass to the C compiler when constructing a | |
421 | relocatable object file to include in a shared library; e.g. ``-K | |
422 | PIC'' on a Sun system. The <tt>DSO</tt> parameter must also be set | |
423 | to a unique label that identifies the target system and compilation | |
424 | tools. This label is used to select a target in | |
425 | <b>libtiff/Makefile.in</b> to do the actual work in building the | |
426 | shared library. Finally, to complete support for the shared library | |
427 | added the appropriate rules to <b>libtiff/Makefile.in</b> under the | |
428 | target specified in the <tt>configure</tt> script. <a name="PC" id= | |
429 | "PC"></a></p> | |
430 | <hr> | |
431 | <h2>Building the Software under Windows 95/98/NT/2000 with MS | |
432 | VC++</h2> | |
433 | With Microsoft Visual C++ installed, and properly configured for | |
434 | commandline use (you will likely need to source VCVARS32.BAT in | |
435 | AUTOEXEC.bAT or somewhere similar) you should be able to use the | |
436 | provided <tt>makefile.vc</tt>. | |
437 | <p>The source package is delivered using Unix line termination | |
438 | conventions, which work with MSVC but do not work with Windows | |
439 | 'notepad'. If you use unzip from the <a href= | |
440 | "http://www.info-zip.org/pub/infozip/">Info-Zip</a> package, you | |
441 | can extract the files using Windows normal line termination | |
442 | conventions with a command similar to:</p> | |
443 | <pre> | |
444 | unzip -aa -a tiff-3.7.4.zip | |
445 | </pre> | |
446 | <p>By default libtiff expects that a pre-built zlib and jpeg | |
447 | library are provided by the user. If this is not the case, then you | |
448 | may edit libtiff\tiffconf.h using a text editor (e.g. notepad) and | |
449 | comment out the entries for JPEG_SUPPORT, PIXARLOG_SUPPORT, and | |
450 | ZIP_SUPPORT. Ignore the comment at the top of the file which says | |
451 | that it has no influence on the build, because the statement is not | |
452 | true for Windows. However, by taking this approach, libtiff will | |
453 | not be able to open some TIFF files.</p> | |
454 | <p>To build using the provided makefile.vc you may use:</p> | |
455 | <pre> | |
456 | C:\tiff-3.7.4> nmake /f makefile.vc clean | |
457 | C:\tiff-3.7.4> nmake /f makefile.vc | |
458 | ||
459 | or (the hard way) | |
460 | ||
461 | C:\tiff-3.7.4> cd port | |
462 | C:\tiff-3.7.4\port> nmake /f makefile.vc clean | |
463 | C:\tiff-3.7.4\port> nmake /f makefile.vc | |
464 | C:\tiff-3.7.4> cd ../libtiff | |
465 | C:\tiff-3.7.4\libtiff> nmake /f makefile.vc clean | |
466 | C:\tiff-3.7.4\libtiff> nmake /f makefile.vc | |
467 | C:\tiff-3.7.4\libtiff> cd ..\tools | |
468 | C:\tiff-3.7.4\tools> nmake /f makefile.vc clean | |
469 | C:\tiff-3.7.4\tools> nmake /f makefile.vc | |
470 | </pre> | |
471 | <p>This will build the library file | |
472 | <tt>libtiff\libtiff\libtiff.lib</tt>. This can be used in Win32 | |
473 | programs. You may want to adjust the build options before start | |
474 | compiling. All parameters contained in the <tt>nmake.opt</tt> | |
475 | file.This is a plain text file you can open with your favorite text | |
476 | editor.</p> | |
477 | <p>The makefile also builds a DLL (libtiff.dll) with an associated | |
478 | import library (libtiff_i.lib). Any builds using libtiff will need | |
479 | to include the LIBTIFF\LIBTIFF directory in the include path.</p> | |
480 | <p>The <tt>libtiff\tools\makefile.vc</tt> should build .exe's for | |
481 | all the standard TIFF tool programs.</p> | |
482 | <p><a name="DJGPP" id="DJGPP"></a></p> | |
483 | <hr> | |
484 | <h2>Building the Software under MS/DOS with the DJGPP v2 | |
485 | compiler</h2> | |
486 | [<i>From the file <b>contrib/dosdjgpp/README</b>.</i>] | |
487 | <p>The directory <b>contrib/dosdjgpp</b> contains the files | |
488 | necessary to build the library and tools with the DJGPP v2 compiler | |
489 | under MSDOS.</p> | |
490 | <p>All you have to do is copy the files in the directory into the | |
491 | respective directories and run make. If you want, you can use the | |
492 | <b>conf.bat</b> script to do that for you, make sure that the file | |
493 | is stored with MSDOS text EOL-convention (CR/LF), otherwise the | |
494 | <b>command.com</b> will not do anything.</p> | |
495 | <p>Note that you probably will not be able to build the library | |
496 | with the v1.x versions of djgpp, due to two problems. First, the | |
497 | top makefile calls a sub-make for each directory and you are likely | |
498 | to run out of memory, since each recursive invocation of a djgpp | |
499 | v1.x program requires about 130k, to avoid that, you can enter the | |
500 | directories manually and call make (well, there are only two dirs). | |
501 | The 2nd problem is that djgpp 1.x doesn't call the coff2exe | |
502 | (stubify) program when creating an executable. This means that all | |
503 | programs compiled are not converted to exe and consequently are not | |
504 | available for calling directly. For the tools directory, you can | |
505 | just call coff2exe for each program after make finishes, but in the | |
506 | libtiff directory, a few programs are created during the make | |
507 | process that have to be called for make to continue (e.g. | |
508 | mkg3states). Make will probably report an error at each such stage. | |
509 | To fix that, either add a coff2exe call before each program is | |
510 | called or call coff2exe manually and rerun make (there 2-3 such | |
511 | programs). <a name="MacMPW" id="MacMPW"></a></p> | |
512 | <hr> | |
513 | <h2>Building the Software on a Macintosh with MPW</h2> | |
514 | The directory <b>contrib/mac-mpw</b> contains support for compiling | |
515 | the library and tools under the MPW Shell on a Macintosh system. | |
516 | This support was contributed by Niles Ritter (<a href= | |
517 | "mailto:ndr@tazboy.jpl.nasa.gov">ndr@tazboy.jpl.nasa.gov</a>). | |
518 | <p>[<i>From the file <b>contrib/mac-mpw/README</b>.</i>]</p> | |
519 | <p>This directory contains all of the utilities and makefile source | |
520 | to build the LIBTIFF library and tools from the MPW Shell. The file | |
521 | BUILD.mpw in this directory is an executable script which uses all | |
522 | of these files to create the MPW makefiles and run them.</p> | |
523 | <p>The <file>.make files are not MPW makefiles as such, but | |
524 | are when run through the "mactrans" program, which turns the ascii | |
525 | "%nn" metacharacters into the standard weird MPW make | |
526 | characters.</p> | |
527 | <p>This translation trick is necessary to protect the files when | |
528 | they are put into unix tarfiles, which tend to mangle the special | |
529 | characters. <a name="MacCW" id="MacCW"></a></p> | |
530 | <hr> | |
531 | <h2>Building the Software on a Macintosh with CodeWarrior</h2> | |
532 | The directory <b>contrib/mac-cw</b> contains support for compiling | |
533 | the library and tools with MetroWerks CodeWarrior 6.1 on a | |
534 | Macintosh system. This support was contributed by Niles Ritter | |
535 | (<a href= | |
536 | "mailto:ndr@tazboy.jpl.nasa.gov">ndr@tazboy.jpl.nasa.gov</a>). | |
537 | <p>[<i>From the file <b>contrib/mac-cw/README</b>.</i>] In this | |
538 | directory you will find a Makefile.script Applescript file, which | |
539 | should be run in order to build the libtiff code using MetroWerks | |
540 | CodeWarrior. Refer to the "metrowerks.note" instructions on | |
541 | building the library for 68k and PowerPC native code, as well as | |
542 | building some of the libtiff tools, which are rather unix-like, but | |
543 | at least give an example of how to link everything together. | |
544 | <a name="VMS" id="VMS"></a></p> | |
545 | <hr> | |
546 | <h2>Building the Software on a VMS System</h2> | |
547 | The VMS port was done by Karsten Spang (<a href= | |
548 | "mailto:krs@kampsax.dk">krs@kampsax.dk</a>), who also "sort of" | |
549 | maintains it. The VMS specific files are not in the main | |
550 | directories. Instead they are placed under | |
551 | <tt>[.CONTRIB.VMS...]</tt> in the distribution tree. Installation: | |
552 | It is assumed that you have unpacked the tar file into a VMS | |
553 | directory tree, in this text called DISK:[TIFF]. | |
554 | <ol> | |
555 | <li>Move the VMS specific files to their proper directories. | |
556 | <pre> | |
557 | $ SET DEFAULT DISK:[TIFF.CONTRIB.VMS] | |
558 | $ RENAME [.LIBTIFF]*.* [-.-.LIBTIFF] | |
559 | $ RENAME [.TOOLS]*.* [-.-.TOOLS] | |
560 | </pre></li> | |
561 | <li>Compile the library. | |
562 | <pre> | |
563 | $ SET DEFAULT DISK:[TIFF.LIBTIFF] | |
564 | $ @MAKEVMS | |
565 | </pre></li> | |
566 | <li>Compile the tools. | |
567 | <pre> | |
568 | $ SET DEFAULT DISK:[TIFF.TOOLS] | |
569 | $ @MAKEVMS | |
570 | </pre></li> | |
571 | <li>Define the programs. | |
572 | <pre> | |
573 | $ DEFINE TIFFSHR DISK:[TIFF.LIBTIFF]TIFFSHR | |
574 | $ FAX2PS :==$DISK:[TIFF.TOOLS]FAX2PS | |
575 | $ FAX2TIFF :==$DISK:[TIFF.TOOLS]FAX2TIFF | |
576 | $ GIF2TIFF :==$DISK:[TIFF.TOOLS]GIF2TIFF | |
577 | $ PAL2RGB :==$DISK:[TIFF.TOOLS]PAL2RGB | |
578 | $ PPM2TIFF :==$DISK:[TIFF.TOOLS]PPM2TIFF | |
579 | $ RAS2TIFF :==$DISK:[TIFF.TOOLS]RAS2TIFF | |
580 | $ RGB2YCBCR :==$DISK:[TIFF.TOOLS]RGB2YCBCR | |
581 | $ THUMBNAIL :==$DISK:[TIFF.TOOLS]THUMBNAIL | |
582 | $ TIFF2BW :==$DISK:[TIFF.TOOLS]TIFF2BW | |
583 | $ TIFF2PS :==$DISK:[TIFF.TOOLS]TIFF2PS | |
584 | $ TIFFCMP :==$DISK:[TIFF.TOOLS]TIFFCMP | |
585 | $ TIFFCP :==$DISK:[TIFF.TOOLS]TIFFCP | |
586 | $ TIFFDITHER:==$DISK:[TIFF.TOOLS]TIFFDITHER | |
587 | $ TIFFDUMP :==$DISK:[TIFF.TOOLS]TIFFDUMP | |
588 | $ TIFFINFO :==$DISK:[TIFF.TOOLS]TIFFINFO | |
589 | $ TIFFMEDIAN:==$DISK:[TIFF.TOOLS]TIFFMEDIAN | |
590 | $ TIFFSPLIT :==$DISK:[TIFF.TOOLS]TIFFSPLIT | |
591 | $ YCBCR :==$DISK:[TIFF.TOOLS]YCBCR | |
592 | </pre></li> | |
593 | </ol> | |
594 | You will want to add these lines to your <tt>LOGIN.COM</tt> file, | |
595 | after changing the name of the directory that you have used on your | |
596 | machine. | |
597 | <p>This release has been tested on OpenVMS/VAX 5.5-2, using VAX C | |
598 | 3.2. A previous release was tested under OpenVMS/AXP ?.? using DEC | |
599 | C ?.?, it is believed that this release as well works on AXP. The | |
600 | code contains some GNU C specific things. This does *not* imply, | |
601 | however, that the VAX/GCC configuration has been tested, *it has | |
602 | not*.</p> | |
603 | <p>The command procedures (<tt>MAKEVMS.COM</tt>) for building the | |
604 | library and tools, is believed to choose the correct options for | |
605 | the VAX and AXP cases automatically.</p> | |
606 | <p>On the AXP, IEEE floating point is used by default. If you want | |
607 | VAX floating point, remove the <tt>/FLOAT=IEEE_FLOAT</tt> | |
608 | qualifier, and change <tt>HAVE_IEEEFP=1</tt> to | |
609 | <tt>HAVE_IEEEFP=0</tt> in the <tt>MAKEVMS.COM</tt> files in both | |
610 | the <b>libtiff</b> and <b>tools</b> directories.</p> | |
611 | <h3>Compiling your own program on a VMS system:</h3> | |
612 | When compiling a source file in which you <tt>"#include | |
613 | <tiffio.h>"</tt>, use the following command | |
614 | <pre> | |
615 | $ CC/INCLUDE=DISK:[TIFF.LIBTIFF] | |
616 | </pre> | |
617 | This ensures that the header file is found. On the AXP, also add | |
618 | <tt>/FLOAT=IEEE_FLOAT</tt> (if used when building the library). | |
619 | <h3>Linking your own program to the TIFF library on a VMS | |
620 | system:</h3> | |
621 | You can link to the library in two ways: Either using the shareable | |
622 | library, or using the object library. On the VAX these | |
623 | possibilities are: | |
624 | <ol> | |
625 | <li>Using the shareable TIFF library. | |
626 | <pre> | |
627 | $ LINK MY_PROGRAM,DISK:[TIFF.LIBTIFF]TIFF/OPTIONS,SYS$INPUT:/OPTIONS | |
628 | SYS$SHARE:VAXCRTL/SHAREABLE | |
629 | </pre></li> | |
630 | <li>Using the TIFF object library. | |
631 | <pre> | |
632 | $ LINK MY_PROGRAM, - | |
633 | DISK:[TIFF.LIBTIFF]TIFF/LIBRARY/INCLUDE=(TIF_FAX3SM,TIF_CODEC), - | |
634 | SYS$INPUT:/OPTIONS | |
635 | SYS$SHARE:VAXCRTL/SHAREABLE | |
636 | </pre></li> | |
637 | </ol> | |
638 | On AXP (and possibly also using DEC C on VAX) the corresponding | |
639 | commands are | |
640 | <ol> | |
641 | <li>Using the shareable TIFF library. | |
642 | <pre> | |
643 | $ LINK MY_PROGRAM,DISK:[TIFF.LIBTIFF]TIFF/OPTIONS | |
644 | </pre></li> | |
645 | <li>Using the TIFF object library. | |
646 | <pre> | |
647 | $ LINK MY_PROGRAM,DISK:[TIFF.LIBTIFF]TIFF/LIBRARY | |
648 | </pre></li> | |
649 | </ol> | |
650 | Method 1 uses the shortest link time and smallest <tt>.EXE</tt> | |
651 | files, but it requires that <tt>TIFFSHR</tt> is defined as above at | |
652 | link time and <strong>at run time</strong>. Using the compilation | |
653 | procedure above, the tools are linked in this way. | |
654 | <p>Method 2 gives somewhat longer link time and larger | |
655 | <tt>.EXE</tt> files, but does not require <tt>TIFFSHR</tt> to be | |
656 | defined. This method is recommended if you want to run your program | |
657 | on another machine, and for some reason don't want to have the | |
658 | library on that machine. If you plan to have more than one program | |
659 | (including the tools) on the machine, it is recommended that you | |
660 | copy the library to the other machine and use method 1. <a name= | |
661 | "Acorn" id="Acorn"></a></p> | |
662 | <hr> | |
663 | <h2>Building the Software on an Acorn RISC OS system</h2> | |
664 | The directory <b>contrib/acorn</b> contains support for compiling | |
665 | the library under Acorn C/C++ under Acorn's RISC OS 3.10 or above. | |
666 | Subsequent pathnames will use the Acorn format: The full-stop or | |
667 | period character is a pathname delimeter, and the slash character | |
668 | is not interpreted; the reverse position from Unix. Thus | |
669 | "libtiff/tif_acorn.c" becomes "libtiff.tif_acorn/c". | |
670 | <p>This support was contributed by Peter Greenham. (<a href= | |
671 | "mailto:peter@enlarion.demon.co.uk">peter@enlarion.demon.co.uk</a>).</p> | |
672 | <h3>Installing LibTIFF:</h3> | |
673 | <p>LIBTIFF uses several files which have names longer than the | |
674 | normal RISC OS maximum of ten characters. This complicates matters. | |
675 | Maybe one day Acorn will address the problem and implement long | |
676 | filenames properly. Until then this gets messy, especially as I'm | |
677 | trying to do this with obeyfiles and not have to include binaries | |
678 | in this distribution.</p> | |
679 | <p>First of all, ensure you have Truncate configured on (type | |
680 | <tt>*Configure Truncate On</tt>)</p> | |
681 | <p>Although it is, of course, preferable to have long filenames, | |
682 | LIBTIFF can be installed with short filenames, and it will compile | |
683 | and link without problems. However, <i>getting</i> it there is more | |
684 | problematic. <b>contrib.acorn.install</b> is an installation | |
685 | obeyfile which will create a normal Acorn-style library from the | |
686 | source (ie: with c, h and o folders etc.), but needs the | |
687 | distribution library to have been unpacked into a location which is | |
688 | capable of supporting long filenames, even if only temporarily.</p> | |
689 | <p>My recommendation, until Acorn address this problem properly, is | |
690 | to use Jason Tribbeck's <a href= | |
691 | "ftp://ftp.demon.co.uk/pub/mirrors/hensa/micros/arch/riscos/c/c020/longfiles.arc"> | |
692 | LongFilenames</a>, or any other working system that gives you long | |
693 | filenames, like a nearby NFS server for instance.</p> | |
694 | <p>If you are using Longfilenames, even if only temporarily to | |
695 | install LIBTIFF, unpack the TAR into a RAMDisc which has been | |
696 | longfilenamed (ie: <tt>*addlongfs ram</tt>) and then install from | |
697 | there to the hard disk. Unfortunately Longfilenames seems a bit | |
698 | unhappy about copying a bunch of long-named files across the same | |
699 | filing system, but is happy going between systems. You'll need to | |
700 | create a ramdisk of about 2Mb.</p> | |
701 | <p>Now you can run the installation script I've supplied (in | |
702 | contrib.acorn), which will automate the process of installing | |
703 | LIBTIFF as an Acorn-style library. The syntax is as follows:</p> | |
704 | <p><tt>install <source_dir> <dest_dir></tt></p> | |
705 | <p>Install will then create <dest_dir> and put the library in | |
706 | there. For example, having used LongFilenames on the RAMDisk and | |
707 | unpacked the library into there, you can then type:</p> | |
708 | <p><tt>Obey RAM::RamDisc0.$.contrib.acorn.install RAM::RamDisc0.$ | |
709 | ADFS::4.$.LIBTIFF</tt></p> | |
710 | <p>It doesn't matter if the destination location can cope with long | |
711 | filenames or not. The filenames will be truncated if necessary | |
712 | (*Configure Truncate On if you get errors) and all will be | |
713 | well.</p> | |
714 | <h3>Compiling LibTIFF:</h3> | |
715 | <p>Once the LibTIFF folder has been created and the files put | |
716 | inside, making the library should be just a matter of running | |
717 | '<b>SetVars</b>' to set the appropriate system variables, then | |
718 | running '<b>Makefile</b>'.</p> | |
719 | <p><b>OSLib</b></p> | |
720 | <p><a href= | |
721 | "ftp://ftp.acorn.co.uk/pub/riscos/releases/oslib/oslib.arc">OSLib</a> | |
722 | is a comprehensive API for RISC OS machines, written by Jonathan | |
723 | Coxhead of Acorn Computers (although OSLib is not an official Acorn | |
724 | product). Using the OSLib SWI veneers produces code which is more | |
725 | compact and more efficient than code written using _kernel_swi or | |
726 | _swi. The Acorn port of LibTIFF can take advantage of this if | |
727 | present. Edit the Makefile and go to the Static dependencies | |
728 | section. The first entry is:</p> | |
729 | <pre> | |
730 | # Static dependencies: | |
731 | @.o.tif_acorn: @.c.tif_acorn | |
732 | cc $(ccflags) -o @.o.tif_acorn @.c.tif_acorn | |
733 | </pre> | |
734 | <p>Change the cc line to:</p> | |
735 | <pre> | |
736 | cc $(ccflags) -DINCLUDE_OSLIB -o @.o.tif_acorn @.c.tif_acorn | |
737 | </pre> | |
738 | <p>Remember, however, that OSLib is only <i>recommended</i> for | |
739 | efficiency's sake. It is not required. <a name="Other" id= | |
740 | "Other"></a></p> | |
741 | <hr> | |
742 | <h2>Building the Software on Other Systems</h2> | |
743 | This section contains information that might be useful if you are | |
744 | working on a non-UNIX system that is not directly supported. All | |
745 | library-related files described below are located in the | |
746 | <b>libtiff</b> directory. | |
747 | <p>The library requires two files that are generated | |
748 | <i>on-the-fly</i>. The file <b>tif_fax3sm.c</b> has the state | |
749 | tables for the Group 3 and Group 4 decoders. This file is generated | |
750 | by the <tt>mkg3states</tt> program on a UNIX system; for | |
751 | example,</p> | |
752 | <div style="margin-left: 2em"> | |
753 | <pre> | |
754 | <tt> | |
755 | cd libtiff | |
756 | cc -o mkg3states mkg3states.c | |
757 | rm -f tif_fax3sm.c | |
758 | ./mkg3states -c const tif_fax3sm.c | |
759 | </tt> | |
760 | </pre></div> | |
761 | The <tt>-c</tt> option can be used to control whether or not the | |
762 | resutling tables are generated with a <tt>const</tt> declaration. | |
763 | The <tt>-s</tt> option can be used to specify a C storage class for | |
764 | the table declarations. The <tt>-b</tt> option can be used to force | |
765 | data values to be explicitly bracketed with ``{}'' (apparently | |
766 | needed for some MS-Windows compilers); otherwise the structures are | |
767 | emitted in as compact a format as possible. Consult the source code | |
768 | for this program if you have questions. | |
769 | <p>The second file required to build the library, <b>version.h</b>, | |
770 | contains the version information returned by the | |
771 | <tt>TIFFGetVersion</tt> routine. This file is built on most systems | |
772 | using the <tt>mkversion</tt> program and the contents of the | |
773 | <tt>VERSION</tt> and <tt>tiff.alpha</tt> files; for example,</p> | |
774 | <div style="margin-left: 2em"> | |
775 | <pre> | |
776 | cd libtiff | |
777 | cc -o mkversion mkversion.c | |
778 | rm -f version.h | |
779 | ./mkversion -v ../VERSION -a ../dist/tiff.alpha version.h | |
780 | </pre></div> | |
781 | <p>Otherwise, when building the library on a non-UNIX system be | |
782 | sure to consult the files <b>tiffcomp.h</b> and <b>tiffconf.h</b>. | |
783 | The former contains system compatibility definitions while the | |
784 | latter is provided so that the software configuration can be | |
785 | controlled on systems that do not support the make facility for | |
786 | building the software.</p> | |
787 | <p>Systems without a 32-bit compiler may not be able to handle some | |
788 | of the codecs in the library; especially the Group 3 and 4 decoder. | |
789 | If you encounter problems try disabling support for a particular | |
790 | codec; consult the <a href= | |
791 | "internals.html#Config">documentation</a>.</p> | |
792 | <p>Programs in the tools directory are written to assume an ANSI C | |
793 | compilation environment. There may be a few POSIX'isms as well. The | |
794 | code in the <b>port</b> directory is provided to emulate routines | |
795 | that may be missing on some systems. On UNIX systems the | |
796 | <tt>configure</tt> script automatically figures out which routines | |
797 | are not present on a system and enables the use of the equivalent | |
798 | emulation routines from the <b>port</b> directory. It may be | |
799 | necessary to manually do this work on a non-UNIX system. <a name= | |
800 | "Testing" id="Testing"></a></p> | |
801 | <hr> | |
802 | <h2>Checking out the Software</h2> | |
803 | <p>Assuming you have working versions of <tt>tiffgt</tt> and | |
804 | <tt>tiffsv</tt>, you can just use them to view any of the sample | |
805 | images available for testing (see the <a href="images.html">section | |
806 | on obtaining the test images</a>). Otherwise, you can do a cursory | |
807 | check of the library with the <tt>tiffcp</tt> and <tt>tiffcmp</tt> | |
808 | programs. For example,</p> | |
809 | <div style="margin-left: 2em"> | |
810 | <pre> | |
811 | tiffcp -lzw cramps.tif x.tif | |
812 | tiffcmp cramps.tif x.tif | |
813 | </pre></div> | |
814 | <p>(<tt>tiffcmp</tt> should be silent if the files compare | |
815 | correctly). <a name="TOC" id="TOC"></a></p> | |
816 | <hr> | |
817 | <h2>Table of Contents</h2> | |
818 | The following files makup the core library: | |
819 | <pre> | |
820 | libtiff/tiff.h TIFF spec definitions | |
821 | libtiff/tiffcomp.h non-UNIX OS-compatibility definitions | |
822 | libtiff/tiffconf.h non-UNIX configuration definitions | |
823 | libtiff/tiffio.h public TIFF library definitions | |
824 | libtiff/tiffiop.h private TIFF library definitions | |
825 | libtiff/t4.h CCITT Group 3/4 code tables+definitions | |
826 | libtiff/tif_dir.h private defs for TIFF directory handling | |
827 | libtiff/tif_fax3.h CCITT Group 3/4-related definitions | |
828 | libtiff/tif_predict.h private defs for Predictor tag support | |
829 | libtiff/uvcode.h LogL/LogLuv codec-specific definitions | |
830 | libtiff/version.h version string (generated by Makefile) | |
831 | ||
832 | libtiff/tif_acorn.c Acorn-related OS support | |
833 | libtiff/tif_apple.c Apple-related OS support | |
834 | libtiff/tif_atari.c Atari-related OS support | |
835 | libtiff/tif_aux.c auxilary directory-related functions | |
836 | libtiff/tif_close.c close an open TIFF file | |
837 | libtiff/tif_codec.c configuration table of builtin codecs | |
838 | libtiff/tif_compress.c compression scheme support | |
839 | libtiff/tif_dir.c directory tag interface code | |
840 | libtiff/tif_dirinfo.c directory known tag support code | |
841 | libtiff/tif_dirread.c directory reading code | |
842 | libtiff/tif_dirwrite.c directory writing code | |
843 | libtiff/tif_dumpmode.c "no" compression codec | |
844 | libtiff/tif_error.c library error handler | |
845 | libtiff/tif_fax3.c CCITT Group 3 and 4 codec | |
846 | libtiff/tif_fax3sm.c G3/G4 state tables (generated by mkg3states) | |
847 | libtiff/tif_flush.c i/o and directory state flushing | |
848 | libtiff/tif_getimage.c TIFFRGBAImage support | |
849 | libtiff/tif_jpeg.c JPEG codec (interface to the IJG distribution) | |
850 | libtiff/tif_luv.c SGI LogL/LogLuv codec | |
851 | libtiff/tif_lzw.c LZW codec | |
852 | libtiff/tif_msdos.c MSDOS-related OS support | |
853 | libtiff/tif_next.c NeXT 2-bit scheme codec (decoding only) | |
854 | libtiff/tif_open.c open and simply query code | |
855 | libtiff/tif_packbits.c Packbits codec | |
856 | libtiff/tif_pixarlog.c Pixar codec | |
857 | libtiff/tif_predict.c Predictor tag support | |
858 | libtiff/tif_print.c directory printing support | |
859 | libtiff/tif_read.c image data reading support | |
860 | libtiff/tif_strip.c some strip-related code | |
861 | libtiff/tif_swab.c byte and bit swapping support | |
862 | libtiff/tif_thunder.c Thunderscan codec (decoding only) | |
863 | libtiff/tif_tile.c some tile-related code | |
864 | libtiff/tif_unix.c UNIX-related OS support | |
865 | libtiff/tif_version.c library version support | |
866 | libtiff/tif_vms.c VMS-related OS support | |
867 | libtiff/tif_warning.c library warning handler | |
868 | libtiff/tif_win3.c Windows-3.1-related OS support | |
869 | libtiff/tif_win32.c Win32 (95/98/NT) related OS support | |
870 | libtiff/tif_write.c image data writing support | |
871 | libtiff/tif_zip.c Deflate codec | |
872 | ||
873 | libtiff/mkg3states.c program to generate G3/G4 decoder state tables | |
874 | libtiff/mkspans.c program to generate black-white span tables | |
875 | libtiff/mkversion.c program to generate libtiff/version.h. | |
876 | </pre> | |
877 | <hr> | |
878 | Last updated: $Date: 2005/12/24 22:25:05 $ | |
879 | </body> | |
880 | </html> |