Coverage Report

Created: 2026-05-16 06:16

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libtiff/libtiff/tif_dirinfo.c
Line
Count
Source
1
/*
2
 * Copyright (c) 1988-1997 Sam Leffler
3
 * Copyright (c) 1991-1997 Silicon Graphics, Inc.
4
 *
5
 * Permission to use, copy, modify, distribute, and sell this software and
6
 * its documentation for any purpose is hereby granted without fee, provided
7
 * that (i) the above copyright notices and this permission notice appear in
8
 * all copies of the software and related documentation, and (ii) the names of
9
 * Sam Leffler and Silicon Graphics may not be used in any advertising or
10
 * publicity relating to the software without the specific, prior written
11
 * permission of Sam Leffler and Silicon Graphics.
12
 *
13
 * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
14
 * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
15
 * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
16
 *
17
 * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
18
 * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
19
 * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
20
 * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
21
 * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
22
 * OF THIS SOFTWARE.
23
 */
24
25
/*
26
 * TIFF Library.
27
 *
28
 * Core Directory Tag Support.
29
 */
30
#include "tiffiop.h"
31
#include <stdlib.h>
32
33
/*
34
 * NOTE: THIS ARRAY IS ASSUMED TO BE SORTED BY TAG.
35
 *
36
 * NOTE: The second field (field_readcount) and third field (field_writecount)
37
 *       sometimes use the values TIFF_VARIABLE (-1), TIFF_VARIABLE2 (-3)
38
 *       and TIFF_SPP (-2). The macros should be used but would throw off
39
 *       the formatting of the code, so please interpret the -1, -2 and -3
40
 *       values accordingly.
41
 */
42
43
/* Forward declarations - definition follows after field arrays.
44
 * Note: In C, we can forward declare static const objects and define them
45
 * later. In C++, we need extern for the declaration, then define without
46
 * extern. Since these are only used within this file via pointers, we use a
47
 * workaround that works in both C and C++: declare as extern here, define as
48
 * static later, but actually we need a different approach for C++
49
 * compatibility.
50
 *
51
 * For C/C++ compatibility, we define a simple struct that holds the pointer
52
 * and initialize it after the arrays are defined.
53
 */
54
#ifdef __cplusplus
55
/* C++ doesn't allow forward declaration of const objects, so we use extern */
56
extern const TIFFFieldArray tiffFieldArray;
57
extern const TIFFFieldArray exifFieldArray;
58
extern const TIFFFieldArray gpsFieldArray;
59
#else
60
/* C allows forward declaration of const objects, but C++ doesn't.
61
 * We disable the C++-compat warning for this section since these circular
62
 * dependencies are unavoidable with static initialization. */
63
#if defined(__GNUC__) && !defined(__clang__)
64
#pragma GCC diagnostic push
65
#pragma GCC diagnostic ignored "-Wc++-compat"
66
#elif defined(__clang__)
67
#pragma clang diagnostic push
68
#pragma clang diagnostic ignored "-Wc++-compat"
69
#elif defined(_MSC_VER)
70
#pragma warning(push)
71
#pragma warning(disable : 4132)
72
#endif
73
static const TIFFFieldArray tiffFieldArray;
74
static const TIFFFieldArray exifFieldArray;
75
static const TIFFFieldArray gpsFieldArray;
76
#if defined(__GNUC__) && !defined(__clang__)
77
#pragma GCC diagnostic pop
78
#elif defined(__clang__)
79
#pragma clang diagnostic pop
80
#elif defined(_MSC_VER)
81
#pragma warning(pop)
82
#endif
83
#endif
84
/*--: Rational2Double: --
85
 * The Rational2Double upgraded libtiff functionality allows the definition and
86
 * achievement of true double-precision accuracy for TIFF tags of RATIONAL type
87
 * and field_bit=FIELD_CUSTOM using the set_get_field_type = TIFF_SETGET_DOUBLE.
88
 * Unfortunately, that changes the old implemented interface for TIFFGetField().
89
 * In order to keep the old TIFFGetField() interface behavior those tags have to
90
 * be redefined with set_get_field_type = TIFF_SETGET_FLOAT!
91
 *
92
 *  Rational custom arrays are already defined as _Cxx_FLOAT, thus can stay.
93
 *
94
 */
95
96
/* clang-format off */ /* for better readability of tag comments */
97
static const TIFFField tiffFields[] = {
98
    {TIFFTAG_SUBFILETYPE, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32, FIELD_SUBFILETYPE, 1, 0, "SubfileType", NULL},
99
    {TIFFTAG_OSUBFILETYPE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UNDEFINED,  FIELD_IGNORE, 1, 0, "OldSubfileType", NULL},
100
    {TIFFTAG_IMAGEWIDTH, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_IMAGEDIMENSIONS, 0, 0, "ImageWidth", NULL},
101
    {TIFFTAG_IMAGELENGTH, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_IMAGEDIMENSIONS, 1, 0, "ImageLength", NULL},
102
    {TIFFTAG_BITSPERSAMPLE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_BITSPERSAMPLE, 0, 0, "BitsPerSample", NULL},
103
    {TIFFTAG_COMPRESSION, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_COMPRESSION, 0, 0, "Compression", NULL},
104
    {TIFFTAG_PHOTOMETRIC, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_PHOTOMETRIC, 0, 0, "PhotometricInterpretation", NULL},
105
    {TIFFTAG_THRESHHOLDING, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_THRESHHOLDING, 1, 0, "Threshholding", NULL},
106
    {TIFFTAG_CELLWIDTH, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "CellWidth", NULL},
107
    {TIFFTAG_CELLLENGTH, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "CellLength", NULL},
108
    {TIFFTAG_FILLORDER, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_FILLORDER, 0, 0, "FillOrder", NULL},
109
    {TIFFTAG_DOCUMENTNAME, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "DocumentName", NULL},
110
    {TIFFTAG_IMAGEDESCRIPTION, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "ImageDescription", NULL},
111
    {TIFFTAG_MAKE, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "Make", NULL},
112
    {TIFFTAG_MODEL, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "Model", NULL},
113
    {TIFFTAG_STRIPOFFSETS, -1, -1, TIFF_LONG8, 0, TIFF_SETGET_UNDEFINED,  FIELD_STRIPOFFSETS, 0, 0, "StripOffsets", NULL},
114
    {TIFFTAG_ORIENTATION, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_ORIENTATION, 0, 0, "Orientation", NULL},
115
    {TIFFTAG_SAMPLESPERPIXEL, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_SAMPLESPERPIXEL, 0, 0, "SamplesPerPixel", NULL},
116
    {TIFFTAG_ROWSPERSTRIP, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_ROWSPERSTRIP, 0, 0, "RowsPerStrip", NULL},
117
    {TIFFTAG_STRIPBYTECOUNTS, -1, -1, TIFF_LONG8, 0, TIFF_SETGET_UNDEFINED,  FIELD_STRIPBYTECOUNTS, 0, 0, "StripByteCounts", NULL},
118
    {TIFFTAG_MINSAMPLEVALUE, -2, -1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_MINSAMPLEVALUE, 1, 0, "MinSampleValue", NULL},
119
    {TIFFTAG_MAXSAMPLEVALUE, -2, -1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_MAXSAMPLEVALUE, 1, 0, "MaxSampleValue", NULL},
120
    {TIFFTAG_XRESOLUTION, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_RESOLUTION, 1, 0, "XResolution", NULL},
121
    {TIFFTAG_YRESOLUTION, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_RESOLUTION, 1, 0, "YResolution", NULL},
122
    {TIFFTAG_PLANARCONFIG, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_PLANARCONFIG, 0, 0, "PlanarConfiguration", NULL},
123
    {TIFFTAG_PAGENAME, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "PageName", NULL},
124
    {TIFFTAG_XPOSITION, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_POSITION, 1, 0, "XPosition", NULL},
125
    {TIFFTAG_YPOSITION, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_POSITION, 1, 0, "YPosition", NULL},
126
    {TIFFTAG_FREEOFFSETS, -1, -1, TIFF_LONG8, 0, TIFF_SETGET_UNDEFINED,  FIELD_IGNORE, 0, 0, "FreeOffsets", NULL},
127
    {TIFFTAG_FREEBYTECOUNTS, -1, -1, TIFF_LONG8, 0, TIFF_SETGET_UNDEFINED,  FIELD_IGNORE, 0, 0, "FreeByteCounts", NULL},
128
    {TIFFTAG_GRAYRESPONSEUNIT, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UNDEFINED,  FIELD_IGNORE, 1, 0, "GrayResponseUnit", NULL},
129
    {TIFFTAG_GRAYRESPONSECURVE, -1, -1, TIFF_SHORT, 0, TIFF_SETGET_UNDEFINED,  FIELD_IGNORE, 1, 0, "GrayResponseCurve", NULL},
130
    {TIFFTAG_RESOLUTIONUNIT, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_RESOLUTIONUNIT, 1, 0, "ResolutionUnit", NULL},
131
    {TIFFTAG_PAGENUMBER, 2, 2, TIFF_SHORT, 0, TIFF_SETGET_UINT16_PAIR,  FIELD_PAGENUMBER, 1, 0, "PageNumber", NULL},
132
    {TIFFTAG_COLORRESPONSEUNIT, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UNDEFINED,  FIELD_IGNORE, 1, 0, "ColorResponseUnit", NULL},
133
    {TIFFTAG_TRANSFERFUNCTION, -1, -1, TIFF_SHORT, 0, TIFF_SETGET_OTHER,  FIELD_TRANSFERFUNCTION, 1, 0, "TransferFunction", NULL},
134
    {TIFFTAG_SOFTWARE, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "Software", NULL},
135
    {TIFFTAG_DATETIME, 20, 20, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "DateTime", NULL},
136
    {TIFFTAG_ARTIST, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "Artist", NULL},
137
    {TIFFTAG_HOSTCOMPUTER, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "HostComputer", NULL},
138
    {TIFFTAG_WHITEPOINT, 2, 2, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "WhitePoint", NULL},
139
    {TIFFTAG_PRIMARYCHROMATICITIES, 6, 6, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "PrimaryChromaticities", NULL},
140
    {TIFFTAG_COLORMAP, -1, -1, TIFF_SHORT, 0, TIFF_SETGET_OTHER,  FIELD_COLORMAP, 1, 0, "ColorMap", NULL},
141
    {TIFFTAG_HALFTONEHINTS, 2, 2, TIFF_SHORT, 0, TIFF_SETGET_UINT16_PAIR,  FIELD_HALFTONEHINTS, 1, 0, "HalftoneHints", NULL},
142
    {TIFFTAG_TILEWIDTH, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_TILEDIMENSIONS, 0, 0, "TileWidth", NULL},
143
    {TIFFTAG_TILELENGTH, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_TILEDIMENSIONS, 0, 0, "TileLength", NULL},
144
    {TIFFTAG_TILEOFFSETS, -1, 1, TIFF_LONG8, 0, TIFF_SETGET_UNDEFINED,  FIELD_STRIPOFFSETS, 0, 0, "TileOffsets", NULL},
145
    {TIFFTAG_TILEBYTECOUNTS, -1, 1, TIFF_LONG8, 0, TIFF_SETGET_UNDEFINED,  FIELD_STRIPBYTECOUNTS, 0, 0, "TileByteCounts", NULL},
146
    {TIFFTAG_SUBIFD, -1, -1, TIFF_IFD8, 0, TIFF_SETGET_C16_IFD8,  FIELD_SUBIFD, 1, 1, "SubIFD", (TIFFFieldArray *)&tiffFieldArray},
147
    {TIFFTAG_INKSET, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 0, 0, "InkSet", NULL},
148
    {TIFFTAG_INKNAMES, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_C16_ASCII,  FIELD_INKNAMES, 1, 1, "InkNames", NULL},
149
    {TIFFTAG_NUMBEROFINKS, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_NUMBEROFINKS, 1, 0, "NumberOfInks", NULL},
150
    {TIFFTAG_DOTRANGE, 2, 2, TIFF_SHORT, 0, TIFF_SETGET_UINT16_PAIR,  FIELD_CUSTOM, 0, 0, "DotRange", NULL},
151
    {TIFFTAG_TARGETPRINTER, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "TargetPrinter", NULL},
152
    {TIFFTAG_EXTRASAMPLES, -1, -1, TIFF_SHORT, 0, TIFF_SETGET_C16_UINT16,  FIELD_EXTRASAMPLES, 0, 1, "ExtraSamples", NULL},
153
    {TIFFTAG_SAMPLEFORMAT, -1, -1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_SAMPLEFORMAT, 0, 0, "SampleFormat", NULL},
154
    {TIFFTAG_SMINSAMPLEVALUE, -2, -1, TIFF_ANY, 0, TIFF_SETGET_DOUBLE,  FIELD_SMINSAMPLEVALUE, 1, 0, "SMinSampleValue", NULL},
155
    {TIFFTAG_SMAXSAMPLEVALUE, -2, -1, TIFF_ANY, 0, TIFF_SETGET_DOUBLE,  FIELD_SMAXSAMPLEVALUE, 1, 0, "SMaxSampleValue", NULL},
156
    {TIFFTAG_CLIPPATH, -3, -3, TIFF_BYTE, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 0, 1, "ClipPath", NULL},
157
    {TIFFTAG_XCLIPPATHUNITS, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 0, 0, "XClipPathUnits", NULL},
158
    {TIFFTAG_YCLIPPATHUNITS, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 0, 0, "YClipPathUnits", NULL},
159
    {TIFFTAG_YCBCRCOEFFICIENTS, 3, 3, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 0, 0, "YCbCrCoefficients", NULL},
160
    {TIFFTAG_YCBCRSUBSAMPLING, 2, 2, TIFF_SHORT, 0, TIFF_SETGET_UINT16_PAIR,  FIELD_YCBCRSUBSAMPLING, 0, 0, "YCbCrSubsampling", NULL},
161
    {TIFFTAG_YCBCRPOSITIONING, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_YCBCRPOSITIONING, 0, 0, "YCbCrPositioning", NULL},
162
    {TIFFTAG_REFERENCEBLACKWHITE, 6, 6, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_REFBLACKWHITE, 1, 0, "ReferenceBlackWhite", NULL},
163
    {TIFFTAG_XMLPACKET, -3, -3, TIFF_BYTE, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "XMLPacket", NULL},
164
    /* begin SGI tags */
165
    {TIFFTAG_MATTEING, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_EXTRASAMPLES, 0, 0, "Matteing", NULL},
166
    {TIFFTAG_DATATYPE, -2, -1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_SAMPLEFORMAT, 0, 0, "DataType", NULL},
167
    {TIFFTAG_IMAGEDEPTH, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_IMAGEDEPTH, 0, 0, "ImageDepth", NULL},
168
    {TIFFTAG_TILEDEPTH, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_TILEDEPTH, 0, 0, "TileDepth", NULL},
169
    /* end SGI tags */
170
    /* begin Pixar tags */
171
    {TIFFTAG_PIXAR_IMAGEFULLWIDTH, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "ImageFullWidth", NULL},
172
    {TIFFTAG_PIXAR_IMAGEFULLLENGTH, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "ImageFullLength", NULL},
173
    {TIFFTAG_PIXAR_TEXTUREFORMAT, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "TextureFormat", NULL},
174
    {TIFFTAG_PIXAR_WRAPMODES, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "TextureWrapModes", NULL},
175
    {TIFFTAG_PIXAR_FOVCOT, 1, 1, TIFF_FLOAT, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "FieldOfViewCotangent", NULL},
176
    {TIFFTAG_PIXAR_MATRIX_WORLDTOSCREEN, 16, 16, TIFF_FLOAT, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "MatrixWorldToScreen", NULL},
177
    {TIFFTAG_PIXAR_MATRIX_WORLDTOCAMERA, 16, 16, TIFF_FLOAT, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "MatrixWorldToCamera", NULL},
178
    {TIFFTAG_COPYRIGHT, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "Copyright", NULL},
179
    /* end Pixar tags */
180
    {TIFFTAG_RICHTIFFIPTC, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "RichTIFFIPTC", NULL},
181
    {TIFFTAG_PHOTOSHOP, -3, -3, TIFF_BYTE, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "Photoshop", NULL},
182
    /*--: EXIFIFD and GPSIFD specified as TIFF_LONG by Aware-Systems and not TIFF_IFD8 as in original LibTiff. However, for IFD-like tags,
183
     * libtiff uses the data type TIFF_IFD8 in tiffFields[]-tag definition combined with a special handling procedure in order to write either
184
     * a 32-bit value and the TIFF_IFD type-id into ClassicTIFF files or a 64-bit value and the TIFF_IFD8 type-id into BigTIFF files. */
185
    {TIFFTAG_EXIFIFD, 1, 1, TIFF_LONG8, 0, TIFF_SETGET_UINT64,  FIELD_CUSTOM, 1, 0, "EXIFIFDOffset", (TIFFFieldArray *)&exifFieldArray},
186
    {TIFFTAG_ICCPROFILE, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "ICC Profile", NULL},
187
    {TIFFTAG_GPSIFD, 1, 1, TIFF_LONG8, 0, TIFF_SETGET_UINT64,  FIELD_CUSTOM, 1, 0, "GPSIFDOffset", (TIFFFieldArray *)&gpsFieldArray},
188
    {TIFFTAG_FAXRECVPARAMS, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, TRUE, FALSE, "FaxRecvParams", NULL},
189
    {TIFFTAG_FAXSUBADDRESS, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, TRUE, FALSE, "FaxSubAddress", NULL},
190
    {TIFFTAG_FAXRECVTIME, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, TRUE, FALSE, "FaxRecvTime", NULL},
191
    {TIFFTAG_FAXDCS, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, TRUE, FALSE, "FaxDcs", NULL},
192
    {TIFFTAG_STONITS, 1, 1, TIFF_DOUBLE, 0, TIFF_SETGET_DOUBLE,  FIELD_CUSTOM, 0, 0, "StoNits", NULL},
193
    {TIFFTAG_IMAGESOURCEDATA, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "Adobe Photoshop Document Data Block", NULL},
194
    {TIFFTAG_INTEROPERABILITYIFD, 1, 1, TIFF_IFD8, 0, TIFF_SETGET_IFD8,  FIELD_CUSTOM, 0, 0, "InteroperabilityIFDOffset", NULL},
195
    /* begin DNG tags */
196
    {TIFFTAG_DNGVERSION, 4, 4, TIFF_BYTE, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "DNGVersion", NULL},
197
    {TIFFTAG_DNGBACKWARDVERSION, 4, 4, TIFF_BYTE, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "DNGBackwardVersion", NULL},
198
    {TIFFTAG_UNIQUECAMERAMODEL, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "UniqueCameraModel", NULL},
199
    {TIFFTAG_LOCALIZEDCAMERAMODEL, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "LocalizedCameraModel", NULL},
200
    {TIFFTAG_CFAPLANECOLOR, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "CFAPlaneColor", NULL},
201
    {TIFFTAG_CFALAYOUT, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "CFALayout", NULL},
202
    {TIFFTAG_LINEARIZATIONTABLE, -1, -1, TIFF_SHORT, 0, TIFF_SETGET_C16_UINT16,  FIELD_CUSTOM, 1, 1, "LinearizationTable", NULL},
203
    {TIFFTAG_BLACKLEVELREPEATDIM, 2, 2, TIFF_SHORT, 0, TIFF_SETGET_C0_UINT16,  FIELD_CUSTOM, 1, 0, "BlackLevelRepeatDim", NULL},
204
    {TIFFTAG_BLACKLEVEL, -1, -1, TIFF_RATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "BlackLevel", NULL},
205
    {TIFFTAG_BLACKLEVELDELTAH, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "BlackLevelDeltaH", NULL},
206
    {TIFFTAG_BLACKLEVELDELTAV, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "BlackLevelDeltaV", NULL},
207
    {TIFFTAG_WHITELEVEL, -1, -1, TIFF_LONG, 0, TIFF_SETGET_C16_UINT32,  FIELD_CUSTOM, 1, 1, "WhiteLevel", NULL},
208
    {TIFFTAG_DEFAULTSCALE, 2, 2, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "DefaultScale", NULL},
209
    {TIFFTAG_BESTQUALITYSCALE, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "BestQualityScale", NULL},
210
    {TIFFTAG_DEFAULTCROPORIGIN, 2, 2, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "DefaultCropOrigin", NULL},
211
    {TIFFTAG_DEFAULTCROPSIZE, 2, 2, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "DefaultCropSize", NULL},
212
    {TIFFTAG_COLORMATRIX1, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ColorMatrix1", NULL},
213
    {TIFFTAG_COLORMATRIX2, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ColorMatrix2", NULL},
214
    {TIFFTAG_CAMERACALIBRATION1, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "CameraCalibration1", NULL},
215
    {TIFFTAG_CAMERACALIBRATION2, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "CameraCalibration2", NULL},
216
    {TIFFTAG_REDUCTIONMATRIX1, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ReductionMatrix1", NULL},
217
    {TIFFTAG_REDUCTIONMATRIX2, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ReductionMatrix2", NULL},
218
    {TIFFTAG_ANALOGBALANCE, -1, -1, TIFF_RATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "AnalogBalance", NULL},
219
    {TIFFTAG_ASSHOTNEUTRAL, -1, -1, TIFF_RATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "AsShotNeutral", NULL},
220
    {TIFFTAG_ASSHOTWHITEXY, 2, 2, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "AsShotWhiteXY", NULL},
221
    {TIFFTAG_BASELINEEXPOSURE, 1, 1, TIFF_SRATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "BaselineExposure", NULL},
222
    {TIFFTAG_BASELINENOISE, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "BaselineNoise", NULL},
223
    {TIFFTAG_BASELINESHARPNESS, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "BaselineSharpness", NULL},
224
    {TIFFTAG_BAYERGREENSPLIT, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "BayerGreenSplit", NULL},
225
    {TIFFTAG_LINEARRESPONSELIMIT, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "LinearResponseLimit", NULL},
226
    {TIFFTAG_CAMERASERIALNUMBER, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "CameraSerialNumber", NULL},
227
    {TIFFTAG_LENSINFO, 4, 4, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "LensInfo", NULL},
228
    {TIFFTAG_CHROMABLURRADIUS, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "ChromaBlurRadius", NULL},
229
    {TIFFTAG_ANTIALIASSTRENGTH, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "AntiAliasStrength", NULL},
230
    {TIFFTAG_SHADOWSCALE, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "ShadowScale", NULL},
231
    {TIFFTAG_DNGPRIVATEDATA, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "DNGPrivateData", NULL},
232
    {TIFFTAG_MAKERNOTESAFETY, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "MakerNoteSafety", NULL},
233
    {TIFFTAG_CALIBRATIONILLUMINANT1, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "CalibrationIlluminant1", NULL},
234
    {TIFFTAG_CALIBRATIONILLUMINANT2, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "CalibrationIlluminant2", NULL},
235
    {TIFFTAG_RAWDATAUNIQUEID, 16, 16, TIFF_BYTE, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "RawDataUniqueID", NULL},
236
    {TIFFTAG_ORIGINALRAWFILENAME, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "OriginalRawFileName", NULL},
237
    {TIFFTAG_ORIGINALRAWFILEDATA, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "OriginalRawFileData", NULL},
238
    {TIFFTAG_ACTIVEAREA, 4, 4, TIFF_LONG, 0, TIFF_SETGET_C0_UINT32,  FIELD_CUSTOM, 1, 0, "ActiveArea", NULL},
239
    {TIFFTAG_MASKEDAREAS, -1, -1, TIFF_LONG, 0, TIFF_SETGET_C16_UINT32,  FIELD_CUSTOM, 1, 1, "MaskedAreas", NULL},
240
    {TIFFTAG_ASSHOTICCPROFILE, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "AsShotICCProfile", NULL},
241
    {TIFFTAG_ASSHOTPREPROFILEMATRIX, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "AsShotPreProfileMatrix", NULL},
242
    {TIFFTAG_CURRENTICCPROFILE, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "CurrentICCProfile", NULL},
243
    {TIFFTAG_CURRENTPREPROFILEMATRIX, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "CurrentPreProfileMatrix", NULL},
244
    {TIFFTAG_PERSAMPLE, 0, 0, TIFF_SHORT, 0, TIFF_SETGET_UNDEFINED,  FIELD_PSEUDO, TRUE, FALSE, "PerSample", NULL},
245
#if 0
246
    /* begin DNG 1.2.0.0 tags */
247
    {TIFFTAG_COLORIMETRICREFERENCE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "ColorimetricReference", NULL},
248
    {TIFFTAG_CAMERACALIBRATIONSIGNATURE, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "CameraCalibrationSignature", NULL},
249
    {TIFFTAG_PROFILECALIBRATIONSIGNATURE, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "ProfileCalibrationSignature", NULL},
250
    {TIFFTAG_EXTRACAMERAPROFILES, -1, -1, TIFF_IFD8, 0, TIFF_SETGET_C16_IFD8,  FIELD_CUSTOM, 1, 1, "ExtraCameraProfiles", NULL},
251
    {TIFFTAG_ASSHOTPROFILENAME, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "AsShotProfileName", NULL},
252
    {TIFFTAG_NOISEREDUCTIONAPPLIED, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "NoiseReductionApplied", NULL},
253
    {TIFFTAG_PROFILENAME, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "ProfileName", NULL},
254
    {TIFFTAG_PROFILEHUESATMAPDIMS, 3, 3, TIFF_LONG, 0, TIFF_SETGET_C0_UINT32,  FIELD_CUSTOM, 1, 0, "ProfileHueSatMapDims", NULL},
255
    {TIFFTAG_PROFILEHUESATMAPDATA1, -1, -1, TIFF_FLOAT, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ProfileHueSatMapData1", NULL},
256
    {TIFFTAG_PROFILEHUESATMAPDATA2, -1, -1, TIFF_FLOAT, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ProfileHueSatMapData2", NULL},
257
    {TIFFTAG_PROFILETONECURVE, -1, -1, TIFF_FLOAT, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ProfileToneCurve", NULL},
258
    {TIFFTAG_PROFILEEMBEDPOLICY, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "ProfileEmbedPolicy", NULL},
259
    {TIFFTAG_PROFILECOPYRIGHT, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "ProfileCopyright", NULL},
260
    {TIFFTAG_FORWARDMATRIX1, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ForwardMatrix1", NULL},
261
    {TIFFTAG_FORWARDMATRIX2, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ForwardMatrix2", NULL},
262
    {TIFFTAG_PREVIEWAPPLICATIONNAME, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "PreviewApplicationName", NULL},
263
    {TIFFTAG_PREVIEWAPPLICATIONVERSION, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "PreviewApplicationVersion", NULL},
264
    {TIFFTAG_PREVIEWSETTINGSNAME, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "PreviewSettingsName", NULL},
265
    {TIFFTAG_PREVIEWSETTINGSDIGEST, 16, 16, TIFF_BYTE, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "PreviewSettingsDigest", NULL},
266
    {TIFFTAG_PREVIEWCOLORSPACE, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "PreviewColorSpace", NULL},
267
    {TIFFTAG_PREVIEWDATETIME, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "PreviewDateTime", NULL},
268
    {TIFFTAG_RAWIMAGEDIGEST, 16, 16, TIFF_BYTE, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "RawImageDigest", NULL},
269
    {TIFFTAG_ORIGINALRAWFILEDIGEST, 16, 16, TIFF_BYTE, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "OriginalRawFileDigest", NULL},
270
    {TIFFTAG_SUBTILEBLOCKSIZE, 2, 2, TIFF_LONG, 0, TIFF_SETGET_C0_UINT32,  FIELD_CUSTOM, 1, 0, "SubTileBlockSize", NULL},
271
    {TIFFTAG_ROWINTERLEAVEFACTOR, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "RowInterleaveFactor", NULL},
272
    {TIFFTAG_PROFILELOOKTABLEDIMS, 3, 3, TIFF_LONG, 0, TIFF_SETGET_C0_UINT32,  FIELD_CUSTOM, 1, 0, "ProfileLookTableDims", NULL},
273
    {TIFFTAG_PROFILELOOKTABLEDATA, -1, -1, TIFF_FLOAT, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ProfileLookTableData", NULL},
274
    /* begin DNG 1.3.0.0 tags */
275
    {TIFFTAG_OPCODELIST1, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "OpcodeList1", NULL},
276
    {TIFFTAG_OPCODELIST2, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "OpcodeList2", NULL},
277
    {TIFFTAG_OPCODELIST3, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "OpcodeList3", NULL},
278
    {TIFFTAG_NOISEPROFILE, -1, -1, TIFF_DOUBLE, 0, TIFF_SETGET_C16_DOUBLE,  FIELD_CUSTOM, 1, 1, "NoiseProfile", NULL},
279
    /* begin DNG 1.4.0.0 tags */
280
    {TIFFTAG_DEFAULTUSERCROP, 4, 4, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "DefaultUserCrop", NULL},
281
    {TIFFTAG_DEFAULTBLACKRENDER, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "DefaultBlackRender", NULL},
282
    {TIFFTAG_BASELINEEXPOSUREOFFSET, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "BaselineExposureOffset", NULL},
283
    {TIFFTAG_PROFILELOOKTABLEENCODING, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "ProfileLookTableEncoding", NULL},
284
    {TIFFTAG_PROFILEHUESATMAPENCODING, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "ProfileHueSatMapEncoding", NULL},
285
    {TIFFTAG_ORIGINALDEFAULTFINALSIZE, 2, 2, TIFF_LONG, 0, TIFF_SETGET_C0_UINT32,  FIELD_CUSTOM, 1, 0, "OriginalDefaultFinalSize", NULL},
286
    {TIFFTAG_ORIGINALBESTQUALITYFINALSIZE, 2, 2, TIFF_LONG, 0, TIFF_SETGET_C0_UINT32,  FIELD_CUSTOM, 1, 0, "OriginalBestQualityFinalSize", NULL},
287
    {TIFFTAG_ORIGINALDEFAULTCROPSIZE, 2, 2, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "OriginalDefaultCropSize", NULL}, /* could also be rational */
288
    {TIFFTAG_NEWRAWIMAGEDIGEST, 16, 16, TIFF_BYTE, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "NewRawImageDigest", NULL},
289
    {TIFFTAG_RAWTOPREVIEWGAIN, 1, 1, TIFF_DOUBLE, 0, TIFF_SETGET_DOUBLE,  FIELD_CUSTOM, 1, 0, "RawToPreviewGain", NULL},
290
    /* begin DNG 1.5.0.0 tags */
291
    {TIFFTAG_DEPTHFORMAT, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "DepthFormat", NULL},
292
    {TIFFTAG_DEPTHNEAR, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "DepthNear", NULL},
293
    {TIFFTAG_DEPTHFAR, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "DepthFar", NULL},
294
    {TIFFTAG_DEPTHUNITS, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "DepthUnits", NULL},
295
    {TIFFTAG_DEPTHMEASURETYPE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "DepthMeasureType", NULL},
296
    {TIFFTAG_ENHANCEPARAMS, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "EnhanceParams", NULL},
297
    /* begin DNG 1.6.0.0 tags */
298
    {TIFFTAG_PROFILEGAINTABLEMAP, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "ProfileGainTableMap", NULL},
299
    {TIFFTAG_SEMANTICNAME, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "SemanticName", NULL},
300
    {TIFFTAG_SEMANTICINSTANCEID, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "SemanticInstanceID", NULL},
301
    {TIFFTAG_MASKSUBAREA, 4, 4, TIFF_LONG, 0, TIFF_SETGET_C0_UINT32,  FIELD_CUSTOM, 1, 0, "MaskSubArea", NULL},
302
    {TIFFTAG_RGBTABLES, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "RGBTables", NULL},
303
    {TIFFTAG_CALIBRATIONILLUMINANT3, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "CalibrationIlluminant3", NULL},
304
    {TIFFTAG_COLORMATRIX3, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ColorMatrix3", NULL},
305
    {TIFFTAG_CAMERACALIBRATION3, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "CameraCalibration3", NULL},
306
    {TIFFTAG_REDUCTIONMATRIX3, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ReductionMatrix3", NULL},
307
    {TIFFTAG_PROFILEHUESATMAPDATA3, -1, -1, TIFF_FLOAT, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ProfileHueSatMapData3", NULL},
308
    {TIFFTAG_FORWARDMATRIX3, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "ForwardMatrix3", NULL},
309
    {TIFFTAG_ILLUMINANTDATA1, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "IlluminantData1", NULL},
310
    {TIFFTAG_ILLUMINANTDATA2, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "IlluminantData2", NULL},
311
    {TIFFTAG_ILLUMINANTDATA3, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "IlluminantData3", NULL},
312
    /* end DNG tags */
313
#endif
314
    /* begin TIFF/EP tags */
315
    {TIFFTAG_EP_CFAREPEATPATTERNDIM, 2, 2, TIFF_SHORT, 0, TIFF_SETGET_C0_UINT16,  FIELD_CUSTOM, 1, 0, "EP CFARepeatPatternDim", NULL},
316
    {TIFFTAG_EP_CFAPATTERN, -1, -1, TIFF_BYTE, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "EP CFAPattern", NULL},
317
#if 0
318
    /* TIFFTAG_EP_BATTERYLEVEL can be RATIONAL or ASCII.
319
     * LibTiff defines it as ASCII and converts RATIONAL to an ASCII string. */
320
    {TIFFTAG_EP_BATTERYLEVEL, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "EP BatteryLevel", NULL},
321
    {TIFFTAG_EP_INTERLACE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "EP Interlace", NULL},
322
    /* TIFFTAG_EP_IPTC_NAA and TIFFTAG_RICHTIFFIPTC share the same tag number (33723)
323
     *   LibTIFF type is UNDEFINED or BYTE, but often times incorrectly specified as LONG, because TIFF/EP (ISO/DIS 12234-2) specifies type LONG or ASCII. */
324
    {TIFFTAG_EP_TIMEZONEOFFSET, -1, -1, TIFF_SSHORT, 0, TIFF_SETGET_C16_UINT16,  FIELD_CUSTOM, 1, 1, "EP TimeZoneOffset", NULL},
325
    {TIFFTAG_EP_SELFTIMERMODE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "EP SelfTimerMode", NULL},
326
    {TIFFTAG_EP_FLASHENERGY, -1, -1, TIFF_RATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "EP FlashEnergy", NULL},
327
    {TIFFTAG_EP_SPATIALFREQUENCYRESPONSE, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "EP SpatialFrequencyResponse", NULL},
328
    {TIFFTAG_EP_NOISE, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "EP Noise", NULL},
329
    {TIFFTAG_EP_FOCALPLANEXRESOLUTION, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "EP FocalPlaneXResolution", NULL},
330
    {TIFFTAG_EP_FOCALPLANEYRESOLUTION, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "EP FocalPlaneYResolution", NULL},
331
    {TIFFTAG_EP_FOCALPLANERESOLUTIONUNIT, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "EP FocalPlaneResolutionUnit", NULL},
332
    {TIFFTAG_EP_IMAGENUMBER, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "EP ImageNumber", NULL}, /* or SHORT */
333
    {TIFFTAG_EP_SECURITYCLASSIFICATION, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "EP SecurityClassification", NULL},
334
    {TIFFTAG_EP_IMAGEHISTORY, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "EP ImageHistory", NULL},
335
    {TIFFTAG_EP_EXPOSUREINDEX, -1, -1, TIFF_RATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "EP ExposureIndex", NULL},
336
    {TIFFTAG_EP_STANDARDID, 4, 4, TIFF_BYTE, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "EP StandardId", NULL},
337
    {TIFFTAG_EP_SENSINGMETHOD, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "EP SensingMethod", NULL},
338
    /* TIFF/EP tags equivalent to EXIF tags, sometimes defined differently. */
339
    {TIFFTAG_EP_EXPOSURETIME, -1, -1, TIFF_RATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "EP ExposureTime", NULL}, /*N=1 or 2 */
340
    {TIFFTAG_EP_FNUMBER, -1, -1, TIFF_RATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "EP FNumber", NULL},
341
    {TIFFTAG_EP_EXPOSUREPROGRAM, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "EP ExposureProgram", NULL},
342
    {TIFFTAG_EP_SPECTRALSENSITIVITY, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "EP SpectralSensitivity", NULL},
343
    {TIFFTAG_EP_ISOSPEEDRATINGS, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "EP ISOSpeedRatings", NULL},
344
    {TIFFTAG_EP_OECF, -3, -3, TIFF_UNDEFINED, 0, TIFF_SETGET_C32_UINT8,  FIELD_CUSTOM, 1, 1, "EP OptoelectricConversionFactor", NULL},
345
    {TIFFTAG_EP_DATETIMEORIGINAL, 20, 20, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "EP DateTimeOriginal", NULL},
346
    {TIFFTAG_EP_COMPRESSEDBITSPERPIXEL, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "EP CompressedBitsPerPixel", NULL},
347
    {TIFFTAG_EP_SHUTTERSPEEDVALUE, 1, 1, TIFF_SRATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "EP ShutterSpeedValue", NULL},
348
    {TIFFTAG_EP_APERTUREVALUE, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "EP ApertureValue", NULL},
349
    {TIFFTAG_EP_BRIGHTNESSVALUE, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "EP BrightnessValue", NULL},
350
    {TIFFTAG_EP_EXPOSUREBIASVALUE, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "EP ExposureBiasValue", NULL}, /*N=1 or 2 */
351
    {TIFFTAG_EP_MAXAPERTUREVALUE, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "EP MaxApertureValue", NULL},
352
    {TIFFTAG_EP_SUBJECTDISTANCE, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "EP SubjectDistance", NULL},
353
    {TIFFTAG_EP_METERINGMODE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "EP MeteringMode", NULL},
354
    {TIFFTAG_EP_LIGHTSOURCE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "EP LightSource", NULL},
355
    {TIFFTAG_EP_FLASH, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "EP Flash", NULL},
356
    {TIFFTAG_EP_FOCALLENGTH, -1, -1, TIFF_RATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "EP FocalLength", NULL},
357
    {TIFFTAG_EP_SUBJECTLOCATION, -1, -1, TIFF_SHORT, 0, TIFF_SETGET_C16_UINT16,  FIELD_CUSTOM, 1, 1, "EP SubjectLocation", NULL},
358
    /* end TIFF/EP tags */
359
#endif
360
    /* begin TIFF/FX tags */
361
    {TIFFTAG_INDEXED, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "Indexed", NULL},
362
    {TIFFTAG_GLOBALPARAMETERSIFD, 1, 1, TIFF_IFD8, 0, TIFF_SETGET_IFD8,  FIELD_CUSTOM, 1, 0, "GlobalParametersIFD", NULL},
363
    {TIFFTAG_PROFILETYPE, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "ProfileType", NULL},
364
    {TIFFTAG_FAXPROFILE, 1, 1, TIFF_BYTE, 0, TIFF_SETGET_UINT8,  FIELD_CUSTOM, 1, 0, "FaxProfile", NULL},
365
    {TIFFTAG_CODINGMETHODS, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "CodingMethods", NULL},
366
    {TIFFTAG_VERSIONYEAR, 4, 4, TIFF_BYTE, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "VersionYear", NULL},
367
    {TIFFTAG_MODENUMBER, 1, 1, TIFF_BYTE, 0, TIFF_SETGET_UINT8,  FIELD_CUSTOM, 1, 0, "ModeNumber", NULL},
368
    {TIFFTAG_DECODE, -1, -1, TIFF_SRATIONAL, 0, TIFF_SETGET_C16_FLOAT,  FIELD_CUSTOM, 1, 1, "Decode", NULL},
369
    {TIFFTAG_IMAGEBASECOLOR, -1, -1, TIFF_SHORT, 0, TIFF_SETGET_C16_UINT16,  FIELD_CUSTOM, 1, 1, "ImageBaseColor", NULL},
370
    {TIFFTAG_T82OPTIONS, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "T82Options", NULL},
371
    {TIFFTAG_STRIPROWCOUNTS, -1, -1, TIFF_LONG, 0, TIFF_SETGET_C16_UINT32,  FIELD_CUSTOM, 1, 1, "StripRowCounts", NULL},
372
    {TIFFTAG_IMAGELAYER, 2, 2, TIFF_LONG, 0, TIFF_SETGET_C0_UINT32,  FIELD_CUSTOM, 1, 0, "ImageLayer", NULL},
373
    /* end TIFF/FX tags */
374
    /* begin pseudo tags */
375
};
376
377
/*
378
 * EXIF tags  (Version 2.31, July 2016 plus version 2.32 May 2019)
379
 */
380
static const TIFFField exifFields[] = {
381
    {EXIFTAG_EXPOSURETIME, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "ExposureTime", NULL},
382
    {EXIFTAG_FNUMBER, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "FNumber", NULL},
383
    {EXIFTAG_EXPOSUREPROGRAM, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "ExposureProgram", NULL},
384
    {EXIFTAG_SPECTRALSENSITIVITY, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "SpectralSensitivity", NULL},
385
    /* After EXIF 2.2.1 ISOSpeedRatings is named PhotographicSensitivity. In addition, while "Count=Any", only 1 count should be used. */
386
    {EXIFTAG_ISOSPEEDRATINGS, -1, -1, TIFF_SHORT, 0, TIFF_SETGET_C16_UINT16,  FIELD_CUSTOM, 1, 1, "ISOSpeedRatings", NULL},
387
    {EXIFTAG_OECF, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "OptoelectricConversionFactor", NULL},
388
    {EXIFTAG_SENSITIVITYTYPE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "SensitivityType", NULL},
389
    {EXIFTAG_STANDARDOUTPUTSENSITIVITY, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "StandardOutputSensitivity", NULL},
390
    {EXIFTAG_RECOMMENDEDEXPOSUREINDEX, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "RecommendedExposureIndex", NULL},
391
    {EXIFTAG_ISOSPEED, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "ISOSpeed", NULL},
392
    {EXIFTAG_ISOSPEEDLATITUDEYYY, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "ISOSpeedLatitudeyyy", NULL},
393
    {EXIFTAG_ISOSPEEDLATITUDEZZZ, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "ISOSpeedLatitudezzz", NULL},
394
    {EXIFTAG_EXIFVERSION, 4, 4, TIFF_UNDEFINED, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "ExifVersion", NULL},
395
    {EXIFTAG_DATETIMEORIGINAL, 20, 20, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "DateTimeOriginal", NULL},
396
    {EXIFTAG_DATETIMEDIGITIZED, 20, 20, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "DateTimeDigitized", NULL},
397
    {EXIFTAG_OFFSETTIME, 7, 7, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "OffsetTime", NULL},
398
    {EXIFTAG_OFFSETTIMEORIGINAL, 7, 7, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "OffsetTimeOriginal", NULL},
399
    {EXIFTAG_OFFSETTIMEDIGITIZED, 7, 7, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "OffsetTimeDigitized", NULL},
400
    {EXIFTAG_COMPONENTSCONFIGURATION, 4, 4, TIFF_UNDEFINED, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "ComponentsConfiguration", NULL},
401
    {EXIFTAG_COMPRESSEDBITSPERPIXEL, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "CompressedBitsPerPixel", NULL},
402
    {EXIFTAG_SHUTTERSPEEDVALUE, 1, 1, TIFF_SRATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "ShutterSpeedValue", NULL},
403
    {EXIFTAG_APERTUREVALUE, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "ApertureValue", NULL},
404
    {EXIFTAG_BRIGHTNESSVALUE, 1, 1, TIFF_SRATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "BrightnessValue", NULL},
405
    {EXIFTAG_EXPOSUREBIASVALUE, 1, 1, TIFF_SRATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "ExposureBiasValue", NULL},
406
    {EXIFTAG_MAXAPERTUREVALUE, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "MaxApertureValue", NULL},
407
    /*--: EXIFTAG_SUBJECTDISTANCE: LibTiff returns value of "-1" if numerator equals 4294967295 (0xFFFFFFFF) to indicate infinite distance!
408
     *    However, there are two other EXIF tags where numerator indicates a special value and six other cases where the denominator indicates special values,
409
     *    which are not treated within LibTiff!! */
410
    {EXIFTAG_SUBJECTDISTANCE, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "SubjectDistance", NULL},
411
    {EXIFTAG_METERINGMODE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "MeteringMode", NULL},
412
    {EXIFTAG_LIGHTSOURCE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "LightSource", NULL},
413
    {EXIFTAG_FLASH, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "Flash", NULL},
414
    {EXIFTAG_FOCALLENGTH, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "FocalLength", NULL},
415
    {EXIFTAG_SUBJECTAREA, -1, -1, TIFF_SHORT, 0, TIFF_SETGET_C16_UINT16,  FIELD_CUSTOM, 1, 1, "SubjectArea", NULL},
416
    {EXIFTAG_MAKERNOTE, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "MakerNote", NULL},
417
    {EXIFTAG_USERCOMMENT, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "UserComment", NULL},
418
    {EXIFTAG_SUBSECTIME, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "SubSecTime", NULL},
419
    {EXIFTAG_SUBSECTIMEORIGINAL, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "SubSecTimeOriginal", NULL},
420
    {EXIFTAG_SUBSECTIMEDIGITIZED, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "SubSecTimeDigitized", NULL},
421
    {EXIFTAG_TEMPERATURE, 1, 1, TIFF_SRATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "Temperature", NULL},
422
    {EXIFTAG_HUMIDITY, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "Humidity", NULL},
423
    {EXIFTAG_PRESSURE, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "Pressure", NULL},
424
    {EXIFTAG_WATERDEPTH, 1, 1, TIFF_SRATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "WaterDepth", NULL},
425
    {EXIFTAG_ACCELERATION, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "Acceleration", NULL},
426
    {EXIFTAG_CAMERAELEVATIONANGLE, 1, 1, TIFF_SRATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "CameraElevationAngle", NULL},
427
    {EXIFTAG_FLASHPIXVERSION, 4, 4, TIFF_UNDEFINED, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "FlashpixVersion", NULL},
428
    {EXIFTAG_COLORSPACE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "ColorSpace", NULL},
429
    {EXIFTAG_PIXELXDIMENSION, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "PixelXDimension", NULL},
430
    {EXIFTAG_PIXELYDIMENSION, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32,  FIELD_CUSTOM, 1, 0, "PixelYDimension", NULL},
431
    {EXIFTAG_RELATEDSOUNDFILE, 13, 13, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "RelatedSoundFile", NULL},
432
    {EXIFTAG_FLASHENERGY, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "FlashEnergy", NULL},
433
    {EXIFTAG_SPATIALFREQUENCYRESPONSE, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "SpatialFrequencyResponse", NULL},
434
    {EXIFTAG_FOCALPLANEXRESOLUTION, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "FocalPlaneXResolution", NULL},
435
    {EXIFTAG_FOCALPLANEYRESOLUTION, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "FocalPlaneYResolution", NULL},
436
    {EXIFTAG_FOCALPLANERESOLUTIONUNIT, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "FocalPlaneResolutionUnit", NULL},
437
    {EXIFTAG_SUBJECTLOCATION, 2, 2, TIFF_SHORT, 0, TIFF_SETGET_C0_UINT16,  FIELD_CUSTOM, 1, 0, "SubjectLocation", NULL},
438
    {EXIFTAG_EXPOSUREINDEX, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "ExposureIndex", NULL},
439
    {EXIFTAG_SENSINGMETHOD, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "SensingMethod", NULL},
440
    {EXIFTAG_FILESOURCE, 1, 1, TIFF_UNDEFINED, 0, TIFF_SETGET_UINT8,  FIELD_CUSTOM, 1, 0, "FileSource", NULL},
441
    {EXIFTAG_SCENETYPE, 1, 1, TIFF_UNDEFINED, 0, TIFF_SETGET_UINT8,  FIELD_CUSTOM, 1, 0, "SceneType", NULL},
442
    {EXIFTAG_CFAPATTERN, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "CFAPattern", NULL},
443
    {EXIFTAG_CUSTOMRENDERED, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "CustomRendered", NULL},
444
    {EXIFTAG_EXPOSUREMODE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "ExposureMode", NULL},
445
    {EXIFTAG_WHITEBALANCE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "WhiteBalance", NULL},
446
    {EXIFTAG_DIGITALZOOMRATIO, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "DigitalZoomRatio", NULL},
447
    {EXIFTAG_FOCALLENGTHIN35MMFILM, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "FocalLengthIn35mmFilm", NULL},
448
    {EXIFTAG_SCENECAPTURETYPE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "SceneCaptureType", NULL},
449
    {EXIFTAG_GAINCONTROL, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "GainControl", NULL},
450
    {EXIFTAG_CONTRAST, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "Contrast", NULL},
451
    {EXIFTAG_SATURATION, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "Saturation", NULL},
452
    {EXIFTAG_SHARPNESS, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "Sharpness", NULL},
453
    {EXIFTAG_DEVICESETTINGDESCRIPTION, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "DeviceSettingDescription", NULL},
454
    {EXIFTAG_SUBJECTDISTANCERANGE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "SubjectDistanceRange", NULL},
455
    {EXIFTAG_IMAGEUNIQUEID, 33, 33, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "ImageUniqueID", NULL},
456
    {EXIFTAG_CAMERAOWNERNAME, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "CameraOwnerName", NULL},
457
    {EXIFTAG_BODYSERIALNUMBER, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "BodySerialNumber", NULL},
458
    {EXIFTAG_LENSSPECIFICATION, 4, 4, TIFF_RATIONAL, 0, TIFF_SETGET_C0_FLOAT,  FIELD_CUSTOM, 1, 0, "LensSpecification", NULL},
459
    {EXIFTAG_LENSMAKE, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "LensMake", NULL},
460
    {EXIFTAG_LENSMODEL, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "LensModel", NULL},
461
    {EXIFTAG_LENSSERIALNUMBER, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "LensSerialNumber", NULL},
462
    {EXIFTAG_GAMMA, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_FLOAT,  FIELD_CUSTOM, 1, 0, "Gamma", NULL},
463
    {EXIFTAG_COMPOSITEIMAGE, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "CompositeImage", NULL},
464
    {EXIFTAG_SOURCEIMAGENUMBEROFCOMPOSITEIMAGE, 2, 2, TIFF_SHORT, 0, TIFF_SETGET_C0_UINT16,  FIELD_CUSTOM, 1, 0, "SourceImageNumberOfCompositeImage", NULL},
465
    {EXIFTAG_SOURCEEXPOSURETIMESOFCOMPOSITEIMAGE, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1,
466
     "SourceExposureTimesOfCompositeImage", NULL}};
467
/*
468
 * EXIF-GPS tags  (Version 2.31, July 2016; nothing changed for version 2.32 May
469
 * 2019)
470
 */
471
472
static const TIFFField gpsFields[] = {
473
    /*  For the GPS tag definitions in gpsFields[] the standard definition for Rationals is TIFF_SETGET_DOUBLE and TIFF_SETGET_C0_FLOAT.
474
     *-- ATTENTION: After the upgrade with Rational2Double, the GPSTAG values can now be written and also read in double precision!
475
     *              In order to achieve double precision for GPS tags: Standard definitions for GPSTAG is kept to TIFF_SETGET_DOUBLE
476
     *              and TIFF_SETGET_C0_FLOAT is changed to TIFF_SETGET_C0_DOUBLE.
477
     */
478
    {GPSTAG_VERSIONID, 4, 4, TIFF_BYTE, 0, TIFF_SETGET_C0_UINT8,  FIELD_CUSTOM, 1, 0, "VersionID", NULL},
479
    {GPSTAG_LATITUDEREF, 2, 2, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "LatitudeRef", NULL},
480
    {GPSTAG_LATITUDE, 3, 3, TIFF_RATIONAL, 0, TIFF_SETGET_C0_DOUBLE,  FIELD_CUSTOM, 1, 0, "Latitude", NULL},
481
    {GPSTAG_LONGITUDEREF, 2, 2, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "LongitudeRef", NULL},
482
    {GPSTAG_LONGITUDE, 3, 3, TIFF_RATIONAL, 0, TIFF_SETGET_C0_DOUBLE,  FIELD_CUSTOM, 1, 0, "Longitude", NULL},
483
    {GPSTAG_ALTITUDEREF, 1, 1, TIFF_BYTE, 0, TIFF_SETGET_UINT8,  FIELD_CUSTOM, 1, 0, "AltitudeRef", NULL},
484
    {GPSTAG_ALTITUDE, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_DOUBLE,  FIELD_CUSTOM, 1, 0, "Altitude", NULL},
485
    {GPSTAG_TIMESTAMP, 3, 3, TIFF_RATIONAL, 0, TIFF_SETGET_C0_DOUBLE,  FIELD_CUSTOM, 1, 0, "TimeStamp", NULL},
486
    {GPSTAG_SATELLITES, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "Satellites", NULL},
487
    {GPSTAG_STATUS, 2, 2, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "Status", NULL},
488
    {GPSTAG_MEASUREMODE, 2, 2, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "MeasureMode", NULL},
489
    {GPSTAG_DOP, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_DOUBLE,  FIELD_CUSTOM, 1, 0, "DOP", NULL},
490
    {GPSTAG_SPEEDREF, 2, 2, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "SpeedRef", NULL},
491
    {GPSTAG_SPEED, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_DOUBLE,  FIELD_CUSTOM, 1, 0, "Speed", NULL},
492
    {GPSTAG_TRACKREF, 2, 2, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "TrackRef", NULL},
493
    {GPSTAG_TRACK, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_DOUBLE,  FIELD_CUSTOM, 1, 0, "Track", NULL},
494
    {GPSTAG_IMGDIRECTIONREF, 2, 2, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "ImgDirectionRef", NULL},
495
    {GPSTAG_IMGDIRECTION, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_DOUBLE,  FIELD_CUSTOM, 1, 0, "ImgDirection", NULL},
496
    {GPSTAG_MAPDATUM, -1, -1, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "MapDatum", NULL},
497
    {GPSTAG_DESTLATITUDEREF, 2, 2, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "DestLatitudeRef", NULL},
498
    {GPSTAG_DESTLATITUDE, 3, 3, TIFF_RATIONAL, 0, TIFF_SETGET_C0_DOUBLE,  FIELD_CUSTOM, 1, 0, "DestLatitude", NULL},
499
    {GPSTAG_DESTLONGITUDEREF, 2, 2, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "DestLongitudeRef", NULL},
500
    {GPSTAG_DESTLONGITUDE, 3, 3, TIFF_RATIONAL, 0, TIFF_SETGET_C0_DOUBLE,  FIELD_CUSTOM, 1, 0, "DestLongitude", NULL},
501
    {GPSTAG_DESTBEARINGREF, 2, 2, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "DestBearingRef", NULL},
502
    {GPSTAG_DESTBEARING, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_DOUBLE,  FIELD_CUSTOM, 1, 0, "DestBearing", NULL},
503
    {GPSTAG_DESTDISTANCEREF, 2, 2, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "DestDistanceRef", NULL},
504
    {GPSTAG_DESTDISTANCE, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_DOUBLE,  FIELD_CUSTOM, 1, 0, "DestDistance", NULL},
505
    {GPSTAG_PROCESSINGMETHOD, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "ProcessingMethod", NULL},
506
    {GPSTAG_AREAINFORMATION, -1, -1, TIFF_UNDEFINED, 0, TIFF_SETGET_C16_UINT8,  FIELD_CUSTOM, 1, 1, "AreaInformation", NULL},
507
    {GPSTAG_DATESTAMP, 11, 11, TIFF_ASCII, 0, TIFF_SETGET_ASCII,  FIELD_CUSTOM, 1, 0, "DateStamp", NULL},
508
    {GPSTAG_DIFFERENTIAL, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16,  FIELD_CUSTOM, 1, 0, "Differential", NULL},
509
    {GPSTAG_GPSHPOSITIONINGERROR, 1, 1, TIFF_RATIONAL, 0, TIFF_SETGET_DOUBLE,  FIELD_CUSTOM, 1, 0, "HorizontalPositioningError", NULL}};
510
/* clang-format on */ /* was off for better readability of tag comments */
511
512
#ifdef __cplusplus
513
/* In C++, the forward declaration used extern, so definitions must not be
514
 * static */
515
const TIFFFieldArray tiffFieldArray = {
516
    tfiatImage, 0, TIFFArrayCount(tiffFields), (TIFFField *)tiffFields};
517
const TIFFFieldArray exifFieldArray = {tfiatExif, 0, TIFFArrayCount(exifFields),
518
                                       (TIFFField *)exifFields};
519
const TIFFFieldArray gpsFieldArray = {tfiatGps, 0, TIFFArrayCount(gpsFields),
520
                                      (TIFFField *)gpsFields};
521
#else
522
/* Suppress C++-compat warning for the definitions as well */
523
#if defined(__GNUC__) && !defined(__clang__)
524
#pragma GCC diagnostic push
525
#pragma GCC diagnostic ignored "-Wc++-compat"
526
#elif defined(__clang__)
527
#pragma clang diagnostic push
528
#pragma clang diagnostic ignored "-Wc++-compat"
529
#endif
530
static const TIFFFieldArray tiffFieldArray = {
531
    tfiatImage, 0, TIFFArrayCount(tiffFields), (TIFFField *)tiffFields};
532
static const TIFFFieldArray exifFieldArray = {
533
    tfiatExif, 0, TIFFArrayCount(exifFields), (TIFFField *)exifFields};
534
static const TIFFFieldArray gpsFieldArray = {
535
    tfiatGps, 0, TIFFArrayCount(gpsFields), (TIFFField *)gpsFields};
536
#if defined(__GNUC__) && !defined(__clang__)
537
#pragma GCC diagnostic pop
538
#elif defined(__clang__)
539
#pragma clang diagnostic pop
540
#endif
541
#endif
542
543
/*
544
 *  We have our own local lfind() equivalent to avoid subtle differences
545
 *  in types passed to lfind() on different systems.
546
 */
547
548
static void *td_lfind(const void *key, const void *base, size_t *nmemb,
549
                      size_t size, int (*compar)(const void *, const void *))
550
0
{
551
0
    char *element, *end;
552
553
0
    end = (char *)base + *nmemb * size;
554
0
    for (element = (char *)base; element < end; element += size)
555
0
        if (!compar(key, element)) /* key found */
556
0
            return element;
557
558
0
    return NULL;
559
0
}
560
561
82.2k
const TIFFFieldArray *_TIFFGetFields(void) { return (&tiffFieldArray); }
562
563
0
const TIFFFieldArray *_TIFFGetExifFields(void) { return (&exifFieldArray); }
564
565
0
const TIFFFieldArray *_TIFFGetGpsFields(void) { return (&gpsFieldArray); }
566
567
void _TIFFSetupFields(TIFF *tif, const TIFFFieldArray *fieldarray)
568
82.2k
{
569
82.2k
    if (tif->tif_fields && tif->tif_nfields > 0)
570
12.1k
    {
571
12.1k
        uint32_t i;
572
573
1.94M
        for (i = 0; i < tif->tif_nfields; i++)
574
1.93M
        {
575
1.93M
            TIFFField *fld = tif->tif_fields[i];
576
1.93M
            if (fld->field_name != NULL)
577
1.93M
            {
578
1.93M
                if (fld->field_bit == FIELD_CUSTOM && TIFFFieldIsAnonymous(fld))
579
0
                {
580
0
                    _TIFFfreeExt(tif, (void *)fld->field_name);
581
                    /* caution: tif_fields[i] must not be the beginning of a
582
                     * fields-array. Otherwise the following tags are also freed
583
                     * with the first free().
584
                     */
585
0
                    _TIFFfreeExt(tif, fld);
586
0
                }
587
1.93M
            }
588
1.93M
        }
589
590
12.1k
        _TIFFfreeExt(tif, tif->tif_fields);
591
12.1k
        tif->tif_fields = NULL;
592
12.1k
        tif->tif_nfields = 0;
593
12.1k
    }
594
82.2k
    if (!_TIFFMergeFields(tif, fieldarray->fields, fieldarray->count))
595
0
    {
596
0
        TIFFErrorExtR(tif, "_TIFFSetupFields", "Setting up field info failed");
597
0
    }
598
82.2k
}
599
600
static int tagCompare(const void *a, const void *b)
601
208M
{
602
208M
    const TIFFField *ta = *(const TIFFField **)a;
603
208M
    const TIFFField *tb = *(const TIFFField **)b;
604
    /* NB: be careful of return values for 16-bit platforms */
605
208M
    if (ta->field_tag != tb->field_tag)
606
207M
        return (int)ta->field_tag - (int)tb->field_tag;
607
1.40M
    else
608
1.40M
        return (ta->field_type == TIFF_ANY)
609
1.40M
                   ? 0
610
1.40M
                   : ((int)tb->field_type - (int)ta->field_type);
611
208M
}
612
613
static int tagNameCompare(const void *a, const void *b)
614
0
{
615
0
    const TIFFField *ta = *(const TIFFField **)a;
616
0
    const TIFFField *tb = *(const TIFFField **)b;
617
0
    int ret = strcmp(ta->field_name, tb->field_name);
618
619
0
    if (ret)
620
0
        return ret;
621
0
    else
622
0
        return (ta->field_type == TIFF_ANY)
623
0
                   ? 0
624
0
                   : ((int)tb->field_type - (int)ta->field_type);
625
0
}
626
627
int _TIFFMergeFields(TIFF *tif, const TIFFField info[], uint32_t n)
628
222k
{
629
222k
    static const char module[] = "_TIFFMergeFields";
630
222k
    static const char reason[] = "for fields array";
631
    /* TIFFField** tp; */
632
222k
    uint32_t i;
633
634
222k
    tif->tif_foundfield = NULL;
635
636
222k
    TIFFField **tif_newfields = NULL;
637
638
222k
    if (tif->tif_fields && tif->tif_nfields > 0)
639
140k
    {
640
140k
        tif_newfields = (TIFFField **)_TIFFCheckRealloc(
641
140k
            tif, tif->tif_fields, (tmsize_t)tif->tif_nfields + n,
642
140k
            (tmsize_t)sizeof(TIFFField *), reason);
643
140k
    }
644
82.2k
    else
645
82.2k
    {
646
82.2k
        tif_newfields =
647
82.2k
            (TIFFField **)_TIFFCheckMalloc(tif, n, sizeof(TIFFField *), reason);
648
82.2k
    }
649
222k
    if (!tif_newfields)
650
0
    {
651
0
        tif->tif_nfields = 0;
652
0
        TIFFErrorExtR(tif, module, "Failed to allocate fields array");
653
0
        return 0;
654
0
    }
655
222k
    tif->tif_fields = tif_newfields;
656
657
    /* tp = tif->tif_fields + tif->tif_nfields; */
658
13.2M
    for (i = 0; i < n; i++)
659
13.0M
    {
660
13.0M
        const TIFFField *fip = TIFFFindField(tif, info[i].field_tag, TIFF_ANY);
661
662
        /* only add definitions that aren't already present */
663
13.0M
        if (!fip)
664
13.0M
        {
665
13.0M
            tif->tif_fields[tif->tif_nfields] = (TIFFField *)(info + i);
666
13.0M
            tif->tif_nfields++;
667
13.0M
        }
668
13.0M
    }
669
670
    /* Sort the field info by tag number */
671
222k
    qsort(tif->tif_fields, tif->tif_nfields, sizeof(TIFFField *), tagCompare);
672
673
222k
    return (int)n;
674
222k
}
675
676
void _TIFFPrintFieldInfo(TIFF *tif, FILE *fd)
677
0
{
678
0
    uint32_t i;
679
680
0
    fprintf(fd, "%s: \n", tif->tif_name);
681
0
    for (i = 0; i < tif->tif_nfields; i++)
682
0
    {
683
0
        const TIFFField *fip = tif->tif_fields[i];
684
0
        fprintf(fd, "field[%2d] %5lu, %2d, %2d, %u, %2d, %5s, %5s, %s\n",
685
0
                (int)i, (unsigned long)fip->field_tag, fip->field_readcount,
686
0
                fip->field_writecount, fip->field_type, fip->field_bit,
687
0
                fip->field_oktochange ? "TRUE" : "FALSE",
688
0
                fip->field_passcount ? "TRUE" : "FALSE", fip->field_name);
689
0
    }
690
0
}
691
692
/*
693
 * Return size of TIFFDataType within TIFF-file in bytes
694
 */
695
int TIFFDataWidth(TIFFDataType type)
696
405k
{
697
405k
    switch (type)
698
405k
    {
699
0
        case 0: /* nothing */
700
0
        case TIFF_BYTE:
701
0
        case TIFF_ASCII:
702
0
        case TIFF_SBYTE:
703
0
        case TIFF_UNDEFINED:
704
0
            return 1;
705
57.9k
        case TIFF_SHORT:
706
57.9k
        case TIFF_SSHORT:
707
57.9k
            return 2;
708
231k
        case TIFF_LONG:
709
231k
        case TIFF_SLONG:
710
231k
        case TIFF_FLOAT:
711
231k
        case TIFF_IFD:
712
231k
            return 4;
713
115k
        case TIFF_RATIONAL:
714
115k
        case TIFF_SRATIONAL:
715
115k
        case TIFF_DOUBLE:
716
115k
        case TIFF_LONG8:
717
115k
        case TIFF_SLONG8:
718
115k
        case TIFF_IFD8:
719
115k
            return 8;
720
0
        default:
721
0
            return 0; /* will return 0 for unknown types */
722
405k
    }
723
405k
}
724
725
/*
726
 * Return internal storage size of TIFFSetGetFieldType in bytes.
727
 * TIFFSetField() and TIFFGetField() have to provide the parameter accordingly.
728
 * Replaces internal functions _TIFFDataSize() and _TIFFSetGetFieldSize()
729
 * with now extern available function TIFFFieldSetGetSize().
730
 */
731
int TIFFFieldSetGetSize(const TIFFField *fip)
732
0
{
733
    /*
734
     * TIFFSetField() and TIFFGetField() must provide the parameter accordingly
735
     * to the definition of "set_get_field_type" of the tag definition in
736
     * dir_info.c. This function returns the data size for that purpose.
737
     *
738
     * Furthermore, this data size is also used for the internal storage,
739
     * even for TIFF_RATIONAL values for FIELD_CUSTOM, which are stored
740
     * internally as 4-byte float, but some of them should be stored internally
741
     * as 8-byte double, depending on the "set_get_field_type" _FLOAT_ or
742
     * _DOUBLE_.
743
     */
744
0
    if (fip == NULL)
745
0
        return 0;
746
747
0
    switch (fip->set_get_field_type)
748
0
    {
749
0
        case TIFF_SETGET_UNDEFINED:
750
0
        case TIFF_SETGET_ASCII:
751
0
        case TIFF_SETGET_C0_ASCII:
752
0
        case TIFF_SETGET_C16_ASCII:
753
0
        case TIFF_SETGET_C32_ASCII:
754
0
        case TIFF_SETGET_OTHER:
755
0
            return 1;
756
0
        case TIFF_SETGET_UINT8:
757
0
        case TIFF_SETGET_SINT8:
758
0
        case TIFF_SETGET_C0_UINT8:
759
0
        case TIFF_SETGET_C0_SINT8:
760
0
        case TIFF_SETGET_C16_UINT8:
761
0
        case TIFF_SETGET_C16_SINT8:
762
0
        case TIFF_SETGET_C32_UINT8:
763
0
        case TIFF_SETGET_C32_SINT8:
764
0
            return 1;
765
0
        case TIFF_SETGET_UINT16:
766
0
        case TIFF_SETGET_SINT16:
767
0
        case TIFF_SETGET_C0_UINT16:
768
0
        case TIFF_SETGET_C0_SINT16:
769
0
        case TIFF_SETGET_C16_UINT16:
770
0
        case TIFF_SETGET_C16_SINT16:
771
0
        case TIFF_SETGET_C32_UINT16:
772
0
        case TIFF_SETGET_C32_SINT16:
773
0
            return 2;
774
0
        case TIFF_SETGET_INT:
775
0
        case TIFF_SETGET_UINT32:
776
0
        case TIFF_SETGET_SINT32:
777
0
        case TIFF_SETGET_FLOAT:
778
0
        case TIFF_SETGET_UINT16_PAIR:
779
0
        case TIFF_SETGET_C0_UINT32:
780
0
        case TIFF_SETGET_C0_SINT32:
781
0
        case TIFF_SETGET_C0_FLOAT:
782
0
        case TIFF_SETGET_C16_UINT32:
783
0
        case TIFF_SETGET_C16_SINT32:
784
0
        case TIFF_SETGET_C16_FLOAT:
785
0
        case TIFF_SETGET_C32_UINT32:
786
0
        case TIFF_SETGET_C32_SINT32:
787
0
        case TIFF_SETGET_C32_FLOAT:
788
0
            return 4;
789
0
        case TIFF_SETGET_UINT64:
790
0
        case TIFF_SETGET_SINT64:
791
0
        case TIFF_SETGET_DOUBLE:
792
0
        case TIFF_SETGET_IFD8:
793
0
        case TIFF_SETGET_C0_UINT64:
794
0
        case TIFF_SETGET_C0_SINT64:
795
0
        case TIFF_SETGET_C0_DOUBLE:
796
0
        case TIFF_SETGET_C0_IFD8:
797
0
        case TIFF_SETGET_C16_UINT64:
798
0
        case TIFF_SETGET_C16_SINT64:
799
0
        case TIFF_SETGET_C16_DOUBLE:
800
0
        case TIFF_SETGET_C16_IFD8:
801
0
        case TIFF_SETGET_C32_UINT64:
802
0
        case TIFF_SETGET_C32_SINT64:
803
0
        case TIFF_SETGET_C32_DOUBLE:
804
0
        case TIFF_SETGET_C32_IFD8:
805
0
            return 8;
806
0
        default:
807
0
            return 0;
808
0
    }
809
0
} /*-- TIFFFieldSetGetSize() --- */
810
811
/*
812
 * Return size of count parameter of TIFFSetField() and TIFFGetField()
813
 * and also if it is required:  0=none, 2=uint16_t, 4=uint32_t
814
 */
815
int TIFFFieldSetGetCountSize(const TIFFField *fip)
816
0
{
817
0
    if (fip == NULL)
818
0
        return 0;
819
820
0
    switch (fip->set_get_field_type)
821
0
    {
822
0
        case TIFF_SETGET_C16_ASCII:
823
0
        case TIFF_SETGET_C16_UINT8:
824
0
        case TIFF_SETGET_C16_SINT8:
825
0
        case TIFF_SETGET_C16_UINT16:
826
0
        case TIFF_SETGET_C16_SINT16:
827
0
        case TIFF_SETGET_C16_UINT32:
828
0
        case TIFF_SETGET_C16_SINT32:
829
0
        case TIFF_SETGET_C16_FLOAT:
830
0
        case TIFF_SETGET_C16_UINT64:
831
0
        case TIFF_SETGET_C16_SINT64:
832
0
        case TIFF_SETGET_C16_DOUBLE:
833
0
        case TIFF_SETGET_C16_IFD8:
834
0
            return 2;
835
0
        case TIFF_SETGET_C32_ASCII:
836
0
        case TIFF_SETGET_C32_UINT8:
837
0
        case TIFF_SETGET_C32_SINT8:
838
0
        case TIFF_SETGET_C32_UINT16:
839
0
        case TIFF_SETGET_C32_SINT16:
840
0
        case TIFF_SETGET_C32_UINT32:
841
0
        case TIFF_SETGET_C32_SINT32:
842
0
        case TIFF_SETGET_C32_FLOAT:
843
0
        case TIFF_SETGET_C32_UINT64:
844
0
        case TIFF_SETGET_C32_SINT64:
845
0
        case TIFF_SETGET_C32_DOUBLE:
846
0
        case TIFF_SETGET_C32_IFD8:
847
0
            return 4;
848
0
        case TIFF_SETGET_UNDEFINED:
849
0
        case TIFF_SETGET_ASCII:
850
0
        case TIFF_SETGET_UINT8:
851
0
        case TIFF_SETGET_SINT8:
852
0
        case TIFF_SETGET_UINT16:
853
0
        case TIFF_SETGET_SINT16:
854
0
        case TIFF_SETGET_UINT32:
855
0
        case TIFF_SETGET_SINT32:
856
0
        case TIFF_SETGET_UINT64:
857
0
        case TIFF_SETGET_SINT64:
858
0
        case TIFF_SETGET_FLOAT:
859
0
        case TIFF_SETGET_DOUBLE:
860
0
        case TIFF_SETGET_IFD8:
861
0
        case TIFF_SETGET_INT:
862
0
        case TIFF_SETGET_UINT16_PAIR:
863
0
        case TIFF_SETGET_C0_ASCII:
864
0
        case TIFF_SETGET_C0_UINT8:
865
0
        case TIFF_SETGET_C0_SINT8:
866
0
        case TIFF_SETGET_C0_UINT16:
867
0
        case TIFF_SETGET_C0_SINT16:
868
0
        case TIFF_SETGET_C0_UINT32:
869
0
        case TIFF_SETGET_C0_SINT32:
870
0
        case TIFF_SETGET_C0_UINT64:
871
0
        case TIFF_SETGET_C0_SINT64:
872
0
        case TIFF_SETGET_C0_FLOAT:
873
0
        case TIFF_SETGET_C0_DOUBLE:
874
0
        case TIFF_SETGET_C0_IFD8:
875
0
        case TIFF_SETGET_OTHER:
876
0
        default:
877
0
            return 0;
878
0
    }
879
0
} /*-- TIFFFieldSetGetCountSize() --- */
880
881
const TIFFField *TIFFFindField(TIFF *tif, uint32_t tag, TIFFDataType dt)
882
16.5M
{
883
16.5M
    TIFFField key = {0, 0, 0, TIFF_NOTYPE, 0,   TIFF_SETGET_UNDEFINED,
884
16.5M
                     0, 0, 0, NULL,        NULL};
885
16.5M
    TIFFField *pkey = &key;
886
16.5M
    const TIFFField **ret;
887
16.5M
    if (tif->tif_foundfield && tif->tif_foundfield->field_tag == tag &&
888
2.10M
        (dt == TIFF_ANY || dt == tif->tif_foundfield->field_type))
889
2.10M
        return tif->tif_foundfield;
890
891
    /* If we are invoked with no field information, then just return. */
892
14.4M
    if (!tif->tif_fields)
893
0
        return NULL;
894
895
    /* NB: use sorted search (e.g. binary search) */
896
897
14.4M
    key.field_tag = tag;
898
14.4M
    key.field_type = dt;
899
900
14.4M
    ret = (const TIFFField **)bsearch(&pkey, tif->tif_fields, tif->tif_nfields,
901
14.4M
                                      sizeof(TIFFField *), tagCompare);
902
14.4M
    return tif->tif_foundfield = (ret ? *ret : NULL);
903
14.4M
}
904
905
static const TIFFField *_TIFFFindFieldByName(TIFF *tif, const char *field_name,
906
                                             TIFFDataType dt)
907
0
{
908
0
    TIFFField key = {0, 0, 0, TIFF_NOTYPE, 0,   TIFF_SETGET_UNDEFINED,
909
0
                     0, 0, 0, NULL,        NULL};
910
0
    TIFFField *pkey = &key;
911
0
    const TIFFField **ret;
912
0
    if (tif->tif_foundfield &&
913
0
        streq(tif->tif_foundfield->field_name, field_name) &&
914
0
        (dt == TIFF_ANY || dt == tif->tif_foundfield->field_type))
915
0
        return (tif->tif_foundfield);
916
917
    /* If we are invoked with no field information, then just return. */
918
0
    if (!tif->tif_fields)
919
0
        return NULL;
920
921
    /* NB: use linear search since list is sorted by key#, not name */
922
923
0
    key.field_name = (char *)field_name;
924
0
    key.field_type = dt;
925
926
0
    ret =
927
0
        (const TIFFField **)td_lfind(&pkey, tif->tif_fields, &tif->tif_nfields,
928
0
                                     sizeof(TIFFField *), tagNameCompare);
929
930
0
    return tif->tif_foundfield = (ret ? *ret : NULL);
931
0
}
932
933
const TIFFField *TIFFFieldWithTag(TIFF *tif, uint32_t tag)
934
981k
{
935
981k
    const TIFFField *fip = TIFFFindField(tif, tag, TIFF_ANY);
936
981k
    if (!fip)
937
0
    {
938
0
        TIFFWarningExtR(tif, "TIFFFieldWithTag", "Warning, unknown tag 0x%x",
939
0
                        (unsigned int)tag);
940
0
    }
941
981k
    return (fip);
942
981k
}
943
944
const TIFFField *TIFFFieldWithName(TIFF *tif, const char *field_name)
945
0
{
946
0
    const TIFFField *fip = _TIFFFindFieldByName(tif, field_name, TIFF_ANY);
947
0
    if (!fip)
948
0
    {
949
0
        TIFFWarningExtR(tif, "TIFFFieldWithName", "Warning, unknown tag %s",
950
0
                        field_name);
951
0
    }
952
0
    return (fip);
953
0
}
954
955
0
uint32_t TIFFFieldTag(const TIFFField *fip) { return fip->field_tag; }
956
957
0
const char *TIFFFieldName(const TIFFField *fip) { return fip->field_name; }
958
959
0
TIFFDataType TIFFFieldDataType(const TIFFField *fip) { return fip->field_type; }
960
961
0
int TIFFFieldPassCount(const TIFFField *fip) { return fip->field_passcount; }
962
963
0
int TIFFFieldReadCount(const TIFFField *fip) { return fip->field_readcount; }
964
965
0
int TIFFFieldWriteCount(const TIFFField *fip) { return fip->field_writecount; }
966
967
int TIFFFieldIsAnonymous(const TIFFField *fip)
968
8.47M
{
969
8.47M
    return (int)fip->field_anonymous;
970
8.47M
}
971
972
const TIFFField *_TIFFFindOrRegisterField(TIFF *tif, uint32_t tag,
973
                                          TIFFDataType dt)
974
975
0
{
976
0
    const TIFFField *fld;
977
978
0
    fld = TIFFFindField(tif, tag, dt);
979
0
    if (fld == NULL)
980
0
    {
981
0
        fld = _TIFFCreateAnonField(tif, tag, dt);
982
0
        if (fld == NULL || !_TIFFMergeFields(tif, fld, 1))
983
0
            return NULL;
984
0
    }
985
986
0
    return fld;
987
0
}
988
989
TIFFField *_TIFFCreateAnonField(TIFF *tif, uint32_t tag,
990
                                TIFFDataType field_type)
991
0
{
992
0
    TIFFField *fld;
993
0
    (void)tif;
994
995
0
    fld = (TIFFField *)_TIFFmallocExt(tif, sizeof(TIFFField));
996
0
    if (fld == NULL)
997
0
        return NULL;
998
0
    _TIFFmemset(fld, 0, sizeof(TIFFField));
999
1000
0
    fld->field_tag = tag;
1001
0
    fld->field_readcount = TIFF_VARIABLE2;
1002
0
    fld->field_writecount = TIFF_VARIABLE2;
1003
0
    fld->field_type = field_type;
1004
0
    fld->field_anonymous =
1005
0
        1; /* indicate that this is an anonymous / unknown tag */
1006
0
    switch (field_type)
1007
0
    {
1008
0
        case TIFF_BYTE:
1009
0
        case TIFF_UNDEFINED:
1010
0
            fld->set_get_field_type = TIFF_SETGET_C32_UINT8;
1011
0
            break;
1012
0
        case TIFF_ASCII:
1013
0
            fld->set_get_field_type = TIFF_SETGET_C32_ASCII;
1014
0
            break;
1015
0
        case TIFF_SHORT:
1016
0
            fld->set_get_field_type = TIFF_SETGET_C32_UINT16;
1017
0
            break;
1018
0
        case TIFF_LONG:
1019
0
            fld->set_get_field_type = TIFF_SETGET_C32_UINT32;
1020
0
            break;
1021
0
        case TIFF_RATIONAL:
1022
0
        case TIFF_SRATIONAL:
1023
0
        case TIFF_FLOAT:
1024
0
            fld->set_get_field_type = TIFF_SETGET_C32_FLOAT;
1025
0
            break;
1026
0
        case TIFF_SBYTE:
1027
0
            fld->set_get_field_type = TIFF_SETGET_C32_SINT8;
1028
0
            break;
1029
0
        case TIFF_SSHORT:
1030
0
            fld->set_get_field_type = TIFF_SETGET_C32_SINT16;
1031
0
            break;
1032
0
        case TIFF_SLONG:
1033
0
            fld->set_get_field_type = TIFF_SETGET_C32_SINT32;
1034
0
            break;
1035
0
        case TIFF_DOUBLE:
1036
0
            fld->set_get_field_type = TIFF_SETGET_C32_DOUBLE;
1037
0
            break;
1038
0
        case TIFF_IFD:
1039
0
        case TIFF_IFD8:
1040
0
            fld->set_get_field_type = TIFF_SETGET_C32_IFD8;
1041
0
            break;
1042
0
        case TIFF_LONG8:
1043
0
            fld->set_get_field_type = TIFF_SETGET_C32_UINT64;
1044
0
            break;
1045
0
        case TIFF_SLONG8:
1046
0
            fld->set_get_field_type = TIFF_SETGET_C32_SINT64;
1047
0
            break;
1048
0
        case TIFF_NOTYPE:
1049
0
        default:
1050
0
            fld->set_get_field_type = TIFF_SETGET_UNDEFINED;
1051
0
            break;
1052
0
    }
1053
0
    fld->field_bit = FIELD_CUSTOM;
1054
0
    fld->field_oktochange = TRUE;
1055
0
    fld->field_passcount = TRUE;
1056
0
    char *field_name_buf = (char *)_TIFFmallocExt(tif, 32);
1057
0
    if (field_name_buf == NULL)
1058
0
    {
1059
0
        _TIFFfreeExt(tif, fld);
1060
0
        return NULL;
1061
0
    }
1062
0
    fld->field_subfields = NULL;
1063
1064
    /*
1065
     * note that this name is a special sign to TIFFClose() and
1066
     * _TIFFSetupFields() to free the field
1067
     * Update:
1068
     *   This special sign is replaced by fld->field_anonymous  flag.
1069
     */
1070
0
    (void)snprintf(field_name_buf, 32, "Tag %d", (int)tag);
1071
0
    fld->field_name = field_name_buf;
1072
1073
0
    return fld;
1074
0
}
1075
1076
/****************************************************************************
1077
 *               O B S O L E T E D    I N T E R F A C E S
1078
 *
1079
 * Don't use this stuff in your applications, it may be removed in the future
1080
 * libtiff versions.
1081
 ****************************************************************************/
1082
1083
static TIFFSetGetFieldType _TIFFSetGetType(TIFFDataType type, short count,
1084
                                           unsigned char passcount)
1085
0
{
1086
0
    if (type == TIFF_ASCII && count == TIFF_VARIABLE && passcount == 0)
1087
0
        return TIFF_SETGET_ASCII;
1088
1089
0
    else if (count == 1 && passcount == 0)
1090
0
    {
1091
0
        switch (type)
1092
0
        {
1093
0
            case TIFF_BYTE:
1094
0
            case TIFF_UNDEFINED:
1095
0
                return TIFF_SETGET_UINT8;
1096
0
            case TIFF_ASCII:
1097
0
                return TIFF_SETGET_ASCII;
1098
0
            case TIFF_SHORT:
1099
0
                return TIFF_SETGET_UINT16;
1100
0
            case TIFF_LONG:
1101
0
                return TIFF_SETGET_UINT32;
1102
0
            case TIFF_RATIONAL:
1103
0
            case TIFF_SRATIONAL:
1104
0
            case TIFF_FLOAT:
1105
0
                return TIFF_SETGET_FLOAT;
1106
0
            case TIFF_SBYTE:
1107
0
                return TIFF_SETGET_SINT8;
1108
0
            case TIFF_SSHORT:
1109
0
                return TIFF_SETGET_SINT16;
1110
0
            case TIFF_SLONG:
1111
0
                return TIFF_SETGET_SINT32;
1112
0
            case TIFF_DOUBLE:
1113
0
                return TIFF_SETGET_DOUBLE;
1114
0
            case TIFF_IFD:
1115
0
            case TIFF_IFD8:
1116
0
                return TIFF_SETGET_IFD8;
1117
0
            case TIFF_LONG8:
1118
0
                return TIFF_SETGET_UINT64;
1119
0
            case TIFF_SLONG8:
1120
0
                return TIFF_SETGET_SINT64;
1121
0
            case TIFF_NOTYPE:
1122
0
            default:
1123
0
                return TIFF_SETGET_UNDEFINED;
1124
0
        }
1125
0
    }
1126
1127
0
    else if (count >= 1 && passcount == 0)
1128
0
    {
1129
0
        switch (type)
1130
0
        {
1131
0
            case TIFF_BYTE:
1132
0
            case TIFF_UNDEFINED:
1133
0
                return TIFF_SETGET_C0_UINT8;
1134
0
            case TIFF_ASCII:
1135
0
                return TIFF_SETGET_C0_ASCII;
1136
0
            case TIFF_SHORT:
1137
0
                return TIFF_SETGET_C0_UINT16;
1138
0
            case TIFF_LONG:
1139
0
                return TIFF_SETGET_C0_UINT32;
1140
0
            case TIFF_RATIONAL:
1141
0
            case TIFF_SRATIONAL:
1142
0
            case TIFF_FLOAT:
1143
0
                return TIFF_SETGET_C0_FLOAT;
1144
0
            case TIFF_SBYTE:
1145
0
                return TIFF_SETGET_C0_SINT8;
1146
0
            case TIFF_SSHORT:
1147
0
                return TIFF_SETGET_C0_SINT16;
1148
0
            case TIFF_SLONG:
1149
0
                return TIFF_SETGET_C0_SINT32;
1150
0
            case TIFF_DOUBLE:
1151
0
                return TIFF_SETGET_C0_DOUBLE;
1152
0
            case TIFF_IFD:
1153
0
            case TIFF_IFD8:
1154
0
                return TIFF_SETGET_C0_IFD8;
1155
0
            case TIFF_LONG8:
1156
0
                return TIFF_SETGET_C0_UINT64;
1157
0
            case TIFF_SLONG8:
1158
0
                return TIFF_SETGET_C0_SINT64;
1159
0
            case TIFF_NOTYPE:
1160
0
            default:
1161
0
                return TIFF_SETGET_UNDEFINED;
1162
0
        }
1163
0
    }
1164
1165
0
    else if (count == TIFF_VARIABLE && passcount == 1)
1166
0
    {
1167
0
        switch (type)
1168
0
        {
1169
0
            case TIFF_BYTE:
1170
0
            case TIFF_UNDEFINED:
1171
0
                return TIFF_SETGET_C16_UINT8;
1172
0
            case TIFF_ASCII:
1173
0
                return TIFF_SETGET_C16_ASCII;
1174
0
            case TIFF_SHORT:
1175
0
                return TIFF_SETGET_C16_UINT16;
1176
0
            case TIFF_LONG:
1177
0
                return TIFF_SETGET_C16_UINT32;
1178
0
            case TIFF_RATIONAL:
1179
0
            case TIFF_SRATIONAL:
1180
0
            case TIFF_FLOAT:
1181
0
                return TIFF_SETGET_C16_FLOAT;
1182
0
            case TIFF_SBYTE:
1183
0
                return TIFF_SETGET_C16_SINT8;
1184
0
            case TIFF_SSHORT:
1185
0
                return TIFF_SETGET_C16_SINT16;
1186
0
            case TIFF_SLONG:
1187
0
                return TIFF_SETGET_C16_SINT32;
1188
0
            case TIFF_DOUBLE:
1189
0
                return TIFF_SETGET_C16_DOUBLE;
1190
0
            case TIFF_IFD:
1191
0
            case TIFF_IFD8:
1192
0
                return TIFF_SETGET_C16_IFD8;
1193
0
            case TIFF_LONG8:
1194
0
                return TIFF_SETGET_C16_UINT64;
1195
0
            case TIFF_SLONG8:
1196
0
                return TIFF_SETGET_C16_SINT64;
1197
0
            case TIFF_NOTYPE:
1198
0
            default:
1199
0
                return TIFF_SETGET_UNDEFINED;
1200
0
        }
1201
0
    }
1202
1203
0
    else if (count == TIFF_VARIABLE2 && passcount == 1)
1204
0
    {
1205
0
        switch (type)
1206
0
        {
1207
0
            case TIFF_BYTE:
1208
0
            case TIFF_UNDEFINED:
1209
0
                return TIFF_SETGET_C32_UINT8;
1210
0
            case TIFF_ASCII:
1211
0
                return TIFF_SETGET_C32_ASCII;
1212
0
            case TIFF_SHORT:
1213
0
                return TIFF_SETGET_C32_UINT16;
1214
0
            case TIFF_LONG:
1215
0
                return TIFF_SETGET_C32_UINT32;
1216
0
            case TIFF_RATIONAL:
1217
0
            case TIFF_SRATIONAL:
1218
0
            case TIFF_FLOAT:
1219
0
                return TIFF_SETGET_C32_FLOAT;
1220
0
            case TIFF_SBYTE:
1221
0
                return TIFF_SETGET_C32_SINT8;
1222
0
            case TIFF_SSHORT:
1223
0
                return TIFF_SETGET_C32_SINT16;
1224
0
            case TIFF_SLONG:
1225
0
                return TIFF_SETGET_C32_SINT32;
1226
0
            case TIFF_DOUBLE:
1227
0
                return TIFF_SETGET_C32_DOUBLE;
1228
0
            case TIFF_IFD:
1229
0
            case TIFF_IFD8:
1230
0
                return TIFF_SETGET_C32_IFD8;
1231
0
            case TIFF_LONG8:
1232
0
                return TIFF_SETGET_C32_UINT64;
1233
0
            case TIFF_SLONG8:
1234
0
                return TIFF_SETGET_C32_SINT64;
1235
0
            case TIFF_NOTYPE:
1236
0
            default:
1237
0
                return TIFF_SETGET_UNDEFINED;
1238
0
        }
1239
0
    }
1240
1241
0
    return TIFF_SETGET_UNDEFINED;
1242
0
}
1243
1244
int TIFFMergeFieldInfo(TIFF *tif, const TIFFFieldInfo info[], uint32_t n)
1245
0
{
1246
0
    static const char module[] = "TIFFMergeFieldInfo";
1247
0
    static const char reason[] = "for fields array";
1248
0
    TIFFField *tp;
1249
0
    size_t nfields;
1250
0
    uint32_t i;
1251
1252
0
    TIFFFieldArray *tif_newfieldscompat = NULL;
1253
1254
0
    if (tif->tif_nfieldscompat > 0)
1255
0
    {
1256
0
        tif_newfieldscompat = (TIFFFieldArray *)_TIFFCheckRealloc(
1257
0
            tif, tif->tif_fieldscompat, (tmsize_t)tif->tif_nfieldscompat + 1,
1258
0
            (tmsize_t)sizeof(TIFFFieldArray), reason);
1259
0
    }
1260
0
    else
1261
0
    {
1262
0
        tif_newfieldscompat = (TIFFFieldArray *)_TIFFCheckMalloc(
1263
0
            tif, 1, sizeof(TIFFFieldArray), reason);
1264
0
    }
1265
0
    if (!tif_newfieldscompat)
1266
0
    {
1267
0
        TIFFErrorExtR(tif, module, "Failed to allocate fields array");
1268
0
        return -1;
1269
0
    }
1270
0
    tif->tif_fieldscompat = tif_newfieldscompat;
1271
0
    nfields = tif->tif_nfieldscompat++;
1272
1273
0
    tif->tif_fieldscompat[nfields].type = tfiatOther;
1274
0
    tif->tif_fieldscompat[nfields].allocated_size = n;
1275
0
    tif->tif_fieldscompat[nfields].count = n;
1276
0
    tif->tif_fieldscompat[nfields].fields =
1277
0
        (TIFFField *)_TIFFCheckMalloc(tif, n, sizeof(TIFFField), reason);
1278
0
    if (!tif->tif_fieldscompat[nfields].fields)
1279
0
    {
1280
0
        TIFFErrorExtR(tif, module, "Failed to allocate fields array");
1281
0
        return -1;
1282
0
    }
1283
1284
0
    tp = tif->tif_fieldscompat[nfields].fields;
1285
0
    for (i = 0; i < n; i++)
1286
0
    {
1287
0
        tp->field_tag = info[i].field_tag;
1288
0
        if (info[i].field_readcount < TIFF_VARIABLE2 ||
1289
0
            info[i].field_writecount < TIFF_VARIABLE2)
1290
0
        {
1291
            /* The fields (field_readcount) and (field_writecount) may use the
1292
             * values TIFF_VARIABLE (-1), TIFF_SPP (-2), TIFF_VARIABLE2 (-3). */
1293
0
            TIFFErrorExtR(
1294
0
                tif, module,
1295
0
                "The value of field_readcount %d and field_writecount %d "
1296
0
                "must be greater than or equal to -3.",
1297
0
                info[i].field_readcount, info[i].field_writecount);
1298
0
            return -1;
1299
0
        }
1300
0
        if ((info[i].field_readcount == 0 || info[i].field_writecount == 0) &&
1301
0
            info[i].field_bit != FIELD_IGNORE)
1302
0
        {
1303
            /* The fields (field_readcount) and (field_writecount) may only
1304
            be zero for pseudo_tags or ignored tags. */
1305
0
            TIFFErrorExtR(
1306
0
                tif, module,
1307
0
                "The value of field_readcount %d and field_writecount %d "
1308
0
                "may only be zero for field_bit = 0 (i.e. ignored tags).",
1309
0
                info[i].field_readcount, info[i].field_writecount);
1310
0
            return -1;
1311
0
        }
1312
0
        tp->field_readcount = info[i].field_readcount;
1313
0
        tp->field_writecount = info[i].field_writecount;
1314
0
        tp->field_type = info[i].field_type;
1315
0
        tp->field_anonymous = 0;
1316
0
        tp->set_get_field_type =
1317
0
            _TIFFSetGetType(info[i].field_type, info[i].field_writecount,
1318
0
                            info[i].field_passcount);
1319
0
        tp->field_bit = info[i].field_bit;
1320
0
        tp->field_oktochange = info[i].field_oktochange;
1321
0
        tp->field_passcount = info[i].field_passcount;
1322
        /* Define an empty static string to be passed as field_name where a NULL
1323
         * pointer is passed in. Otherwise, this will lead to buffer overflow
1324
         * furtheron. */
1325
0
        if (info[i].field_name == NULL)
1326
0
        {
1327
0
            static const char *string_static_empty = "";
1328
0
            tp->field_name = (char *)string_static_empty;
1329
0
        }
1330
0
        else
1331
0
        {
1332
0
            tp->field_name = info[i].field_name;
1333
0
        }
1334
0
        tp->field_subfields = NULL;
1335
0
        tp++;
1336
0
    }
1337
1338
0
    if (!_TIFFMergeFields(tif, tif->tif_fieldscompat[nfields].fields, n))
1339
0
    {
1340
0
        TIFFErrorExtR(tif, module, "Setting up field info failed");
1341
0
        return -1;
1342
0
    }
1343
1344
0
    return 0;
1345
0
}
1346
1347
int _TIFFCheckFieldIsValidForCodec(TIFF *tif, ttag_t tag)
1348
347k
{
1349
    /* Filter out non-codec specific tags */
1350
347k
    switch (tag)
1351
347k
    {
1352
        /* Shared tags */
1353
0
        case TIFFTAG_PREDICTOR:
1354
        /* JPEG tags */
1355
0
        case TIFFTAG_JPEGTABLES:
1356
        /* OJPEG tags */
1357
0
        case TIFFTAG_JPEGIFOFFSET:
1358
0
        case TIFFTAG_JPEGIFBYTECOUNT:
1359
0
        case TIFFTAG_JPEGQTABLES:
1360
0
        case TIFFTAG_JPEGDCTABLES:
1361
0
        case TIFFTAG_JPEGACTABLES:
1362
0
        case TIFFTAG_JPEGPROC:
1363
0
        case TIFFTAG_JPEGRESTARTINTERVAL:
1364
        /* CCITT* */
1365
0
        case TIFFTAG_BADFAXLINES:
1366
0
        case TIFFTAG_CLEANFAXDATA:
1367
0
        case TIFFTAG_CONSECUTIVEBADFAXLINES:
1368
0
        case TIFFTAG_GROUP3OPTIONS:
1369
0
        case TIFFTAG_GROUP4OPTIONS:
1370
        /* LERC */
1371
0
        case TIFFTAG_LERC_PARAMETERS:
1372
0
            break;
1373
347k
        default:
1374
347k
            return 1;
1375
347k
    }
1376
0
    if (!TIFFIsCODECConfigured(tif->tif_dir.td_compression))
1377
0
    {
1378
0
        return 0;
1379
0
    }
1380
    /* Check if codec specific tags are allowed for the current
1381
     * compression scheme (codec) */
1382
0
    switch (tif->tif_dir.td_compression)
1383
0
    {
1384
0
        case COMPRESSION_LZW:
1385
0
            if (tag == TIFFTAG_PREDICTOR)
1386
0
                return 1;
1387
0
            break;
1388
0
        case COMPRESSION_PACKBITS:
1389
            /* No codec-specific tags */
1390
0
            break;
1391
0
        case COMPRESSION_THUNDERSCAN:
1392
            /* No codec-specific tags */
1393
0
            break;
1394
0
        case COMPRESSION_NEXT:
1395
            /* No codec-specific tags */
1396
0
            break;
1397
0
        case COMPRESSION_JPEG:
1398
0
            if (tag == TIFFTAG_JPEGTABLES)
1399
0
                return 1;
1400
0
            break;
1401
0
        case COMPRESSION_OJPEG:
1402
0
            switch (tag)
1403
0
            {
1404
0
                case TIFFTAG_JPEGIFOFFSET:
1405
0
                case TIFFTAG_JPEGIFBYTECOUNT:
1406
0
                case TIFFTAG_JPEGQTABLES:
1407
0
                case TIFFTAG_JPEGDCTABLES:
1408
0
                case TIFFTAG_JPEGACTABLES:
1409
0
                case TIFFTAG_JPEGPROC:
1410
0
                case TIFFTAG_JPEGRESTARTINTERVAL:
1411
0
                    return 1;
1412
0
                default:
1413
0
                    break;
1414
0
            }
1415
0
            break;
1416
0
        case COMPRESSION_CCITTRLE:
1417
0
        case COMPRESSION_CCITTRLEW:
1418
0
        case COMPRESSION_CCITTFAX3:
1419
0
        case COMPRESSION_CCITTFAX4:
1420
0
            switch (tag)
1421
0
            {
1422
0
                case TIFFTAG_BADFAXLINES:
1423
0
                case TIFFTAG_CLEANFAXDATA:
1424
0
                case TIFFTAG_CONSECUTIVEBADFAXLINES:
1425
0
                    return 1;
1426
0
                case TIFFTAG_GROUP3OPTIONS:
1427
0
                    if (tif->tif_dir.td_compression == COMPRESSION_CCITTFAX3)
1428
0
                        return 1;
1429
0
                    break;
1430
0
                case TIFFTAG_GROUP4OPTIONS:
1431
0
                    if (tif->tif_dir.td_compression == COMPRESSION_CCITTFAX4)
1432
0
                        return 1;
1433
0
                    break;
1434
0
                default:
1435
0
                    break;
1436
0
            }
1437
0
            break;
1438
0
        case COMPRESSION_JBIG:
1439
            /* No codec-specific tags */
1440
0
            break;
1441
0
        case COMPRESSION_DEFLATE:
1442
0
        case COMPRESSION_ADOBE_DEFLATE:
1443
0
            if (tag == TIFFTAG_PREDICTOR)
1444
0
                return 1;
1445
0
            break;
1446
0
        case COMPRESSION_PIXARLOG:
1447
0
            if (tag == TIFFTAG_PREDICTOR)
1448
0
                return 1;
1449
0
            break;
1450
0
        case COMPRESSION_SGILOG:
1451
0
        case COMPRESSION_SGILOG24:
1452
            /* No codec-specific tags */
1453
0
            break;
1454
0
        case COMPRESSION_LZMA:
1455
0
            if (tag == TIFFTAG_PREDICTOR)
1456
0
                return 1;
1457
0
            break;
1458
0
        case COMPRESSION_ZSTD:
1459
0
            if (tag == TIFFTAG_PREDICTOR)
1460
0
                return 1;
1461
0
            break;
1462
0
        case COMPRESSION_LERC:
1463
0
            if (tag == TIFFTAG_LERC_PARAMETERS)
1464
0
                return 1;
1465
0
            break;
1466
0
        default:
1467
0
            break;
1468
0
    }
1469
0
    return 0;
1470
0
}