]>
git.saurik.com Git - wxWidgets.git/blob - src/tiff/libtiff/tif_close.c
e891aa59d7a6c1e311595fd33fc3165ed3fde87d
4 * Copyright (c) 1988-1997 Sam Leffler
5 * Copyright (c) 1991-1997 Silicon Graphics, Inc.
7 * Permission to use, copy, modify, distribute, and sell this software and
8 * its documentation for any purpose is hereby granted without fee, provided
9 * that (i) the above copyright notices and this permission notice appear in
10 * all copies of the software and related documentation, and (ii) the names of
11 * Sam Leffler and Silicon Graphics may not be used in any advertising or
12 * publicity relating to the software without the specific, prior written
13 * permission of Sam Leffler and Silicon Graphics.
15 * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
16 * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
17 * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
19 * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
20 * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
21 * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
22 * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
23 * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
33 /************************************************************************/
35 /************************************************************************/
38 * Auxiliary function to free the TIFF structure. Given structure will be
39 * completetly freed, so you should save opened file handle and pointer
40 * to the close procedure in external variables before calling
41 * _TIFFCleanup(), if you will need these ones to close the file.
43 * @param tif A TIFF pointer.
47 TIFFCleanup(TIFF
* tif
)
50 * Flush buffered data and directory (if dirty).
52 if (tif
->tif_mode
!= O_RDONLY
)
54 (*tif
->tif_cleanup
)(tif
);
55 TIFFFreeDirectory(tif
);
58 _TIFFfree(tif
->tif_dirlist
);
61 * Clean up client info links.
63 while( tif
->tif_clientinfo
)
65 TIFFClientInfoLink
*link
= tif
->tif_clientinfo
;
67 tif
->tif_clientinfo
= link
->next
;
68 _TIFFfree( link
->name
);
72 if (tif
->tif_rawdata
&& (tif
->tif_flags
&TIFF_MYBUFFER
))
73 _TIFFfree(tif
->tif_rawdata
);
75 TIFFUnmapFileContents(tif
, tif
->tif_base
, (toff_t
)tif
->tif_size
);
78 * Clean up custom fields.
80 if (tif
->tif_fields
&& tif
->tif_nfields
> 0) {
83 for (i
= 0; i
< tif
->tif_nfields
; i
++) {
84 TIFFField
*fld
= tif
->tif_fields
[i
];
85 if (fld
->field_bit
== FIELD_CUSTOM
&&
86 strncmp("Tag ", fld
->field_name
, 4) == 0) {
87 _TIFFfree(fld
->field_name
);
92 _TIFFfree(tif
->tif_fields
);
95 if (tif
->tif_nfieldscompat
> 0) {
98 for (i
= 0; i
< tif
->tif_nfieldscompat
; i
++) {
99 if (tif
->tif_fieldscompat
[i
].allocated_size
)
100 _TIFFfree(tif
->tif_fieldscompat
[i
].fields
);
102 _TIFFfree(tif
->tif_fieldscompat
);
108 /************************************************************************/
110 /************************************************************************/
113 * Close a previously opened TIFF file.
115 * TIFFClose closes a file that was previously opened with TIFFOpen().
116 * Any buffered data are flushed to the file, including the contents of
117 * the current directory (if modified); and all resources are reclaimed.
119 * @param tif A TIFF pointer.
125 TIFFCloseProc closeproc
= tif
->tif_closeproc
;
126 thandle_t fd
= tif
->tif_clientdata
;
129 (void) (*closeproc
)(fd
);
132 /* vim: set ts=8 sts=8 sw=8 noet: */