[trunk] Update libtiff to 4.0.1 to support BigTIFF. openjpeg/tiff 4.0.1 currently builds on linux/x86_64 and linux/mingw32.

This commit is contained in:
Mathieu Malaterre 2012-03-12 11:35:35 +00:00
parent 3de14fc63e
commit ecd5c523dc
58 changed files with 16524 additions and 8450 deletions

View File

@ -57,7 +57,10 @@ IF(BUILD_THIRDPARTY)
message(STATUS "We will build TIFF lib from thirdparty") message(STATUS "We will build TIFF lib from thirdparty")
ADD_SUBDIRECTORY(libtiff) ADD_SUBDIRECTORY(libtiff)
SET(TIFF_LIBNAME tiff PARENT_SCOPE) SET(TIFF_LIBNAME tiff PARENT_SCOPE)
SET(TIFF_INCLUDE_DIRNAME ${OPENJPEG_SOURCE_DIR}/thirdparty/libtiff PARENT_SCOPE) SET(TIFF_INCLUDE_DIRNAME
${OPENJPEG_SOURCE_DIR}/thirdparty/libtiff
${OPENJPEG_BINARY_DIR}/thirdparty/libtiff
PARENT_SCOPE)
SET(HAVE_TIFF_H 1 PARENT_SCOPE) SET(HAVE_TIFF_H 1 PARENT_SCOPE)
SET(HAVE_LIBTIFF 1 PARENT_SCOPE) SET(HAVE_LIBTIFF 1 PARENT_SCOPE)
ELSE (BUILD_THIRDPARTY) ELSE (BUILD_THIRDPARTY)

View File

@ -1,78 +1,194 @@
CMAKE_MINIMUM_REQUIRED(VERSION 2.6) CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
project(libtiff C) project(libtiff C)
# This convenient copy of libtiff does not support encapsulated zlib or jpeg
# stream. see ZIP_SUPPORT and JPEG_SUPPORT values
INCLUDE_DIRECTORIES("${CMAKE_CURRENT_SOURCE_DIR}") INCLUDE_DIRECTORIES(BEFORE "${CMAKE_CURRENT_SOURCE_DIR}")
# INCLUDE_DIRECTORIES(BEFORE "${CMAKE_CURRENT_BINARY_DIR}")
ADD_DEFINITIONS(-DHAVE_STRING_H=1)
SET(TARGET_FILES SET(TARGET_FILES
t4.h t4.h
tiffiop.h tiffiop.h
tif_aux.c tif_aux.c
tif_close.c tif_close.c
tif_codec.c tif_codec.c
tif_color.c tif_color.c
tif_compress.c tif_compress.c
tif_dir.c tif_dir.c
tif_dir.h tif_dir.h
tif_dirinfo.c tif_dirinfo.c
tif_dirread.c tif_dirread.c
tif_dirwrite.c tif_dirwrite.c
tif_dumpmode.c tif_dumpmode.c
tif_error.c tif_error.c
tif_extension.c tif_extension.c
tif_fax3.c tif_fax3.c
tif_fax3.h tif_fax3.h
tif_fax3sm.c tif_fax3sm.c
tif_flush.c tif_flush.c
tif_getimage.c tif_getimage.c
tif_jbig.c tif_jbig.c
tif_jpeg.c tif_jpeg.c
tif_luv.c tif_luv.c
tif_lzw.c tif_lzw.c
tif_next.c tif_next.c
tif_ojpeg.c tif_ojpeg.c
tif_open.c tif_open.c
tif_packbits.c tif_packbits.c
tif_pixarlog.c tif_pixarlog.c
tif_predict.c tif_predict.c
tif_predict.h tif_predict.h
tif_print.c tif_print.c
tif_read.c tif_read.c
tif_strip.c tif_strip.c
tif_swab.c tif_swab.c
tif_thunder.c tif_thunder.c
tif_tile.c tif_tile.c
tif_version.c tif_version.c
tif_warning.c tif_warning.c
tif_write.c tif_write.c
tif_zip.c tif_zip.c
uvcode.h tif_jpeg_12.c
) tif_lzma.c
uvcode.h
)
IF(UNIX) IF(UNIX)
SET(TARGET_FILES ${TARGET_FILES} tif_unix.c) SET(TARGET_FILES ${TARGET_FILES} tif_unix.c)
ELSE()
SET(TARGET_FILES ${TARGET_FILES} tif_win32.c)
ENDIF() ENDIF()
IF(WIN32) include(${CMAKE_ROOT}/Modules/TestBigEndian.cmake)
SET(TARGET_FILES ${TARGET_FILES} tif_win32.c) TEST_BIG_ENDIAN(WORDS_BIGENDIAN)
ENDIF(WIN32) set(HOST_BIGENDIAN ${WORDS_BIGENDIAN})
if(HOST_BIGENDIAN)
set(HOST_FILLORDER "FILLORDER_MSB2LSB")
else()
set(HOST_FILLORDER "FILLORDER_LSB2MSB")
endif()
include(CheckIncludeFiles)
include(CheckSymbolExists)
include(CheckFunctionExists)
#IF(APPLE) CHECK_INCLUDE_FILES("zlib.h" HAVE_ZLIB_H)
# SET(TARGET_FILES ${TARGET_FILES} tif_apple.c) CHECK_INCLUDE_FILES("jpeglib.h" HAVE_JPEGLIB_H)
#ENDIF(APPLE) if(HAVE_JPEGLIB_H)
set(JPEG_SUPPORT 1)
endif()
if(HAVE_ZLIB_H)
set(ZIP_SUPPORT 1)
set(PIXARLOG_SUPPORT 1) # require zlib
endif()
CHECK_INCLUDE_FILES("assert.h" HAVE_ASSERT_H)
CHECK_INCLUDE_FILES("dlfcn.h" HAVE_DLFCN_H)
CHECK_INCLUDE_FILES("fcntl.h" HAVE_FCNTL_H)
CHECK_INCLUDE_FILES("inttypes.h" HAVE_INTTYPES_H)
CHECK_INCLUDE_FILES("io.h" HAVE_IO_H)
CHECK_INCLUDE_FILES("limits.h" HAVE_LIMITS_H)
CHECK_INCLUDE_FILES("malloc.h" HAVE_MALLOC_H)
CHECK_INCLUDE_FILES("memory.h" HAVE_MEMORY_H)
CHECK_INCLUDE_FILES("search.h" HAVE_SEARCH_H)
CHECK_INCLUDE_FILES("stdint.h" HAVE_STDINT_H)
CHECK_INCLUDE_FILES("stdlib.h" HAVE_STDLIB_H)
CHECK_INCLUDE_FILES("string.h" HAVE_STRING_H)
CHECK_INCLUDE_FILES("strings.h" HAVE_STRINGS_H)
CHECK_INCLUDE_FILES("sys/stat.h" HAVE_SYS_STAT_H)
CHECK_INCLUDE_FILES("sys/time.h" HAVE_SYS_TIME_H)
CHECK_INCLUDE_FILES("time.h" HAVE_TIME_H)
CHECK_INCLUDE_FILES("sys/types.h" HAVE_SYS_TYPES_H)
CHECK_INCLUDE_FILES("unistd.h" HAVE_UNISTD_H)
CHECK_INCLUDE_FILES("windows.h" HAVE_WINDOWS_H)
CHECK_INCLUDE_FILES("strings.h" HAVE_STRINGS_H)
CHECK_INCLUDE_FILES("ieeefp.h" HAVE_IEEEFP_H)
# wotsit ?
if( HAVE_TIME_H AND HAVE_SYS_TIME_H )
set(TIME_WITH_SYS_TIME 1)
endif()
set(LZMA_SUPPORT 0) # ?
set(MDI_SUPPORT 1) # ?
set(STDC_HEADERS 1) # why not ?
set(DEFAULT_EXTRASAMPLE_AS_ALPHA 1)
set(CHECK_JPEG_YCBCR_SUBSAMPLING 1)
set(CCITT_SUPPORT 1)
set(DEFER_STRILE_LOAD 0)
set(HAVE_JBG_NEWLEN 0) # FIXME: jbigkit stuff
set(STRIPCHOP_DEFAULT "TIFF_STRIPCHOP")
set(STRIP_SIZE_DEFAULT 8192)
set(SUBIFD_SUPPORT 1)
set(THUNDER_SUPPORT 1)
if(HAVE_STDINT_H)
set(TIFF_INT8_T int8_t)
set(TIFF_INT16_T int16_t)
set(TIFF_INT32_T int32_t)
set(TIFF_INT64_T int64_t)
set(TIFF_UINT8_T uint8_t)
set(TIFF_UINT16_T uint16_t)
set(TIFF_UINT32_T uint32_t)
set(TIFF_UINT64_T uint64_t)
set(TIFF_PTRDIFF_T ptrdiff_t)
set(TIFF_SSIZE_T ssize_t)
set(TIFF_INT32_FORMAT "\"%d\"")
set(TIFF_UINT32_FORMAT "\"%u\"")
set(TIFF_INT64_FORMAT "\"%ld\"")
set(TIFF_UINT64_FORMAT "\"%lu\"")
set(TIFF_PTRDIFF_FORMAT "\"%ld\"")
set(TIFF_SSIZE_FORMAT "\"%ld\"")
endif()
CHECK_FUNCTION_EXISTS(getopt HAVE_GETOPT)
CHECK_FUNCTION_EXISTS(isascii HAVE_ISASCII)
CHECK_FUNCTION_EXISTS(memmove HAVE_MEMMOVE)
CHECK_FUNCTION_EXISTS(memset HAVE_MEMSET)
CHECK_FUNCTION_EXISTS(mmap HAVE_MMAP)
CHECK_FUNCTION_EXISTS(strcasecmp HAVE_STRCASECMP)
CHECK_FUNCTION_EXISTS(strchr HAVE_STRCHR)
CHECK_FUNCTION_EXISTS(strrchr HAVE_STRRCHR)
CHECK_FUNCTION_EXISTS(strstr HAVE_STRSTR)
CHECK_FUNCTION_EXISTS(strtol HAVE_STRTOL)
CHECK_FUNCTION_EXISTS(strtoul HAVE_STRTOUL)
CHECK_FUNCTION_EXISTS(strtoull HAVE_STRTOULL)
include(CheckTypeSize)
CHECK_TYPE_SIZE("signed int" SIZEOF_SIGNED_INT)
CHECK_TYPE_SIZE("signed long" SIZEOF_SIGNED_LONG)
CHECK_TYPE_SIZE("signed long long" SIZEOF_SIGNED_LONG_LONG)
CHECK_TYPE_SIZE("signed short" SIZEOF_SIGNED_SHORT)
CHECK_TYPE_SIZE("unsigned int" SIZEOF_UNSIGNED_INT)
CHECK_TYPE_SIZE("unsigned long" SIZEOF_UNSIGNED_LONG)
CHECK_TYPE_SIZE("unsigned long long" SIZEOF_UNSIGNED_LONG_LONG)
CHECK_TYPE_SIZE("unsigned short" SIZEOF_UNSIGNED_SHORT)
CHECK_TYPE_SIZE("unsigned char*" SIZEOF_UNSIGNED_CHAR_P)
#
set(VERSION "\"4.0.1\"")
set(PACKAGE_VERSION ${VERSION})
set(PACKAGE "\"tiff\"")
if(UNIX)
set(CMAKE_REQUIRED_LIBRARIES m)
set(HAVE_LIBM 1)
endif()
CHECK_SYMBOL_EXISTS(floor "math.h" HAVE_FLOOR)
CHECK_SYMBOL_EXISTS(sqrt "math.h" HAVE_SQRT)
CHECK_SYMBOL_EXISTS(pow "math.h" HAVE_POW)
CHECK_SYMBOL_EXISTS(lfind "search.h" HAVE_LFIND)
CHECK_SYMBOL_EXISTS(setmod "io.h" HAVE_SETMODE)
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/tiffconf.h.cmake.in
${CMAKE_CURRENT_BINARY_DIR}/tiffconf.h @ONLY)
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/tif_config.h.cmake.in
${CMAKE_CURRENT_BINARY_DIR}/tif_config.h @ONLY)
SET(LIBTARGET "tiff") SET(LIBTARGET "tiff")
# #
ADD_LIBRARY(${LIBTARGET} STATIC ${TARGET_FILES}) ADD_LIBRARY(${LIBTARGET} STATIC ${TARGET_FILES})
# #
IF(MSVC)
SET_TARGET_PROPERTIES(${LIBTARGET} PROPERTIES PREFIX "lib")
ENDIF(MSVC)
#
SET_TARGET_PROPERTIES(${LIBTARGET} SET_TARGET_PROPERTIES(${LIBTARGET}
PROPERTIES PROPERTIES
OUTPUT_NAME "${LIBTARGET}" OUTPUT_NAME "${LIBTARGET}"
ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/thirdparty/lib ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/thirdparty/lib
) )
#

151
thirdparty/libtiff/libtiff.def vendored Normal file
View File

@ -0,0 +1,151 @@
EXPORTS TIFFOpen
TIFFOpenW
TIFFGetVersion
TIFFCleanup
TIFFClose
TIFFFlush
TIFFFlushData
TIFFGetField
TIFFVGetField
TIFFGetFieldDefaulted
TIFFVGetFieldDefaulted
TIFFGetTagListEntry
TIFFGetTagListCount
TIFFReadDirectory
TIFFScanlineSize64
TIFFScanlineSize
TIFFStripSize64
TIFFStripSize
TIFFVStripSize64
TIFFVStripSize
TIFFRawStripSize64
TIFFRawStripSize
TIFFTileRowSize64
TIFFTileRowSize
TIFFTileSize64
TIFFTileSize
TIFFVTileSize64
TIFFVTileSize
TIFFFileno
TIFFSetFileno
TIFFGetMode
TIFFIsTiled
TIFFIsByteSwapped
TIFFIsBigEndian
TIFFIsMSB2LSB
TIFFIsUpSampled
TIFFCIELabToRGBInit
TIFFCIELabToXYZ
TIFFXYZToRGB
TIFFYCbCrToRGBInit
TIFFYCbCrtoRGB
TIFFCurrentRow
TIFFCurrentDirectory
TIFFCurrentStrip
TIFFCurrentTile
TIFFDataWidth
TIFFReadBufferSetup
TIFFWriteBufferSetup
TIFFSetupStrips
TIFFLastDirectory
TIFFSetDirectory
TIFFSetSubDirectory
TIFFUnlinkDirectory
TIFFSetField
TIFFVSetField
TIFFCheckpointDirectory
TIFFWriteDirectory
TIFFRewriteDirectory
TIFFPrintDirectory
TIFFReadScanline
TIFFWriteScanline
TIFFReadRGBAImage
TIFFReadRGBAImageOriented
TIFFFdOpen
TIFFClientOpen
TIFFFileName
TIFFError
TIFFErrorExt
TIFFWarning
TIFFWarningExt
TIFFSetErrorHandler
TIFFSetErrorHandlerExt
TIFFSetWarningHandler
TIFFSetWarningHandlerExt
TIFFComputeTile
TIFFCheckTile
TIFFNumberOfTiles
TIFFReadTile
TIFFWriteTile
TIFFComputeStrip
TIFFNumberOfStrips
TIFFRGBAImageBegin
TIFFRGBAImageGet
TIFFRGBAImageEnd
TIFFReadEncodedStrip
TIFFReadRawStrip
TIFFReadEncodedTile
TIFFReadRawTile
TIFFReadRGBATile
TIFFReadRGBAStrip
TIFFWriteEncodedStrip
TIFFWriteRawStrip
TIFFWriteEncodedTile
TIFFWriteRawTile
TIFFSetWriteOffset
TIFFSwabFloat
TIFFSwabDouble
TIFFSwabShort
TIFFSwabLong
TIFFSwabArrayOfShort
TIFFSwabArrayOfLong
TIFFSwabArrayOfFloat
TIFFSwabArrayOfDouble
TIFFSwabArrayOfTriples
TIFFReverseBits
TIFFGetBitRevTable
TIFFDefaultStripSize
TIFFDefaultTileSize
TIFFRasterScanlineSize64
TIFFRasterScanlineSize
_TIFFmalloc
_TIFFrealloc
_TIFFfree
_TIFFmemset
_TIFFmemcpy
_TIFFmemcmp
TIFFCreateDirectory
TIFFSetTagExtender
TIFFFieldWithName
TIFFFieldWithTag
TIFFCurrentDirOffset
TIFFWriteCheck
TIFFRGBAImageOK
TIFFNumberOfDirectories
TIFFSetFileName
TIFFSetClientdata
TIFFSetMode
TIFFClientdata
TIFFGetReadProc
TIFFGetWriteProc
TIFFGetSeekProc
TIFFGetCloseProc
TIFFGetSizeProc
TIFFGetMapFileProc
TIFFGetUnmapFileProc
TIFFIsCODECConfigured
TIFFGetConfiguredCODECs
TIFFFindCODEC
TIFFRegisterCODEC
TIFFUnRegisterCODEC
TIFFFreeDirectory
TIFFReadCustomDirectory
TIFFReadEXIFDirectory
TIFFAccessTagMethods
TIFFGetClientInfo
TIFFSetClientInfo
TIFFSwabLong8
TIFFSwabArrayOfLong8
TIFFFindField
TIFFUnsetField
TIFFMergeFieldInfo

View File

@ -1,26 +1,26 @@
/* $Id: t4.h,v 1.1.1.1.2.1 2010-06-08 18:50:41 bfriesen Exp $ */ /* $Id: t4.h,v 1.3 2010-03-10 18:56:48 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
* Copyright (c) 1991-1997 Silicon Graphics, Inc. * Copyright (c) 1991-1997 Silicon Graphics, Inc.
* *
* Permission to use, copy, modify, distribute, and sell this software and * Permission to use, copy, modify, distribute, and sell this software and
* its documentation for any purpose is hereby granted without fee, provided * its documentation for any purpose is hereby granted without fee, provided
* that (i) the above copyright notices and this permission notice appear in * that (i) the above copyright notices and this permission notice appear in
* all copies of the software and related documentation, and (ii) the names of * all copies of the software and related documentation, and (ii) the names of
* Sam Leffler and Silicon Graphics may not be used in any advertising or * Sam Leffler and Silicon Graphics may not be used in any advertising or
* publicity relating to the software without the specific, prior written * publicity relating to the software without the specific, prior written
* permission of Sam Leffler and Silicon Graphics. * permission of Sam Leffler and Silicon Graphics.
* *
* THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND, * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
* EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
* WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
* *
* IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
* ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
* OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
* WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
* LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
* OF THIS SOFTWARE. * OF THIS SOFTWARE.
*/ */
@ -33,18 +33,18 @@
* worthwhile to make code & length 8 bits. * worthwhile to make code & length 8 bits.
*/ */
typedef struct tableentry { typedef struct tableentry {
unsigned short length; /* bit length of g3 code */ unsigned short length; /* bit length of g3 code */
unsigned short code; /* g3 code */ unsigned short code; /* g3 code */
short runlen; /* run length in bits */ short runlen; /* run length in bits */
} tableentry; } tableentry;
#define EOL 0x001 /* EOL code value - 0000 0000 0000 1 */ #define EOL 0x001 /* EOL code value - 0000 0000 0000 1 */
/* status values returned instead of a run length */ /* status values returned instead of a run length */
#define G3CODE_EOL -1 /* NB: ACT_EOL - ACT_WRUNT */ #define G3CODE_EOL -1 /* NB: ACT_EOL - ACT_WRUNT */
#define G3CODE_INVALID -2 /* NB: ACT_INVALID - ACT_WRUNT */ #define G3CODE_INVALID -2 /* NB: ACT_INVALID - ACT_WRUNT */
#define G3CODE_EOF -3 /* end of input data */ #define G3CODE_EOF -3 /* end of input data */
#define G3CODE_INCOMP -4 /* incomplete run code */ #define G3CODE_INCOMP -4 /* incomplete run code */
/* /*
* Note that these tables are ordered such that the * Note that these tables are ordered such that the
@ -279,8 +279,8 @@ const tableentry TIFFFaxBlackCodes[] = {
{ 12, 0x0, G3CODE_INVALID }, /* 0000 0000 0000 */ { 12, 0x0, G3CODE_INVALID }, /* 0000 0000 0000 */
}; };
#else #else
extern const tableentry TIFFFaxWhiteCodes[]; extern const tableentry TIFFFaxWhiteCodes[];
extern const tableentry TIFFFaxBlackCodes[]; extern const tableentry TIFFFaxBlackCodes[];
#endif #endif
#endif /* _T4_ */ #endif /* _T4_ */
/* /*

View File

@ -1,281 +0,0 @@
/* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/Attic/tif_apple.c,v 1.3.2.1 2010-06-08 18:50:41 bfriesen Exp $ */
/*
* Copyright (c) 1988-1997 Sam Leffler
* Copyright (c) 1991-1997 Silicon Graphics, Inc.
*
* Permission to use, copy, modify, distribute, and sell this software and
* its documentation for any purpose is hereby granted without fee, provided
* that (i) the above copyright notices and this permission notice appear in
* all copies of the software and related documentation, and (ii) the names of
* Sam Leffler and Silicon Graphics may not be used in any advertising or
* publicity relating to the software without the specific, prior written
* permission of Sam Leffler and Silicon Graphics.
*
* THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
* EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
* WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
*
* IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
* ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
* OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
* WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
* LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
* OF THIS SOFTWARE.
*/
/*
* TIFF Library Macintosh-specific routines.
*
* These routines use only Toolbox and high-level File Manager traps.
* They make no calls to the THINK C "unix" compatibility library. Also,
* malloc is not used directly but it is still referenced internally by
* the ANSI library in rare cases. Heap fragmentation by the malloc ring
* buffer is therefore minimized.
*
* O_RDONLY and O_RDWR are treated identically here. The tif_mode flag is
* checked in TIFFWriteCheck().
*
* Create below fills in a blank creator signature and sets the file type
* to 'TIFF'. It is much better for the application to do this by Create'ing
* the file first and TIFFOpen'ing it later.
* ---------
* This code has been "Carbonized", and may not work with older MacOS versions.
* If so, grab the tif_apple.c out of an older libtiff distribution, like
* 3.5.5 from www.libtiff.org.
*/
#include "tiffiop.h"
#include <Errors.h>
#include <Files.h>
#include <Memory.h>
#include <Script.h>
#if defined(__PPCC__) || defined(__SC__) || defined(__MRC__) || defined(applec)
#define CtoPstr c2pstr
#endif
static tsize_t
_tiffReadProc(thandle_t fd, tdata_t buf, tsize_t size)
{
return (FSRead((short) fd, (long*) &size, (char*) buf) == noErr ?
size : (tsize_t) -1);
}
static tsize_t
_tiffWriteProc(thandle_t fd, tdata_t buf, tsize_t size)
{
return (FSWrite((short) fd, (long*) &size, (char*) buf) == noErr ?
size : (tsize_t) -1);
}
static toff_t
_tiffSeekProc(thandle_t fd, toff_t off, int whence)
{
long fpos, size;
if (GetEOF((short) fd, &size) != noErr)
return EOF;
(void) GetFPos((short) fd, &fpos);
switch (whence) {
case SEEK_CUR:
if (off + fpos > size)
SetEOF((short) fd, off + fpos);
if (SetFPos((short) fd, fsFromMark, off) != noErr)
return EOF;
break;
case SEEK_END:
if (off > 0)
SetEOF((short) fd, off + size);
if (SetFPos((short) fd, fsFromStart, off + size) != noErr)
return EOF;
break;
case SEEK_SET:
if (off > size)
SetEOF((short) fd, off);
if (SetFPos((short) fd, fsFromStart, off) != noErr)
return EOF;
break;
}
return (toff_t)(GetFPos((short) fd, &fpos) == noErr ? fpos : EOF);
}
static int
_tiffMapProc(thandle_t fd, tdata_t* pbase, toff_t* psize)
{
return (0);
}
static void
_tiffUnmapProc(thandle_t fd, tdata_t base, toff_t size)
{
}
static int
_tiffCloseProc(thandle_t fd)
{
return (FSClose((short) fd));
}
static toff_t
_tiffSizeProc(thandle_t fd)
{
long size;
if (GetEOF((short) fd, &size) != noErr) {
TIFFErrorExt(fd, "_tiffSizeProc", "%s: Cannot get file size");
return (-1L);
}
return ((toff_t) size);
}
/*
* Open a TIFF file descriptor for read/writing.
*/
TIFF*
TIFFFdOpen(int fd, const char* name, const char* mode)
{
TIFF* tif;
tif = TIFFClientOpen(name, mode, (thandle_t) fd,
_tiffReadProc, _tiffWriteProc, _tiffSeekProc, _tiffCloseProc,
_tiffSizeProc, _tiffMapProc, _tiffUnmapProc);
if (tif)
tif->tif_fd = fd;
return (tif);
}
static void ourc2pstr( char* inString )
{
int sLen = strlen( inString );
BlockMoveData( inString, &inString[1], sLen );
inString[0] = sLen;
}
/*
* Open a TIFF file for read/writing.
*/
TIFF*
TIFFOpen(const char* name, const char* mode)
{
static const char module[] = "TIFFOpen";
Str255 pname;
FInfo finfo;
short fref;
OSErr err;
FSSpec fSpec;
strcpy((char*) pname, name);
ourc2pstr((char*) pname);
err = FSMakeFSSpec( 0, 0, pname, &fSpec );
switch (_TIFFgetMode(mode, module)) {
default:
return ((TIFF*) 0);
case O_RDWR | O_CREAT | O_TRUNC:
if (FSpGetFInfo(&fSpec, &finfo) == noErr)
FSpDelete(&fSpec);
/* fall through */
case O_RDWR | O_CREAT:
if ((err = FSpGetFInfo(&fSpec, &finfo)) == fnfErr) {
if (FSpCreate(&fSpec, ' ', 'TIFF', smSystemScript) != noErr)
goto badCreate;
if (FSpOpenDF(&fSpec, fsRdWrPerm, &fref) != noErr)
goto badOpen;
} else if (err == noErr) {
if (FSpOpenDF(&fSpec, fsRdWrPerm, &fref) != noErr)
goto badOpen;
} else
goto badOpen;
break;
case O_RDONLY:
if (FSpOpenDF(&fSpec, fsRdPerm, &fref) != noErr)
goto badOpen;
break;
case O_RDWR:
if (FSpOpenDF(&fSpec, fsRdWrPerm, &fref) != noErr)
goto badOpen;
break;
}
return (TIFFFdOpen((int) fref, name, mode));
badCreate:
TIFFErrorExt(0, module, "%s: Cannot create", name);
return ((TIFF*) 0);
badOpen:
TIFFErrorExt(0, module, "%s: Cannot open", name);
return ((TIFF*) 0);
}
void
_TIFFmemset(tdata_t p, int v, tsize_t c)
{
memset(p, v, (size_t) c);
}
void
_TIFFmemcpy(tdata_t d, const tdata_t s, tsize_t c)
{
memcpy(d, s, (size_t) c);
}
int
_TIFFmemcmp(const tdata_t p1, const tdata_t p2, tsize_t c)
{
return (memcmp(p1, p2, (size_t) c));
}
tdata_t
_TIFFmalloc(tsize_t s)
{
return (NewPtr((size_t) s));
}
void
_TIFFfree(tdata_t p)
{
DisposePtr(p);
}
tdata_t
_TIFFrealloc(tdata_t p, tsize_t s)
{
Ptr n = p;
SetPtrSize(p, (size_t) s);
if (MemError() && (n = NewPtr((size_t) s)) != NULL) {
BlockMove(p, n, GetPtrSize(p));
DisposePtr(p);
}
return ((tdata_t) n);
}
static void
appleWarningHandler(const char* module, const char* fmt, va_list ap)
{
if (module != NULL)
fprintf(stderr, "%s: ", module);
fprintf(stderr, "Warning, ");
vfprintf(stderr, fmt, ap);
fprintf(stderr, ".\n");
}
TIFFErrorHandler _TIFFwarningHandler = appleWarningHandler;
static void
appleErrorHandler(const char* module, const char* fmt, va_list ap)
{
if (module != NULL)
fprintf(stderr, "%s: ", module);
vfprintf(stderr, fmt, ap);
fprintf(stderr, ".\n");
}
TIFFErrorHandler _TIFFerrorHandler = appleErrorHandler;
/*
* Local Variables:
* mode: c
* c-basic-offset: 8
* fill-column: 78
* End:
*/

View File

@ -1,4 +1,4 @@
/* $Id: tif_aux.c,v 1.20.2.3 2010-06-09 21:15:27 bfriesen Exp $ */ /* $Id: tif_aux.c,v 1.26 2010-07-01 15:33:28 dron Exp $ */
/* /*
* Copyright (c) 1991-1997 Sam Leffler * Copyright (c) 1991-1997 Sam Leffler
@ -33,12 +33,38 @@
#include "tif_predict.h" #include "tif_predict.h"
#include <math.h> #include <math.h>
tdata_t uint32
_TIFFCheckRealloc(TIFF* tif, tdata_t buffer, _TIFFMultiply32(TIFF* tif, uint32 first, uint32 second, const char* where)
size_t nmemb, size_t elem_size, const char* what)
{ {
tdata_t cp = NULL; uint32 bytes = first * second;
tsize_t bytes = nmemb * elem_size;
if (second && bytes / second != first) {
TIFFErrorExt(tif->tif_clientdata, where, "Integer overflow in %s", where);
bytes = 0;
}
return bytes;
}
uint64
_TIFFMultiply64(TIFF* tif, uint64 first, uint64 second, const char* where)
{
uint64 bytes = first * second;
if (second && bytes / second != first) {
TIFFErrorExt(tif->tif_clientdata, where, "Integer overflow in %s", where);
bytes = 0;
}
return bytes;
}
void*
_TIFFCheckRealloc(TIFF* tif, void* buffer,
tmsize_t nmemb, tmsize_t elem_size, const char* what)
{
void* cp = NULL;
tmsize_t bytes = nmemb * elem_size;
/* /*
* XXX: Check for integer overflow. * XXX: Check for integer overflow.
@ -46,32 +72,33 @@ _TIFFCheckRealloc(TIFF* tif, tdata_t buffer,
if (nmemb && elem_size && bytes / elem_size == nmemb) if (nmemb && elem_size && bytes / elem_size == nmemb)
cp = _TIFFrealloc(buffer, bytes); cp = _TIFFrealloc(buffer, bytes);
if (cp == NULL) if (cp == NULL) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, tif->tif_name,
"Failed to allocate memory for %s " "Failed to allocate memory for %s "
"(%ld elements of %ld bytes each)", "(%ld elements of %ld bytes each)",
what,(long) nmemb, (long) elem_size); what,(long) nmemb, (long) elem_size);
}
return cp; return cp;
} }
tdata_t void*
_TIFFCheckMalloc(TIFF* tif, size_t nmemb, size_t elem_size, const char* what) _TIFFCheckMalloc(TIFF* tif, tmsize_t nmemb, tmsize_t elem_size, const char* what)
{ {
return _TIFFCheckRealloc(tif, NULL, nmemb, elem_size, what); return _TIFFCheckRealloc(tif, NULL, nmemb, elem_size, what);
} }
static int static int
TIFFDefaultTransferFunction(TIFFDirectory* td) TIFFDefaultTransferFunction(TIFFDirectory* td)
{ {
uint16 **tf = td->td_transferfunction; uint16 **tf = td->td_transferfunction;
tsize_t i, n, nbytes; tmsize_t i, n, nbytes;
tf[0] = tf[1] = tf[2] = 0; tf[0] = tf[1] = tf[2] = 0;
if (td->td_bitspersample >= sizeof(tsize_t) * 8 - 2) if (td->td_bitspersample >= sizeof(tmsize_t) * 8 - 2)
return 0; return 0;
n = 1<<td->td_bitspersample; n = ((tmsize_t)1)<<td->td_bitspersample;
nbytes = n * sizeof (uint16); nbytes = n * sizeof (uint16);
if (!(tf[0] = (uint16 *)_TIFFmalloc(nbytes))) if (!(tf[0] = (uint16 *)_TIFFmalloc(nbytes)))
return 0; return 0;
@ -140,7 +167,7 @@ TIFFDefaultRefBlackWhite(TIFFDirectory* td)
* place in the library -- in TIFFDefaultDirectory. * place in the library -- in TIFFDefaultDirectory.
*/ */
int int
TIFFVGetFieldDefaulted(TIFF* tif, ttag_t tag, va_list ap) TIFFVGetFieldDefaulted(TIFF* tif, uint32 tag, va_list ap)
{ {
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
@ -269,7 +296,7 @@ TIFFVGetFieldDefaulted(TIFF* tif, ttag_t tag, va_list ap)
* value if the tag is not present in the directory. * value if the tag is not present in the directory.
*/ */
int int
TIFFGetFieldDefaulted(TIFF* tif, ttag_t tag, ...) TIFFGetFieldDefaulted(TIFF* tif, uint32 tag, ...)
{ {
int ok; int ok;
va_list ap; va_list ap;
@ -280,6 +307,47 @@ TIFFGetFieldDefaulted(TIFF* tif, ttag_t tag, ...)
return (ok); return (ok);
} }
struct _Int64Parts {
int32 low, high;
};
typedef union {
struct _Int64Parts part;
int64 value;
} _Int64;
float
_TIFFUInt64ToFloat(uint64 ui64)
{
_Int64 i;
i.value = ui64;
if (i.part.high >= 0) {
return (float)i.value;
} else {
long double df;
df = (long double)i.value;
df += 18446744073709551616.0; /* adding 2**64 */
return (float)df;
}
}
double
_TIFFUInt64ToDouble(uint64 ui64)
{
_Int64 i;
i.value = ui64;
if (i.part.high >= 0) {
return (double)i.value;
} else {
long double df;
df = (long double)i.value;
df += 18446744073709551616.0; /* adding 2**64 */
return (double)df;
}
}
/* vim: set ts=8 sts=8 sw=8 noet: */ /* vim: set ts=8 sts=8 sw=8 noet: */
/* /*
* Local Variables: * Local Variables:

View File

@ -1,4 +1,4 @@
/* $Id: tif_close.c,v 1.10.2.1 2010-06-08 18:50:41 bfriesen Exp $ */ /* $Id: tif_close.c,v 1.19 2010-03-10 18:56:48 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -28,6 +28,7 @@
* TIFF Library. * TIFF Library.
*/ */
#include "tiffiop.h" #include "tiffiop.h"
#include <string.h>
/************************************************************************/ /************************************************************************/
/* TIFFCleanup() */ /* TIFFCleanup() */
@ -45,18 +46,20 @@
void void
TIFFCleanup(TIFF* tif) TIFFCleanup(TIFF* tif)
{ {
/*
* Flush buffered data and directory (if dirty).
*/
if (tif->tif_mode != O_RDONLY) if (tif->tif_mode != O_RDONLY)
/* TIFFFlush(tif);
* Flush buffered data and directory (if dirty).
*/
TIFFFlush(tif);
(*tif->tif_cleanup)(tif); (*tif->tif_cleanup)(tif);
TIFFFreeDirectory(tif); TIFFFreeDirectory(tif);
if (tif->tif_dirlist) if (tif->tif_dirlist)
_TIFFfree(tif->tif_dirlist); _TIFFfree(tif->tif_dirlist);
/* Clean up client info links */ /*
* Clean up client info links.
*/
while( tif->tif_clientinfo ) while( tif->tif_clientinfo )
{ {
TIFFClientInfoLink *link = tif->tif_clientinfo; TIFFClientInfoLink *link = tif->tif_clientinfo;
@ -69,27 +72,36 @@ TIFFCleanup(TIFF* tif)
if (tif->tif_rawdata && (tif->tif_flags&TIFF_MYBUFFER)) if (tif->tif_rawdata && (tif->tif_flags&TIFF_MYBUFFER))
_TIFFfree(tif->tif_rawdata); _TIFFfree(tif->tif_rawdata);
if (isMapped(tif)) if (isMapped(tif))
TIFFUnmapFileContents(tif, tif->tif_base, tif->tif_size); TIFFUnmapFileContents(tif, tif->tif_base, (toff_t)tif->tif_size);
/* Clean up custom fields */ /*
if (tif->tif_nfields > 0) * Clean up custom fields.
{ */
size_t i; if (tif->tif_fields && tif->tif_nfields > 0) {
uint32 i;
for (i = 0; i < tif->tif_nfields; i++) for (i = 0; i < tif->tif_nfields; i++) {
{ TIFFField *fld = tif->tif_fields[i];
TIFFFieldInfo *fld = tif->tif_fieldinfo[i]; if (fld->field_bit == FIELD_CUSTOM &&
if (fld->field_bit == FIELD_CUSTOM && strncmp("Tag ", fld->field_name, 4) == 0) {
strncmp("Tag ", fld->field_name, 4) == 0) _TIFFfree(fld->field_name);
{ _TIFFfree(fld);
_TIFFfree(fld->field_name); }
_TIFFfree(fld);
} }
}
_TIFFfree(tif->tif_fields);
_TIFFfree(tif->tif_fieldinfo);
} }
if (tif->tif_nfieldscompat > 0) {
uint32 i;
for (i = 0; i < tif->tif_nfieldscompat; i++) {
if (tif->tif_fieldscompat[i].allocated_size)
_TIFFfree(tif->tif_fieldscompat[i].fields);
}
_TIFFfree(tif->tif_fieldscompat);
}
_TIFFfree(tif); _TIFFfree(tif);
} }
@ -117,6 +129,8 @@ TIFFClose(TIFF* tif)
(void) (*closeproc)(fd); (void) (*closeproc)(fd);
} }
/* vim: set ts=8 sts=8 sw=8 noet: */
/* /*
* Local Variables: * Local Variables:
* mode: c * mode: c

View File

@ -1,4 +1,4 @@
/* $Id: tif_codec.c,v 1.10.2.2 2010-06-08 18:50:41 bfriesen Exp $ */ /* $Id: tif_codec.c,v 1.15 2010-12-14 12:53:00 dron Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -31,43 +31,46 @@
*/ */
#include "tiffiop.h" #include "tiffiop.h"
static int NotConfigured(TIFF*, int); static int NotConfigured(TIFF*, int);
#ifndef LZW_SUPPORT #ifndef LZW_SUPPORT
#define TIFFInitLZW NotConfigured #define TIFFInitLZW NotConfigured
#endif #endif
#ifndef PACKBITS_SUPPORT #ifndef PACKBITS_SUPPORT
#define TIFFInitPackBits NotConfigured #define TIFFInitPackBits NotConfigured
#endif #endif
#ifndef THUNDER_SUPPORT #ifndef THUNDER_SUPPORT
#define TIFFInitThunderScan NotConfigured #define TIFFInitThunderScan NotConfigured
#endif #endif
#ifndef NEXT_SUPPORT #ifndef NEXT_SUPPORT
#define TIFFInitNeXT NotConfigured #define TIFFInitNeXT NotConfigured
#endif #endif
#ifndef JPEG_SUPPORT #ifndef JPEG_SUPPORT
#define TIFFInitJPEG NotConfigured #define TIFFInitJPEG NotConfigured
#endif #endif
#ifndef OJPEG_SUPPORT #ifndef OJPEG_SUPPORT
#define TIFFInitOJPEG NotConfigured #define TIFFInitOJPEG NotConfigured
#endif #endif
#ifndef CCITT_SUPPORT #ifndef CCITT_SUPPORT
#define TIFFInitCCITTRLE NotConfigured #define TIFFInitCCITTRLE NotConfigured
#define TIFFInitCCITTRLEW NotConfigured #define TIFFInitCCITTRLEW NotConfigured
#define TIFFInitCCITTFax3 NotConfigured #define TIFFInitCCITTFax3 NotConfigured
#define TIFFInitCCITTFax4 NotConfigured #define TIFFInitCCITTFax4 NotConfigured
#endif #endif
#ifndef JBIG_SUPPORT #ifndef JBIG_SUPPORT
#define TIFFInitJBIG NotConfigured #define TIFFInitJBIG NotConfigured
#endif #endif
#ifndef ZIP_SUPPORT #ifndef ZIP_SUPPORT
#define TIFFInitZIP NotConfigured #define TIFFInitZIP NotConfigured
#endif #endif
#ifndef PIXARLOG_SUPPORT #ifndef PIXARLOG_SUPPORT
#define TIFFInitPixarLog NotConfigured #define TIFFInitPixarLog NotConfigured
#endif #endif
#ifndef LOGLUV_SUPPORT #ifndef LOGLUV_SUPPORT
#define TIFFInitSGILog NotConfigured #define TIFFInitSGILog NotConfigured
#endif
#ifndef LZMA_SUPPORT
#define TIFFInitLZMA NotConfigured
#endif #endif
/* /*
@ -95,6 +98,7 @@ TIFFCodec _TIFFBuiltinCODECS[] = {
{ "PixarLog", COMPRESSION_PIXARLOG, TIFFInitPixarLog }, { "PixarLog", COMPRESSION_PIXARLOG, TIFFInitPixarLog },
{ "SGILog", COMPRESSION_SGILOG, TIFFInitSGILog }, { "SGILog", COMPRESSION_SGILOG, TIFFInitSGILog },
{ "SGILog24", COMPRESSION_SGILOG24, TIFFInitSGILog }, { "SGILog24", COMPRESSION_SGILOG24, TIFFInitSGILog },
{ "LZMA", COMPRESSION_LZMA, TIFFInitLZMA },
{ NULL, 0, NULL } { NULL, 0, NULL }
}; };
@ -114,13 +118,14 @@ _notConfigured(TIFF* tif)
static int static int
NotConfigured(TIFF* tif, int scheme) NotConfigured(TIFF* tif, int scheme)
{ {
(void) scheme; (void) scheme;
tif->tif_decodestatus = FALSE; tif->tif_fixuptags = _notConfigured;
tif->tif_setupdecode = _notConfigured; tif->tif_decodestatus = FALSE;
tif->tif_encodestatus = FALSE; tif->tif_setupdecode = _notConfigured;
tif->tif_setupencode = _notConfigured; tif->tif_encodestatus = FALSE;
return (1); tif->tif_setupencode = _notConfigured;
return (1);
} }
/************************************************************************/ /************************************************************************/
@ -129,7 +134,7 @@ NotConfigured(TIFF* tif, int scheme)
/** /**
* Check whether we have working codec for the specific coding scheme. * Check whether we have working codec for the specific coding scheme.
* *
* @return returns 1 if the codec is configured and working. Otherwise * @return returns 1 if the codec is configured and working. Otherwise
* 0 will be returned. * 0 will be returned.
*/ */
@ -140,14 +145,14 @@ TIFFIsCODECConfigured(uint16 scheme)
const TIFFCodec* codec = TIFFFindCODEC(scheme); const TIFFCodec* codec = TIFFFindCODEC(scheme);
if(codec == NULL) { if(codec == NULL) {
return 0; return 0;
} }
if(codec->init == NULL) { if(codec->init == NULL) {
return 0; return 0;
} }
if(codec->init != NotConfigured){ if(codec->init != NotConfigured){
return 1; return 1;
} }
return 0; return 0;
} }

View File

@ -1,4 +1,4 @@
/* $Id: tif_color.c,v 1.12.2.1 2010-06-08 18:50:41 bfriesen Exp $ */ /* $Id: tif_color.c,v 1.19 2010-12-14 02:22:42 faxguy Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -123,7 +123,7 @@ TIFFXYZToRGB(TIFFCIELabToRGB *cielab, float X, float Y, float Z,
*/ */
int int
TIFFCIELabToRGBInit(TIFFCIELabToRGB* cielab, TIFFCIELabToRGBInit(TIFFCIELabToRGB* cielab,
TIFFDisplay *display, float *refWhite) const TIFFDisplay *display, float *refWhite)
{ {
int i; int i;
double gamma; double gamma;
@ -183,13 +183,18 @@ void
TIFFYCbCrtoRGB(TIFFYCbCrToRGB *ycbcr, uint32 Y, int32 Cb, int32 Cr, TIFFYCbCrtoRGB(TIFFYCbCrToRGB *ycbcr, uint32 Y, int32 Cb, int32 Cr,
uint32 *r, uint32 *g, uint32 *b) uint32 *r, uint32 *g, uint32 *b)
{ {
int32 i;
/* XXX: Only 8-bit YCbCr input supported for now */ /* XXX: Only 8-bit YCbCr input supported for now */
Y = HICLAMP(Y, 255), Cb = CLAMP(Cb, 0, 255), Cr = CLAMP(Cr, 0, 255); Y = HICLAMP(Y, 255), Cb = CLAMP(Cb, 0, 255), Cr = CLAMP(Cr, 0, 255);
*r = ycbcr->clamptab[ycbcr->Y_tab[Y] + ycbcr->Cr_r_tab[Cr]]; i = ycbcr->Y_tab[Y] + ycbcr->Cr_r_tab[Cr];
*g = ycbcr->clamptab[ycbcr->Y_tab[Y] *r = CLAMP(i, 0, 255);
+ (int)((ycbcr->Cb_g_tab[Cb] + ycbcr->Cr_g_tab[Cr]) >> SHIFT)]; i = ycbcr->Y_tab[Y]
*b = ycbcr->clamptab[ycbcr->Y_tab[Y] + ycbcr->Cb_b_tab[Cb]]; + (int)((ycbcr->Cb_g_tab[Cb] + ycbcr->Cr_g_tab[Cr]) >> SHIFT);
*g = CLAMP(i, 0, 255);
i = ycbcr->Y_tab[Y] + ycbcr->Cb_b_tab[Cb];
*b = CLAMP(i, 0, 255);
} }
/* /*
@ -219,7 +224,7 @@ TIFFYCbCrToRGBInit(TIFFYCbCrToRGB* ycbcr, float *luma, float *refBlackWhite)
#define LumaBlue luma[2] #define LumaBlue luma[2]
clamptab = (TIFFRGBValue*)( clamptab = (TIFFRGBValue*)(
(tidata_t) ycbcr+TIFFroundup(sizeof (TIFFYCbCrToRGB), sizeof (long))); (uint8*) ycbcr+TIFFroundup_32(sizeof (TIFFYCbCrToRGB), sizeof (long)));
_TIFFmemset(clamptab, 0, 256); /* v < 0 => 0 */ _TIFFmemset(clamptab, 0, 256); /* v < 0 => 0 */
ycbcr->clamptab = (clamptab += 256); ycbcr->clamptab = (clamptab += 256);
for (i = 0; i < 256; i++) for (i = 0; i < 256; i++)

View File

@ -1,4 +1,4 @@
/* $Id: tif_compress.c,v 1.13.2.1 2010-06-08 18:50:41 bfriesen Exp $ */ /* $Id: tif_compress.c,v 1.22 2010-03-10 18:56:48 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -36,11 +36,11 @@ TIFFNoEncode(TIFF* tif, const char* method)
{ {
const TIFFCodec* c = TIFFFindCODEC(tif->tif_dir.td_compression); const TIFFCodec* c = TIFFFindCODEC(tif->tif_dir.td_compression);
if (c) { if (c) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, tif->tif_name,
"%s %s encoding is not implemented", "%s %s encoding is not implemented",
c->name, method); c->name, method);
} else { } else {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, tif->tif_name,
"Compression scheme %u %s encoding is not implemented", "Compression scheme %u %s encoding is not implemented",
tif->tif_dir.td_compression, method); tif->tif_dir.td_compression, method);
@ -49,21 +49,21 @@ TIFFNoEncode(TIFF* tif, const char* method)
} }
int int
_TIFFNoRowEncode(TIFF* tif, tidata_t pp, tsize_t cc, tsample_t s) _TIFFNoRowEncode(TIFF* tif, uint8* pp, tmsize_t cc, uint16 s)
{ {
(void) pp; (void) cc; (void) s; (void) pp; (void) cc; (void) s;
return (TIFFNoEncode(tif, "scanline")); return (TIFFNoEncode(tif, "scanline"));
} }
int int
_TIFFNoStripEncode(TIFF* tif, tidata_t pp, tsize_t cc, tsample_t s) _TIFFNoStripEncode(TIFF* tif, uint8* pp, tmsize_t cc, uint16 s)
{ {
(void) pp; (void) cc; (void) s; (void) pp; (void) cc; (void) s;
return (TIFFNoEncode(tif, "strip")); return (TIFFNoEncode(tif, "strip"));
} }
int int
_TIFFNoTileEncode(TIFF* tif, tidata_t pp, tsize_t cc, tsample_t s) _TIFFNoTileEncode(TIFF* tif, uint8* pp, tmsize_t cc, uint16 s)
{ {
(void) pp; (void) cc; (void) s; (void) pp; (void) cc; (void) s;
return (TIFFNoEncode(tif, "tile")); return (TIFFNoEncode(tif, "tile"));
@ -86,21 +86,28 @@ TIFFNoDecode(TIFF* tif, const char* method)
} }
int int
_TIFFNoRowDecode(TIFF* tif, tidata_t pp, tsize_t cc, tsample_t s) _TIFFNoFixupTags(TIFF* tif)
{
(void) tif;
return (1);
}
int
_TIFFNoRowDecode(TIFF* tif, uint8* pp, tmsize_t cc, uint16 s)
{ {
(void) pp; (void) cc; (void) s; (void) pp; (void) cc; (void) s;
return (TIFFNoDecode(tif, "scanline")); return (TIFFNoDecode(tif, "scanline"));
} }
int int
_TIFFNoStripDecode(TIFF* tif, tidata_t pp, tsize_t cc, tsample_t s) _TIFFNoStripDecode(TIFF* tif, uint8* pp, tmsize_t cc, uint16 s)
{ {
(void) pp; (void) cc; (void) s; (void) pp; (void) cc; (void) s;
return (TIFFNoDecode(tif, "strip")); return (TIFFNoDecode(tif, "strip"));
} }
int int
_TIFFNoTileDecode(TIFF* tif, tidata_t pp, tsize_t cc, tsample_t s) _TIFFNoTileDecode(TIFF* tif, uint8* pp, tmsize_t cc, uint16 s)
{ {
(void) pp; (void) cc; (void) s; (void) pp; (void) cc; (void) s;
return (TIFFNoDecode(tif, "tile")); return (TIFFNoDecode(tif, "tile"));
@ -116,7 +123,7 @@ _TIFFNoSeek(TIFF* tif, uint32 off)
} }
int int
_TIFFNoPreCode(TIFF* tif, tsample_t s) _TIFFNoPreCode(TIFF* tif, uint16 s)
{ {
(void) tif; (void) s; (void) tif; (void) s;
return (1); return (1);
@ -128,19 +135,20 @@ static void _TIFFvoid(TIFF* tif) { (void) tif; }
void void
_TIFFSetDefaultCompressionState(TIFF* tif) _TIFFSetDefaultCompressionState(TIFF* tif)
{ {
tif->tif_fixuptags = _TIFFNoFixupTags;
tif->tif_decodestatus = TRUE; tif->tif_decodestatus = TRUE;
tif->tif_setupdecode = _TIFFtrue; tif->tif_setupdecode = _TIFFtrue;
tif->tif_predecode = _TIFFNoPreCode; tif->tif_predecode = _TIFFNoPreCode;
tif->tif_decoderow = _TIFFNoRowDecode; tif->tif_decoderow = _TIFFNoRowDecode;
tif->tif_decodestrip = _TIFFNoStripDecode; tif->tif_decodestrip = _TIFFNoStripDecode;
tif->tif_decodetile = _TIFFNoTileDecode; tif->tif_decodetile = _TIFFNoTileDecode;
tif->tif_encodestatus = TRUE; tif->tif_encodestatus = TRUE;
tif->tif_setupencode = _TIFFtrue; tif->tif_setupencode = _TIFFtrue;
tif->tif_preencode = _TIFFNoPreCode; tif->tif_preencode = _TIFFNoPreCode;
tif->tif_postencode = _TIFFtrue; tif->tif_postencode = _TIFFtrue;
tif->tif_encoderow = _TIFFNoRowEncode; tif->tif_encoderow = _TIFFNoRowEncode;
tif->tif_encodestrip = _TIFFNoStripEncode; tif->tif_encodestrip = _TIFFNoStripEncode;
tif->tif_encodetile = _TIFFNoTileEncode; tif->tif_encodetile = _TIFFNoTileEncode;
tif->tif_close = _TIFFvoid; tif->tif_close = _TIFFvoid;
tif->tif_seek = _TIFFNoSeek; tif->tif_seek = _TIFFNoSeek;
tif->tif_cleanup = _TIFFvoid; tif->tif_cleanup = _TIFFvoid;
@ -170,10 +178,10 @@ TIFFSetCompressionScheme(TIFF* tif, int scheme)
* by this library. * by this library.
*/ */
typedef struct _codec { typedef struct _codec {
struct _codec* next; struct _codec* next;
TIFFCodec* info; TIFFCodec* info;
} codec_t; } codec_t;
static codec_t* registeredCODECS = NULL; static codec_t* registeredCODECS = NULL;
const TIFFCodec* const TIFFCodec*
TIFFFindCODEC(uint16 scheme) TIFFFindCODEC(uint16 scheme)
@ -194,12 +202,12 @@ TIFFCodec*
TIFFRegisterCODEC(uint16 scheme, const char* name, TIFFInitMethod init) TIFFRegisterCODEC(uint16 scheme, const char* name, TIFFInitMethod init)
{ {
codec_t* cd = (codec_t*) codec_t* cd = (codec_t*)
_TIFFmalloc(sizeof (codec_t) + sizeof (TIFFCodec) + strlen(name)+1); _TIFFmalloc((tmsize_t)(sizeof (codec_t) + sizeof (TIFFCodec) + strlen(name)+1));
if (cd != NULL) { if (cd != NULL) {
cd->info = (TIFFCodec*) ((tidata_t) cd + sizeof (codec_t)); cd->info = (TIFFCodec*) ((uint8*) cd + sizeof (codec_t));
cd->info->name = (char*) cd->info->name = (char*)
((tidata_t) cd->info + sizeof (TIFFCodec)); ((uint8*) cd->info + sizeof (TIFFCodec));
strcpy(cd->info->name, name); strcpy(cd->info->name, name);
cd->info->scheme = scheme; cd->info->scheme = scheme;
cd->info->init = init; cd->info->init = init;
@ -244,13 +252,14 @@ TIFFUnRegisterCODEC(TIFFCodec* c)
TIFFCodec* TIFFCodec*
TIFFGetConfiguredCODECs() TIFFGetConfiguredCODECs()
{ {
int i = 1; int i = 1;
codec_t *cd; codec_t *cd;
const TIFFCodec *c; const TIFFCodec* c;
TIFFCodec *codecs = NULL, *new_codecs; TIFFCodec* codecs = NULL;
TIFFCodec* new_codecs;
for (cd = registeredCODECS; cd; cd = cd->next) { for (cd = registeredCODECS; cd; cd = cd->next) {
new_codecs = (TIFFCodec *) new_codecs = (TIFFCodec *)
_TIFFrealloc(codecs, i * sizeof(TIFFCodec)); _TIFFrealloc(codecs, i * sizeof(TIFFCodec));
if (!new_codecs) { if (!new_codecs) {
_TIFFfree (codecs); _TIFFfree (codecs);
@ -260,16 +269,16 @@ TIFFGetConfiguredCODECs()
_TIFFmemcpy(codecs + i - 1, cd, sizeof(TIFFCodec)); _TIFFmemcpy(codecs + i - 1, cd, sizeof(TIFFCodec));
i++; i++;
} }
for (c = _TIFFBuiltinCODECS; c->name; c++) { for (c = _TIFFBuiltinCODECS; c->name; c++) {
if (TIFFIsCODECConfigured(c->scheme)) { if (TIFFIsCODECConfigured(c->scheme)) {
new_codecs = (TIFFCodec *) new_codecs = (TIFFCodec *)
_TIFFrealloc(codecs, i * sizeof(TIFFCodec)); _TIFFrealloc(codecs, i * sizeof(TIFFCodec));
if (!new_codecs) { if (!new_codecs) {
_TIFFfree (codecs); _TIFFfree (codecs);
return NULL; return NULL;
} }
codecs = new_codecs; codecs = new_codecs;
_TIFFmemcpy(codecs + i - 1, (const tdata_t)c, sizeof(TIFFCodec)); _TIFFmemcpy(codecs + i - 1, (const void*)c, sizeof(TIFFCodec));
i++; i++;
} }
} }
@ -282,7 +291,7 @@ TIFFGetConfiguredCODECs()
codecs = new_codecs; codecs = new_codecs;
_TIFFmemset(codecs + i - 1, 0, sizeof(TIFFCodec)); _TIFFmemset(codecs + i - 1, 0, sizeof(TIFFCodec));
return codecs; return codecs;
} }
/* vim: set ts=8 sts=8 sw=8 noet: */ /* vim: set ts=8 sts=8 sw=8 noet: */

View File

@ -1,70 +0,0 @@
/* Define to 1 if you have the <assert.h> header file. */
#define HAVE_ASSERT_H 1
/* Define to 1 if you have the <fcntl.h> header file. */
#define HAVE_FCNTL_H 1
/* Define as 0 or 1 according to the floating point format suported by the
machine */
#define HAVE_IEEEFP 1
/* Define to 1 if you have the `jbg_newlen' function. */
#define HAVE_JBG_NEWLEN 1
/* Define to 1 if you have the <string.h> header file. */
#define HAVE_STRING_H 1
/* Define to 1 if you have the <sys/types.h> header file. */
#define HAVE_SYS_TYPES_H 1
/* Define to 1 if you have the <io.h> header file. */
#define HAVE_IO_H 1
/* Define to 1 if you have the <search.h> header file. */
#define HAVE_SEARCH_H 1
/* Define to 1 if you have the `setmode' function. */
#define HAVE_SETMODE 1
/* The size of a `int', as computed by sizeof. */
#define SIZEOF_INT 4
/* The size of a `long', as computed by sizeof. */
#define SIZEOF_LONG 4
#ifdef _MSC_VER
/* Signed 64-bit type */
#define TIFF_INT64_T signed __int64
/* Unsigned 64-bit type */
#define TIFF_UINT64_T unsigned __int64
#else
/* Signed 64-bit type */
#define TIFF_INT64_T long long
/* Signed 64-bit type */
#define TIFF_UINT64_T unsigned long long
#endif
/* Set the native cpu bit order */
#define HOST_FILLORDER FILLORDER_LSB2MSB
/* Define to 1 if your processor stores words with the most significant byte
first (like Motorola and SPARC, unlike Intel and VAX). */
/* #undef WORDS_BIGENDIAN */
/* Define to `__inline__' or `__inline' if that's what the C compiler
calls it, or to nothing if 'inline' is not supported under any name. */
#ifndef __cplusplus
# ifndef inline
# define inline __inline
# endif
#endif
#define lfind _lfind
/*
* Local Variables:
* mode: c
* c-basic-offset: 8
* fill-column: 78
* End:
*/

393
thirdparty/libtiff/tif_config.h.cmake.in vendored Normal file
View File

@ -0,0 +1,393 @@
/* libtiff/tif_config.h.in. Generated from configure.ac by autoheader. */
/* Define if building universal (internal helper macro) */
#cmakedefine AC_APPLE_UNIVERSAL_BUILD
/* Support CCITT Group 3 & 4 algorithms */
#cmakedefine CCITT_SUPPORT @CCITT_SUPPORT@
/* Pick up YCbCr subsampling info from the JPEG data stream to support files
lacking the tag (default enabled). */
#cmakedefine CHECK_JPEG_YCBCR_SUBSAMPLING @CHECK_JPEG_YCBCR_SUBSAMPLING@
/* enable partial strip reading for large strips (experimental) */
#cmakedefine CHUNKY_STRIP_READ_SUPPORT
/* Support C++ stream API (requires C++ compiler) */
#cmakedefine CXX_SUPPORT @CXX_SUPPORT@
/* Treat extra sample as alpha (default enabled). The RGBA interface will
treat a fourth sample with no EXTRASAMPLE_ value as being ASSOCALPHA. Many
packages produce RGBA files but don't mark the alpha properly. */
#cmakedefine DEFAULT_EXTRASAMPLE_AS_ALPHA @DEFAULT_EXTRASAMPLE_AS_ALPHA@
/* enable deferred strip/tile offset/size loading (experimental) */
#cmakedefine DEFER_STRILE_LOAD @DEFER_STRILE_LOAD@
/* Define to 1 if you have the <assert.h> header file. */
#cmakedefine HAVE_ASSERT_H @HAVE_ASSERT_H@
/* Define to 1 if you have the <dlfcn.h> header file. */
#cmakedefine HAVE_DLFCN_H @HAVE_DLFCN_H@
/* Define to 1 if you have the <fcntl.h> header file. */
#cmakedefine HAVE_FCNTL_H @HAVE_FCNTL_H@
/* Define to 1 if you have the `floor' function. */
#cmakedefine HAVE_FLOOR @HAVE_FLOOR@
/* Define to 1 if you have the `getopt' function. */
#cmakedefine HAVE_GETOPT @HAVE_GETOPT@
/* Define to 1 if you have the <GLUT/glut.h> header file. */
#cmakedefine HAVE_GLUT_GLUT_H @HAVE_GLUT_GLUT_H@
/* Define to 1 if you have the <GL/glut.h> header file. */
#cmakedefine HAVE_GL_GLUT_H @HAVE_GL_GLUT_H@
/* Define to 1 if you have the <GL/glu.h> header file. */
#cmakedefine HAVE_GL_GLU_H @HAVE_GL_GLU_H@
/* Define to 1 if you have the <GL/gl.h> header file. */
#cmakedefine HAVE_GL_GL_H @HAVE_GL_GL_H@
/* Define as 0 or 1 according to the floating point format suported by the
machine */
#define HAVE_IEEEFP 1
/* Define to 1 if the system has the type `int16'. */
#cmakedefine HAVE_INT16
/* Define to 1 if the system has the type `int32'. */
#cmakedefine HAVE_INT32
/* Define to 1 if the system has the type `int8'. */
#cmakedefine HAVE_INT8
/* Define to 1 if you have the <inttypes.h> header file. */
#cmakedefine HAVE_INTTYPES_H @HAVE_INTTYPES_H@
/* Define to 1 if you have the <io.h> header file. */
#cmakedefine HAVE_IO_H @HAVE_IO_H@
/* Define to 1 if you have the `isascii' function. */
#cmakedefine HAVE_ISASCII @HAVE_ISASCII@
/* Define to 1 if you have the `jbg_newlen' function. */
#cmakedefine HAVE_JBG_NEWLEN @HAVE_JBG_NEWLEN@
/* Define to 1 if you have the `lfind' function. */
#cmakedefine HAVE_LFIND @HAVE_LFIND@
/* Define to 1 if you have the `c' library (-lc). */
#cmakedefine HAVE_LIBC @HAVE_LIBC@
/* Define to 1 if you have the `m' library (-lm). */
#cmakedefine HAVE_LIBM @HAVE_LIBM@
/* Define to 1 if you have the <limits.h> header file. */
#cmakedefine HAVE_LIMITS_H @HAVE_LIMITS_H@
/* Define to 1 if you have the <malloc.h> header file. */
#cmakedefine HAVE_MALLOC_H @HAVE_MALLOC_H@
/* Define to 1 if you have the `memmove' function. */
#cmakedefine HAVE_MEMMOVE @HAVE_MEMMOVE@
/* Define to 1 if you have the <memory.h> header file. */
#cmakedefine HAVE_MEMORY_H @HAVE_MEMORY_H@
/* Define to 1 if you have the `memset' function. */
#cmakedefine HAVE_MEMSET @HAVE_MEMSET@
/* Define to 1 if you have the `mmap' function. */
#cmakedefine HAVE_MMAP @HAVE_MMAP@
/* Define to 1 if you have the <OpenGL/glu.h> header file. */
#cmakedefine HAVE_OPENGL_GLU_H @HAVE_OPENGL_GLU_H@
/* Define to 1 if you have the <OpenGL/gl.h> header file. */
#cmakedefine HAVE_OPENGL_GL_H @HAVE_OPENGL_GL_H@
/* Define to 1 if you have the `pow' function. */
#cmakedefine HAVE_POW @HAVE_POW@
/* Define if you have POSIX threads libraries and header files. */
#cmakedefine HAVE_PTHREAD
/* Define to 1 if you have the <search.h> header file. */
#cmakedefine HAVE_SEARCH_H @HAVE_SEARCH_H@
/* Define to 1 if you have the `setmode' function. */
#cmakedefine HAVE_SETMODE @HAVE_SETMODE@
/* Define to 1 if you have the `sqrt' function. */
#cmakedefine HAVE_SQRT @HAVE_SQRT@
/* Define to 1 if you have the <stdint.h> header file. */
#cmakedefine HAVE_STDINT_H @HAVE_STDINT_H@
/* Define to 1 if you have the <stdlib.h> header file. */
#cmakedefine HAVE_STDLIB_H @HAVE_STDLIB_H@
/* Define to 1 if you have the `strcasecmp' function. */
#cmakedefine HAVE_STRCASECMP @HAVE_STRCASECMP@
/* Define to 1 if you have the `strchr' function. */
#cmakedefine HAVE_STRCHR @HAVE_STRCHR@
/* Define to 1 if you have the <strings.h> header file. */
#cmakedefine HAVE_STRINGS_H @HAVE_STRINGS_H@
/* Define to 1 if you have the <string.h> header file. */
#cmakedefine HAVE_STRING_H @HAVE_STRING_H@
/* Define to 1 if you have the `strrchr' function. */
#cmakedefine HAVE_STRRCHR @HAVE_STRRCHR@
/* Define to 1 if you have the `strstr' function. */
#cmakedefine HAVE_STRSTR @HAVE_STRSTR@
/* Define to 1 if you have the `strtol' function. */
#cmakedefine HAVE_STRTOL @HAVE_STRTOL@
/* Define to 1 if you have the `strtoul' function. */
#cmakedefine HAVE_STRTOUL @HAVE_STRTOUL@
/* Define to 1 if you have the `strtoull' function. */
#cmakedefine HAVE_STRTOULL @HAVE_STRTOULL@
/* Define to 1 if you have the <sys/stat.h> header file. */
#cmakedefine HAVE_SYS_STAT_H @HAVE_SYS_STAT_H@
/* Define to 1 if you have the <sys/time.h> header file. */
#cmakedefine HAVE_SYS_TIME_H @HAVE_SYS_TIME_H@
/* Define to 1 if you have the <sys/types.h> header file. */
#cmakedefine HAVE_SYS_TYPES_H @HAVE_SYS_TYPES_H@
/* Define to 1 if you have the <unistd.h> header file. */
#cmakedefine HAVE_UNISTD_H @HAVE_UNISTD_H@
/* Use nonstandard varargs form for the GLU tesselator callback */
#cmakedefine HAVE_VARARGS_GLU_TESSCB
/* Define to 1 if you have the <windows.h> header file. */
#cmakedefine HAVE_WINDOWS_H @HAVE_WINDOWS_H@
/* Native cpu byte order: 1 if big-endian (Motorola) or 0 if little-endian
(Intel) */
#define HOST_BIGENDIAN @HOST_BIGENDIAN@
/* Set the native cpu bit order (FILLORDER_LSB2MSB or FILLORDER_MSB2LSB) */
#cmakedefine HOST_FILLORDER @HOST_FILLORDER@
/* Support ISO JBIG compression (requires JBIG-KIT library) */
#cmakedefine JBIG_SUPPORT
/* 8/12 bit libjpeg dual mode enabled */
#cmakedefine JPEG_DUAL_MODE_8_12
/* Support JPEG compression (requires IJG JPEG library) */
#cmakedefine JPEG_SUPPORT @JPEG_SUPPORT@
/* 12bit libjpeg primary include file with path */
#cmakedefine LIBJPEG_12_PATH
/* Support LogLuv high dynamic range encoding */
#define LOGLUV_SUPPORT 1
/* Define to the sub-directory in which libtool stores uninstalled libraries.
*/
#undef LT_OBJDIR
/* Support LZMA2 compression */
#cmakedefine LZMA_SUPPORT @LZMA_SUPPORT@
/* Support LZW algorithm */
#define LZW_SUPPORT 1
/* Support Microsoft Document Imaging format */
#cmakedefine MDI_SUPPORT @MDI_SUPPORT@
/* Support NeXT 2-bit RLE algorithm */
#define NEXT_SUPPORT 1
/* Define to 1 if your C compiler doesn't accept -c and -o together. */
#cmakedefine NO_MINUS_C_MINUS_O @NO_MINUS_C_MINUS_O@
/* Support Old JPEG compresson (read-only) */
#cmakedefine OJPEG_SUPPORT
/* Name of package */
#cmakedefine PACKAGE @PACKAGE@
/* Define to the address where bug reports for this package should be sent. */
#cmakedefine PACKAGE_BUGREPORT
/* Define to the full name of this package. */
#cmakedefine PACKAGE_NAME
/* Define to the full name and version of this package. */
#cmakedefine PACKAGE_STRING
/* Define to the one symbol short name of this package. */
#cmakedefine PACKAGE_TARNAME
/* Define to the home page for this package. */
#undef PACKAGE_URL
/* Define to the version of this package. */
#cmakedefine PACKAGE_VERSION
/* Support Macintosh PackBits algorithm */
#define PACKBITS_SUPPORT 1
/* Support Pixar log-format algorithm (requires Zlib) */
#cmakedefine PIXARLOG_SUPPORT @PIXARLOG_SUPPORT@
/* Define to necessary symbol if this constant uses a non-standard name on
your system. */
#cmakedefine PTHREAD_CREATE_JOINABLE
/* The size of `signed int', as computed by sizeof. */
#cmakedefine SIZEOF_SIGNED_INT @SIZEOF_SIGNED_INT@
/* The size of `signed long', as computed by sizeof. */
#cmakedefine SIZEOF_SIGNED_LONG @SIZEOF_SIGNED_LONG@
/* The size of `signed long long', as computed by sizeof. */
#cmakedefine SIZEOF_SIGNED_LONG_LONG @SIZEOF_SIGNED_LONG_LONG@
/* The size of `signed short', as computed by sizeof. */
#cmakedefine SIZEOF_SIGNED_SHORT @SIZEOF_SIGNED_SHORT@
/* The size of `unsigned char *', as computed by sizeof. */
#cmakedefine SIZEOF_UNSIGNED_CHAR_P @SIZEOF_UNSIGNED_CHAR_P@
/* The size of `unsigned int', as computed by sizeof. */
#cmakedefine SIZEOF_UNSIGNED_INT @SIZEOF_UNSIGNED_INT@
/* The size of `unsigned long', as computed by sizeof. */
#cmakedefine SIZEOF_UNSIGNED_LONG @SIZEOF_UNSIGNED_LONG@
/* The size of `unsigned long long', as computed by sizeof. */
#cmakedefine SIZEOF_UNSIGNED_LONG_LONG @SIZEOF_UNSIGNED_LONG_LONG@
/* The size of `unsigned short', as computed by sizeof. */
#cmakedefine SIZEOF_UNSIGNED_SHORT @SIZEOF_UNSIGNED_SHORT@
/* Define to 1 if you have the ANSI C header files. */
#cmakedefine STDC_HEADERS @STDC_HEADERS@
/* Support strip chopping (whether or not to convert single-strip uncompressed
images to mutiple strips of specified size to reduce memory usage) */
#cmakedefine STRIPCHOP_DEFAULT @STRIPCHOP_DEFAULT@
/* Default size of the strip in bytes (when strip chopping enabled) */
#cmakedefine STRIP_SIZE_DEFAULT @STRIP_SIZE_DEFAULT@
/* Enable SubIFD tag (330) support */
#cmakedefine SUBIFD_SUPPORT @SUBIFD_SUPPORT@
/* Support ThunderScan 4-bit RLE algorithm */
#cmakedefine THUNDER_SUPPORT @THUNDER_SUPPORT@
/* Signed 16-bit type */
#cmakedefine TIFF_INT16_T @TIFF_INT16_T@
/* Signed 32-bit type formatter */
#cmakedefine TIFF_INT32_FORMAT @TIFF_INT32_FORMAT@
/* Signed 32-bit type */
#cmakedefine TIFF_INT32_T @TIFF_INT32_T@
/* Signed 64-bit type formatter */
#cmakedefine TIFF_INT64_FORMAT @TIFF_INT64_FORMAT@
/* Signed 64-bit type */
#cmakedefine TIFF_INT64_T @TIFF_INT64_T@
/* Signed 8-bit type */
#cmakedefine TIFF_INT8_T @TIFF_INT8_T@
/* Pointer difference type formatter */
#cmakedefine TIFF_PTRDIFF_FORMAT @TIFF_PTRDIFF_FORMAT@
/* Pointer difference type */
#cmakedefine TIFF_PTRDIFF_T @TIFF_PTRDIFF_T@
/* Signed size type formatter */
#cmakedefine TIFF_SSIZE_FORMAT @TIFF_SSIZE_FORMAT@
/* Signed size type */
#cmakedefine TIFF_SSIZE_T @TIFF_SSIZE_T@
/* Unsigned 16-bit type */
#cmakedefine TIFF_UINT16_T @TIFF_UINT16_T@
/* Unsigned 32-bit type formatter */
#cmakedefine TIFF_UINT32_FORMAT @TIFF_UINT32_FORMAT@
/* Unsigned 32-bit type */
#cmakedefine TIFF_UINT32_T @TIFF_UINT32_T@
/* Unsigned 64-bit type formatter */
#cmakedefine TIFF_UINT64_FORMAT @TIFF_UINT64_FORMAT@
/* Unsigned 64-bit type */
#cmakedefine TIFF_UINT64_T @TIFF_UINT64_T@
/* Unsigned 8-bit type */
#cmakedefine TIFF_UINT8_T @TIFF_UINT8_T@
/* Define to 1 if you can safely include both <sys/time.h> and <time.h>. */
#cmakedefine TIME_WITH_SYS_TIME @TIME_WITH_SYS_TIME@
/* Define to 1 if your <sys/time.h> declares `struct tm'. */
#cmakedefine TM_IN_SYS_TIME
/* define to use win32 IO system */
#cmakedefine USE_WIN32_FILEIO
/* Version number of package */
#cmakedefine VERSION @VERSION@
/* Define WORDS_BIGENDIAN to 1 if your processor stores words with the most
significant byte first (like Motorola and SPARC, unlike Intel). */
#if defined AC_APPLE_UNIVERSAL_BUILD
# if defined __BIG_ENDIAN__
# define WORDS_BIGENDIAN 1
# endif
#else
# ifndef WORDS_BIGENDIAN
#cmakedefine WORDS_BIGENDIAN
# endif
#endif
/* Define to 1 if the X Window System is missing or not being used. */
#cmakedefine X_DISPLAY_MISSING
/* Support Deflate compression */
#cmakedefine ZIP_SUPPORT @ZIP_SUPPORT@
/* Number of bits in a file offset, on hosts where this is settable. */
#cmakedefine _FILE_OFFSET_BITS
/* Define for large files, on AIX-style hosts. */
#cmakedefine _LARGE_FILES
/* Define to empty if `const' does not conform to ANSI C. */
#cmakedefine const
/* Define to `__inline__' or `__inline' if that's what the C compiler
calls it, or to nothing if 'inline' is not supported under any name. */
#ifndef __cplusplus
#cmakedefine inline
#endif
/* Define to `long int' if <sys/types.h> does not define. */
#cmakedefine off_t
/* Define to `unsigned int' if <sys/types.h> does not define. */
#cmakedefine size_t

393
thirdparty/libtiff/tif_config.h.in vendored Normal file
View File

@ -0,0 +1,393 @@
/* libtiff/tif_config.h.in. Generated from configure.ac by autoheader. */
/* Define if building universal (internal helper macro) */
#undef AC_APPLE_UNIVERSAL_BUILD
/* Support CCITT Group 3 & 4 algorithms */
#undef CCITT_SUPPORT
/* Pick up YCbCr subsampling info from the JPEG data stream to support files
lacking the tag (default enabled). */
#undef CHECK_JPEG_YCBCR_SUBSAMPLING
/* enable partial strip reading for large strips (experimental) */
#undef CHUNKY_STRIP_READ_SUPPORT
/* Support C++ stream API (requires C++ compiler) */
#undef CXX_SUPPORT
/* Treat extra sample as alpha (default enabled). The RGBA interface will
treat a fourth sample with no EXTRASAMPLE_ value as being ASSOCALPHA. Many
packages produce RGBA files but don't mark the alpha properly. */
#undef DEFAULT_EXTRASAMPLE_AS_ALPHA
/* enable deferred strip/tile offset/size loading (experimental) */
#undef DEFER_STRILE_LOAD
/* Define to 1 if you have the <assert.h> header file. */
#undef HAVE_ASSERT_H
/* Define to 1 if you have the <dlfcn.h> header file. */
#undef HAVE_DLFCN_H
/* Define to 1 if you have the <fcntl.h> header file. */
#undef HAVE_FCNTL_H
/* Define to 1 if you have the `floor' function. */
#undef HAVE_FLOOR
/* Define to 1 if you have the `getopt' function. */
#undef HAVE_GETOPT
/* Define to 1 if you have the <GLUT/glut.h> header file. */
#undef HAVE_GLUT_GLUT_H
/* Define to 1 if you have the <GL/glut.h> header file. */
#undef HAVE_GL_GLUT_H
/* Define to 1 if you have the <GL/glu.h> header file. */
#undef HAVE_GL_GLU_H
/* Define to 1 if you have the <GL/gl.h> header file. */
#undef HAVE_GL_GL_H
/* Define as 0 or 1 according to the floating point format suported by the
machine */
#undef HAVE_IEEEFP
/* Define to 1 if the system has the type `int16'. */
#undef HAVE_INT16
/* Define to 1 if the system has the type `int32'. */
#undef HAVE_INT32
/* Define to 1 if the system has the type `int8'. */
#undef HAVE_INT8
/* Define to 1 if you have the <inttypes.h> header file. */
#undef HAVE_INTTYPES_H
/* Define to 1 if you have the <io.h> header file. */
#undef HAVE_IO_H
/* Define to 1 if you have the `isascii' function. */
#undef HAVE_ISASCII
/* Define to 1 if you have the `jbg_newlen' function. */
#undef HAVE_JBG_NEWLEN
/* Define to 1 if you have the `lfind' function. */
#undef HAVE_LFIND
/* Define to 1 if you have the `c' library (-lc). */
#undef HAVE_LIBC
/* Define to 1 if you have the `m' library (-lm). */
#undef HAVE_LIBM
/* Define to 1 if you have the <limits.h> header file. */
#undef HAVE_LIMITS_H
/* Define to 1 if you have the <malloc.h> header file. */
#undef HAVE_MALLOC_H
/* Define to 1 if you have the `memmove' function. */
#undef HAVE_MEMMOVE
/* Define to 1 if you have the <memory.h> header file. */
#undef HAVE_MEMORY_H
/* Define to 1 if you have the `memset' function. */
#undef HAVE_MEMSET
/* Define to 1 if you have the `mmap' function. */
#undef HAVE_MMAP
/* Define to 1 if you have the <OpenGL/glu.h> header file. */
#undef HAVE_OPENGL_GLU_H
/* Define to 1 if you have the <OpenGL/gl.h> header file. */
#undef HAVE_OPENGL_GL_H
/* Define to 1 if you have the `pow' function. */
#undef HAVE_POW
/* Define if you have POSIX threads libraries and header files. */
#undef HAVE_PTHREAD
/* Define to 1 if you have the <search.h> header file. */
#undef HAVE_SEARCH_H
/* Define to 1 if you have the `setmode' function. */
#undef HAVE_SETMODE
/* Define to 1 if you have the `sqrt' function. */
#undef HAVE_SQRT
/* Define to 1 if you have the <stdint.h> header file. */
#undef HAVE_STDINT_H
/* Define to 1 if you have the <stdlib.h> header file. */
#undef HAVE_STDLIB_H
/* Define to 1 if you have the `strcasecmp' function. */
#undef HAVE_STRCASECMP
/* Define to 1 if you have the `strchr' function. */
#undef HAVE_STRCHR
/* Define to 1 if you have the <strings.h> header file. */
#undef HAVE_STRINGS_H
/* Define to 1 if you have the <string.h> header file. */
#undef HAVE_STRING_H
/* Define to 1 if you have the `strrchr' function. */
#undef HAVE_STRRCHR
/* Define to 1 if you have the `strstr' function. */
#undef HAVE_STRSTR
/* Define to 1 if you have the `strtol' function. */
#undef HAVE_STRTOL
/* Define to 1 if you have the `strtoul' function. */
#undef HAVE_STRTOUL
/* Define to 1 if you have the `strtoull' function. */
#undef HAVE_STRTOULL
/* Define to 1 if you have the <sys/stat.h> header file. */
#undef HAVE_SYS_STAT_H
/* Define to 1 if you have the <sys/time.h> header file. */
#undef HAVE_SYS_TIME_H
/* Define to 1 if you have the <sys/types.h> header file. */
#undef HAVE_SYS_TYPES_H
/* Define to 1 if you have the <unistd.h> header file. */
#undef HAVE_UNISTD_H
/* Use nonstandard varargs form for the GLU tesselator callback */
#undef HAVE_VARARGS_GLU_TESSCB
/* Define to 1 if you have the <windows.h> header file. */
#undef HAVE_WINDOWS_H
/* Native cpu byte order: 1 if big-endian (Motorola) or 0 if little-endian
(Intel) */
#undef HOST_BIGENDIAN
/* Set the native cpu bit order (FILLORDER_LSB2MSB or FILLORDER_MSB2LSB) */
#undef HOST_FILLORDER
/* Support ISO JBIG compression (requires JBIG-KIT library) */
#undef JBIG_SUPPORT
/* 8/12 bit libjpeg dual mode enabled */
#undef JPEG_DUAL_MODE_8_12
/* Support JPEG compression (requires IJG JPEG library) */
#undef JPEG_SUPPORT
/* 12bit libjpeg primary include file with path */
#undef LIBJPEG_12_PATH
/* Support LogLuv high dynamic range encoding */
#undef LOGLUV_SUPPORT
/* Define to the sub-directory in which libtool stores uninstalled libraries.
*/
#undef LT_OBJDIR
/* Support LZMA2 compression */
#undef LZMA_SUPPORT
/* Support LZW algorithm */
#undef LZW_SUPPORT
/* Support Microsoft Document Imaging format */
#undef MDI_SUPPORT
/* Support NeXT 2-bit RLE algorithm */
#undef NEXT_SUPPORT
/* Define to 1 if your C compiler doesn't accept -c and -o together. */
#undef NO_MINUS_C_MINUS_O
/* Support Old JPEG compresson (read-only) */
#undef OJPEG_SUPPORT
/* Name of package */
#undef PACKAGE
/* Define to the address where bug reports for this package should be sent. */
#undef PACKAGE_BUGREPORT
/* Define to the full name of this package. */
#undef PACKAGE_NAME
/* Define to the full name and version of this package. */
#undef PACKAGE_STRING
/* Define to the one symbol short name of this package. */
#undef PACKAGE_TARNAME
/* Define to the home page for this package. */
#undef PACKAGE_URL
/* Define to the version of this package. */
#undef PACKAGE_VERSION
/* Support Macintosh PackBits algorithm */
#undef PACKBITS_SUPPORT
/* Support Pixar log-format algorithm (requires Zlib) */
#undef PIXARLOG_SUPPORT
/* Define to necessary symbol if this constant uses a non-standard name on
your system. */
#undef PTHREAD_CREATE_JOINABLE
/* The size of `signed int', as computed by sizeof. */
#undef SIZEOF_SIGNED_INT
/* The size of `signed long', as computed by sizeof. */
#undef SIZEOF_SIGNED_LONG
/* The size of `signed long long', as computed by sizeof. */
#undef SIZEOF_SIGNED_LONG_LONG
/* The size of `signed short', as computed by sizeof. */
#undef SIZEOF_SIGNED_SHORT
/* The size of `unsigned char *', as computed by sizeof. */
#undef SIZEOF_UNSIGNED_CHAR_P
/* The size of `unsigned int', as computed by sizeof. */
#undef SIZEOF_UNSIGNED_INT
/* The size of `unsigned long', as computed by sizeof. */
#undef SIZEOF_UNSIGNED_LONG
/* The size of `unsigned long long', as computed by sizeof. */
#undef SIZEOF_UNSIGNED_LONG_LONG
/* The size of `unsigned short', as computed by sizeof. */
#undef SIZEOF_UNSIGNED_SHORT
/* Define to 1 if you have the ANSI C header files. */
#undef STDC_HEADERS
/* Support strip chopping (whether or not to convert single-strip uncompressed
images to mutiple strips of specified size to reduce memory usage) */
#undef STRIPCHOP_DEFAULT
/* Default size of the strip in bytes (when strip chopping enabled) */
#undef STRIP_SIZE_DEFAULT
/* Enable SubIFD tag (330) support */
#undef SUBIFD_SUPPORT
/* Support ThunderScan 4-bit RLE algorithm */
#undef THUNDER_SUPPORT
/* Signed 16-bit type */
#undef TIFF_INT16_T
/* Signed 32-bit type formatter */
#undef TIFF_INT32_FORMAT
/* Signed 32-bit type */
#undef TIFF_INT32_T
/* Signed 64-bit type formatter */
#undef TIFF_INT64_FORMAT
/* Signed 64-bit type */
#undef TIFF_INT64_T
/* Signed 8-bit type */
#undef TIFF_INT8_T
/* Pointer difference type formatter */
#undef TIFF_PTRDIFF_FORMAT
/* Pointer difference type */
#undef TIFF_PTRDIFF_T
/* Signed size type formatter */
#undef TIFF_SSIZE_FORMAT
/* Signed size type */
#undef TIFF_SSIZE_T
/* Unsigned 16-bit type */
#undef TIFF_UINT16_T
/* Unsigned 32-bit type formatter */
#undef TIFF_UINT32_FORMAT
/* Unsigned 32-bit type */
#undef TIFF_UINT32_T
/* Unsigned 64-bit type formatter */
#undef TIFF_UINT64_FORMAT
/* Unsigned 64-bit type */
#undef TIFF_UINT64_T
/* Unsigned 8-bit type */
#undef TIFF_UINT8_T
/* Define to 1 if you can safely include both <sys/time.h> and <time.h>. */
#undef TIME_WITH_SYS_TIME
/* Define to 1 if your <sys/time.h> declares `struct tm'. */
#undef TM_IN_SYS_TIME
/* define to use win32 IO system */
#undef USE_WIN32_FILEIO
/* Version number of package */
#undef VERSION
/* Define WORDS_BIGENDIAN to 1 if your processor stores words with the most
significant byte first (like Motorola and SPARC, unlike Intel). */
#if defined AC_APPLE_UNIVERSAL_BUILD
# if defined __BIG_ENDIAN__
# define WORDS_BIGENDIAN 1
# endif
#else
# ifndef WORDS_BIGENDIAN
# undef WORDS_BIGENDIAN
# endif
#endif
/* Define to 1 if the X Window System is missing or not being used. */
#undef X_DISPLAY_MISSING
/* Support Deflate compression */
#undef ZIP_SUPPORT
/* Number of bits in a file offset, on hosts where this is settable. */
#undef _FILE_OFFSET_BITS
/* Define for large files, on AIX-style hosts. */
#undef _LARGE_FILES
/* Define to empty if `const' does not conform to ANSI C. */
#undef const
/* Define to `__inline__' or `__inline' if that's what the C compiler
calls it, or to nothing if 'inline' is not supported under any name. */
#ifndef __cplusplus
#undef inline
#endif
/* Define to `long int' if <sys/types.h> does not define. */
#undef off_t
/* Define to `unsigned int' if <sys/types.h> does not define. */
#undef size_t

File diff suppressed because it is too large Load Diff

View File

@ -1,4 +1,4 @@
/* $Id: tif_dir.h,v 1.30.2.3 2010-06-09 21:15:27 bfriesen Exp $ */ /* $Id: tif_dir.h,v 1.54 2011-02-18 20:53:05 fwarmerdam Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -30,13 +30,41 @@
* ``Library-private'' Directory-related Definitions. * ``Library-private'' Directory-related Definitions.
*/ */
typedef struct {
const TIFFField *info;
int count;
void *value;
} TIFFTagValue;
/*
* TIFF Image File Directories are comprised of a table of field
* descriptors of the form shown below. The table is sorted in
* ascending order by tag. The values associated with each entry are
* disjoint and may appear anywhere in the file (so long as they are
* placed on a word boundary).
*
* If the value is 4 bytes or less, in ClassicTIFF, or 8 bytes or less in
* BigTIFF, then it is placed in the offset field to save space. If so,
* it is left-justified in the offset field.
*/
typedef struct {
uint16 tdir_tag; /* see below */
uint16 tdir_type; /* data type; see below */
uint64 tdir_count; /* number of items; length in spec */
union {
uint16 toff_short;
uint32 toff_long;
uint64 toff_long8;
} tdir_offset; /* either offset or the data itself if fits */
} TIFFDirEntry;
/* /*
* Internal format of a TIFF directory entry. * Internal format of a TIFF directory entry.
*/ */
typedef struct { typedef struct {
#define FIELD_SETLONGS 4 #define FIELD_SETLONGS 4
/* bit vector of fields that are set */ /* bit vector of fields that are set */
unsigned long td_fieldsset[FIELD_SETLONGS]; unsigned long td_fieldsset[FIELD_SETLONGS];
uint32 td_imagewidth, td_imagelength, td_imagedepth; uint32 td_imagewidth, td_imagelength, td_imagedepth;
uint32 td_tilewidth, td_tilelength, td_tiledepth; uint32 td_tilewidth, td_tilelength, td_tiledepth;
@ -51,7 +79,8 @@ typedef struct {
uint16 td_samplesperpixel; uint16 td_samplesperpixel;
uint32 td_rowsperstrip; uint32 td_rowsperstrip;
uint16 td_minsamplevalue, td_maxsamplevalue; uint16 td_minsamplevalue, td_maxsamplevalue;
double td_sminsamplevalue, td_smaxsamplevalue; double* td_sminsamplevalue;
double* td_smaxsamplevalue;
float td_xresolution, td_yresolution; float td_xresolution, td_yresolution;
uint16 td_resolutionunit; uint16 td_resolutionunit;
uint16 td_planarconfig; uint16 td_planarconfig;
@ -64,19 +93,23 @@ typedef struct {
/* even though the name is misleading, td_stripsperimage is the number /* even though the name is misleading, td_stripsperimage is the number
* of striles (=strips or tiles) per plane, and td_nstrips the total * of striles (=strips or tiles) per plane, and td_nstrips the total
* number of striles */ * number of striles */
tstrile_t td_stripsperimage; uint32 td_stripsperimage;
tstrile_t td_nstrips; /* size of offset & bytecount arrays */ uint32 td_nstrips; /* size of offset & bytecount arrays */
toff_t* td_stripoffset; uint64* td_stripoffset;
toff_t* td_stripbytecount; /* FIXME: it should be tsize_t array */ uint64* td_stripbytecount;
int td_stripbytecountsorted; /* is the bytecount array sorted ascending? */ int td_stripbytecountsorted; /* is the bytecount array sorted ascending? */
#if defined(DEFER_STRILE_LOAD)
TIFFDirEntry td_stripoffset_entry; /* for deferred loading */
TIFFDirEntry td_stripbytecount_entry; /* for deferred loading */
#endif
uint16 td_nsubifd; uint16 td_nsubifd;
uint32* td_subifd; uint64* td_subifd;
/* YCbCr parameters */ /* YCbCr parameters */
uint16 td_ycbcrsubsampling[2]; uint16 td_ycbcrsubsampling[2];
uint16 td_ycbcrpositioning; uint16 td_ycbcrpositioning;
/* Colorimetry parameters */ /* Colorimetry parameters */
float* td_refblackwhite;
uint16* td_transferfunction[3]; uint16* td_transferfunction[3];
float* td_refblackwhite;
/* CMYK parameters */ /* CMYK parameters */
int td_inknameslen; int td_inknameslen;
char* td_inknames; char* td_inknames;
@ -86,115 +119,178 @@ typedef struct {
} TIFFDirectory; } TIFFDirectory;
/* /*
* Field flags used to indicate fields that have * Field flags used to indicate fields that have been set in a directory, and
* been set in a directory, and to reference fields * to reference fields when manipulating a directory.
* when manipulating a directory.
*/ */
/* /*
* FIELD_IGNORE is used to signify tags that are to * FIELD_IGNORE is used to signify tags that are to be processed but otherwise
* be processed but otherwise ignored. This permits * ignored. This permits antiquated tags to be quietly read and discarded.
* antiquated tags to be quietly read and discarded. * Note that a bit *is* allocated for ignored tags; this is understood by the
* Note that a bit *is* allocated for ignored tags; * directory reading logic which uses this fact to avoid special-case handling
* this is understood by the directory reading logic */
* which uses this fact to avoid special-case handling #define FIELD_IGNORE 0
*/
#define FIELD_IGNORE 0
/* multi-item fields */ /* multi-item fields */
#define FIELD_IMAGEDIMENSIONS 1 #define FIELD_IMAGEDIMENSIONS 1
#define FIELD_TILEDIMENSIONS 2 #define FIELD_TILEDIMENSIONS 2
#define FIELD_RESOLUTION 3 #define FIELD_RESOLUTION 3
#define FIELD_POSITION 4 #define FIELD_POSITION 4
/* single-item fields */ /* single-item fields */
#define FIELD_SUBFILETYPE 5 #define FIELD_SUBFILETYPE 5
#define FIELD_BITSPERSAMPLE 6 #define FIELD_BITSPERSAMPLE 6
#define FIELD_COMPRESSION 7 #define FIELD_COMPRESSION 7
#define FIELD_PHOTOMETRIC 8 #define FIELD_PHOTOMETRIC 8
#define FIELD_THRESHHOLDING 9 #define FIELD_THRESHHOLDING 9
#define FIELD_FILLORDER 10 #define FIELD_FILLORDER 10
#define FIELD_ORIENTATION 15 #define FIELD_ORIENTATION 15
#define FIELD_SAMPLESPERPIXEL 16 #define FIELD_SAMPLESPERPIXEL 16
#define FIELD_ROWSPERSTRIP 17 #define FIELD_ROWSPERSTRIP 17
#define FIELD_MINSAMPLEVALUE 18 #define FIELD_MINSAMPLEVALUE 18
#define FIELD_MAXSAMPLEVALUE 19 #define FIELD_MAXSAMPLEVALUE 19
#define FIELD_PLANARCONFIG 20 #define FIELD_PLANARCONFIG 20
#define FIELD_RESOLUTIONUNIT 22 #define FIELD_RESOLUTIONUNIT 22
#define FIELD_PAGENUMBER 23 #define FIELD_PAGENUMBER 23
#define FIELD_STRIPBYTECOUNTS 24 #define FIELD_STRIPBYTECOUNTS 24
#define FIELD_STRIPOFFSETS 25 #define FIELD_STRIPOFFSETS 25
#define FIELD_COLORMAP 26 #define FIELD_COLORMAP 26
#define FIELD_EXTRASAMPLES 31 #define FIELD_EXTRASAMPLES 31
#define FIELD_SAMPLEFORMAT 32 #define FIELD_SAMPLEFORMAT 32
#define FIELD_SMINSAMPLEVALUE 33 #define FIELD_SMINSAMPLEVALUE 33
#define FIELD_SMAXSAMPLEVALUE 34 #define FIELD_SMAXSAMPLEVALUE 34
#define FIELD_IMAGEDEPTH 35 #define FIELD_IMAGEDEPTH 35
#define FIELD_TILEDEPTH 36 #define FIELD_TILEDEPTH 36
#define FIELD_HALFTONEHINTS 37 #define FIELD_HALFTONEHINTS 37
#define FIELD_YCBCRSUBSAMPLING 39 #define FIELD_YCBCRSUBSAMPLING 39
#define FIELD_YCBCRPOSITIONING 40 #define FIELD_YCBCRPOSITIONING 40
#define FIELD_REFBLACKWHITE 41 #define FIELD_REFBLACKWHITE 41
#define FIELD_TRANSFERFUNCTION 44 #define FIELD_TRANSFERFUNCTION 44
#define FIELD_INKNAMES 46 #define FIELD_INKNAMES 46
#define FIELD_SUBIFD 49 #define FIELD_SUBIFD 49
/* FIELD_CUSTOM (see tiffio.h) 65 */ /* FIELD_CUSTOM (see tiffio.h) 65 */
/* end of support for well-known tags; codec-private tags follow */ /* end of support for well-known tags; codec-private tags follow */
#define FIELD_CODEC 66 /* base of codec-private tags */ #define FIELD_CODEC 66 /* base of codec-private tags */
/* /*
* Pseudo-tags don't normally need field bits since they * Pseudo-tags don't normally need field bits since they are not written to an
* are not written to an output file (by definition). * output file (by definition). The library also has express logic to always
* The library also has express logic to always query a * query a codec for a pseudo-tag so allocating a field bit for one is a
* codec for a pseudo-tag so allocating a field bit for * waste. If codec wants to promote the notion of a pseudo-tag being ``set''
* one is a waste. If codec wants to promote the notion * or ``unset'' then it can do using internal state flags without polluting
* of a pseudo-tag being ``set'' or ``unset'' then it can * the field bit space defined for real tags.
* do using internal state flags without polluting the
* field bit space defined for real tags.
*/ */
#define FIELD_PSEUDO 0 #define FIELD_PSEUDO 0
#define FIELD_LAST (32*FIELD_SETLONGS-1) #define FIELD_LAST (32*FIELD_SETLONGS-1)
#define TIFFExtractData(tif, type, v) \ #define BITn(n) (((unsigned long)1L)<<((n)&0x1f))
((uint32) ((tif)->tif_header.tiff_magic == TIFF_BIGENDIAN ? \ #define BITFIELDn(tif, n) ((tif)->tif_dir.td_fieldsset[(n)/32])
((v) >> (tif)->tif_typeshift[type]) & (tif)->tif_typemask[type] : \ #define TIFFFieldSet(tif, field) (BITFIELDn(tif, field) & BITn(field))
(v) & (tif)->tif_typemask[type]))
#define TIFFInsertData(tif, type, v) \
((uint32) ((tif)->tif_header.tiff_magic == TIFF_BIGENDIAN ? \
((v) & (tif)->tif_typemask[type]) << (tif)->tif_typeshift[type] : \
(v) & (tif)->tif_typemask[type]))
#define BITn(n) (((unsigned long)1L)<<((n)&0x1f))
#define BITFIELDn(tif, n) ((tif)->tif_dir.td_fieldsset[(n)/32])
#define TIFFFieldSet(tif, field) (BITFIELDn(tif, field) & BITn(field))
#define TIFFSetFieldBit(tif, field) (BITFIELDn(tif, field) |= BITn(field)) #define TIFFSetFieldBit(tif, field) (BITFIELDn(tif, field) |= BITn(field))
#define TIFFClrFieldBit(tif, field) (BITFIELDn(tif, field) &= ~BITn(field)) #define TIFFClrFieldBit(tif, field) (BITFIELDn(tif, field) &= ~BITn(field))
#define FieldSet(fields, f) (fields[(f)/32] & BITn(f)) #define FieldSet(fields, f) (fields[(f)/32] & BITn(f))
#define ResetFieldBit(fields, f) (fields[(f)/32] &= ~BITn(f)) #define ResetFieldBit(fields, f) (fields[(f)/32] &= ~BITn(f))
typedef enum {
TIFF_SETGET_UNDEFINED = 0,
TIFF_SETGET_ASCII = 1,
TIFF_SETGET_UINT8 = 2,
TIFF_SETGET_SINT8 = 3,
TIFF_SETGET_UINT16 = 4,
TIFF_SETGET_SINT16 = 5,
TIFF_SETGET_UINT32 = 6,
TIFF_SETGET_SINT32 = 7,
TIFF_SETGET_UINT64 = 8,
TIFF_SETGET_SINT64 = 9,
TIFF_SETGET_FLOAT = 10,
TIFF_SETGET_DOUBLE = 11,
TIFF_SETGET_IFD8 = 12,
TIFF_SETGET_INT = 13,
TIFF_SETGET_UINT16_PAIR = 14,
TIFF_SETGET_C0_ASCII = 15,
TIFF_SETGET_C0_UINT8 = 16,
TIFF_SETGET_C0_SINT8 = 17,
TIFF_SETGET_C0_UINT16 = 18,
TIFF_SETGET_C0_SINT16 = 19,
TIFF_SETGET_C0_UINT32 = 20,
TIFF_SETGET_C0_SINT32 = 21,
TIFF_SETGET_C0_UINT64 = 22,
TIFF_SETGET_C0_SINT64 = 23,
TIFF_SETGET_C0_FLOAT = 24,
TIFF_SETGET_C0_DOUBLE = 25,
TIFF_SETGET_C0_IFD8 = 26,
TIFF_SETGET_C16_ASCII = 27,
TIFF_SETGET_C16_UINT8 = 28,
TIFF_SETGET_C16_SINT8 = 29,
TIFF_SETGET_C16_UINT16 = 30,
TIFF_SETGET_C16_SINT16 = 31,
TIFF_SETGET_C16_UINT32 = 32,
TIFF_SETGET_C16_SINT32 = 33,
TIFF_SETGET_C16_UINT64 = 34,
TIFF_SETGET_C16_SINT64 = 35,
TIFF_SETGET_C16_FLOAT = 36,
TIFF_SETGET_C16_DOUBLE = 37,
TIFF_SETGET_C16_IFD8 = 38,
TIFF_SETGET_C32_ASCII = 39,
TIFF_SETGET_C32_UINT8 = 40,
TIFF_SETGET_C32_SINT8 = 41,
TIFF_SETGET_C32_UINT16 = 42,
TIFF_SETGET_C32_SINT16 = 43,
TIFF_SETGET_C32_UINT32 = 44,
TIFF_SETGET_C32_SINT32 = 45,
TIFF_SETGET_C32_UINT64 = 46,
TIFF_SETGET_C32_SINT64 = 47,
TIFF_SETGET_C32_FLOAT = 48,
TIFF_SETGET_C32_DOUBLE = 49,
TIFF_SETGET_C32_IFD8 = 50,
TIFF_SETGET_OTHER = 51
} TIFFSetGetFieldType;
#if defined(__cplusplus) #if defined(__cplusplus)
extern "C" { extern "C" {
#endif #endif
extern const TIFFFieldInfo *_TIFFGetFieldInfo(size_t *);
extern const TIFFFieldInfo *_TIFFGetExifFieldInfo(size_t *);
extern void _TIFFSetupFieldInfo(TIFF*, const TIFFFieldInfo[], size_t);
extern int _TIFFMergeFieldInfo(TIFF*, const TIFFFieldInfo[], int);
extern void _TIFFPrintFieldInfo(TIFF*, FILE*);
extern TIFFDataType _TIFFSampleToTagType(TIFF*);
extern const TIFFFieldInfo* _TIFFFindOrRegisterFieldInfo( TIFF *tif,
ttag_t tag,
TIFFDataType dt );
extern TIFFFieldInfo* _TIFFCreateAnonFieldInfo( TIFF *tif, ttag_t tag,
TIFFDataType dt );
#define _TIFFFindFieldInfo TIFFFindFieldInfo extern const TIFFFieldArray* _TIFFGetFields(void);
#define _TIFFFindFieldInfoByName TIFFFindFieldInfoByName extern const TIFFFieldArray* _TIFFGetExifFields(void);
#define _TIFFFieldWithTag TIFFFieldWithTag extern void _TIFFSetupFields(TIFF* tif, const TIFFFieldArray* infoarray);
#define _TIFFFieldWithName TIFFFieldWithName extern void _TIFFPrintFieldInfo(TIFF*, FILE*);
extern int _TIFFFillStriles(TIFF*);
typedef enum {
tfiatImage,
tfiatExif,
tfiatOther
} TIFFFieldArrayType;
struct _TIFFFieldArray {
TIFFFieldArrayType type; /* array type, will be used to determine if IFD is image and such */
uint32 allocated_size; /* 0 if array is constant, other if modified by future definition extension support */
uint32 count; /* number of elements in fields array */
TIFFField* fields; /* actual field info */
};
struct _TIFFField {
uint32 field_tag; /* field's tag */
short field_readcount; /* read count/TIFF_VARIABLE/TIFF_SPP */
short field_writecount; /* write count/TIFF_VARIABLE */
TIFFDataType field_type; /* type of associated data */
uint32 reserved; /* reserved for future extension */
TIFFSetGetFieldType set_field_type; /* type to be passed to TIFFSetField */
TIFFSetGetFieldType get_field_type; /* type to be passed to TIFFGetField */
unsigned short field_bit; /* bit in fieldsset bit vector */
unsigned char field_oktochange; /* if true, can change while writing */
unsigned char field_passcount; /* if true, pass dir count on set */
char* field_name; /* ASCII name */
TIFFFieldArray* field_subfields; /* if field points to child ifds, child ifd field definition array */
};
extern int _TIFFMergeFields(TIFF*, const TIFFField[], uint32);
extern const TIFFField* _TIFFFindOrRegisterField(TIFF *, uint32, TIFFDataType);
extern TIFFField* _TIFFCreateAnonField(TIFF *, uint32, TIFFDataType);
#if defined(__cplusplus) #if defined(__cplusplus)
} }
@ -202,6 +298,7 @@ extern TIFFFieldInfo* _TIFFCreateAnonFieldInfo( TIFF *tif, ttag_t tag,
#endif /* _TIFFDIR_ */ #endif /* _TIFFDIR_ */
/* vim: set ts=8 sts=8 sw=8 noet: */ /* vim: set ts=8 sts=8 sw=8 noet: */
/* /*
* Local Variables: * Local Variables:
* mode: c * mode: c

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -1,4 +1,4 @@
/* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/tif_dumpmode.c,v 1.5.2.2 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/tif_dumpmode.c,v 1.14 2011-04-02 20:54:09 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -31,22 +31,29 @@
*/ */
#include "tiffiop.h" #include "tiffiop.h"
static int
DumpFixupTags(TIFF* tif)
{
(void) tif;
return (1);
}
/* /*
* Encode a hunk of pixels. * Encode a hunk of pixels.
*/ */
static int static int
DumpModeEncode(TIFF* tif, tidata_t pp, tsize_t cc, tsample_t s) DumpModeEncode(TIFF* tif, uint8* pp, tmsize_t cc, uint16 s)
{ {
(void) s; (void) s;
while (cc > 0) { while (cc > 0) {
tsize_t n; tmsize_t n;
n = cc; n = cc;
if (tif->tif_rawcc + n > tif->tif_rawdatasize) if (tif->tif_rawcc + n > tif->tif_rawdatasize)
n = tif->tif_rawdatasize - tif->tif_rawcc; n = tif->tif_rawdatasize - tif->tif_rawcc;
assert( n > 0 ); assert( n > 0 );
/* /*
* Avoid copy if client has setup raw * Avoid copy if client has setup raw
* data buffer to avoid extra copy. * data buffer to avoid extra copy.
@ -68,15 +75,24 @@ DumpModeEncode(TIFF* tif, tidata_t pp, tsize_t cc, tsample_t s)
* Decode a hunk of pixels. * Decode a hunk of pixels.
*/ */
static int static int
DumpModeDecode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s) DumpModeDecode(TIFF* tif, uint8* buf, tmsize_t cc, uint16 s)
{ {
static const char module[] = "DumpModeDecode";
(void) s; (void) s;
/* fprintf(stderr,"DumpModeDecode: scanline %ld, expected %ld bytes, got %ld bytes\n", */
/* (long) tif->tif_row, (long) tif->tif_rawcc, (long) cc); */
if (tif->tif_rawcc < cc) { if (tif->tif_rawcc < cc) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
"DumpModeDecode: Not enough data for scanline %d", TIFFErrorExt(tif->tif_clientdata, module,
tif->tif_row); "Not enough data for scanline %lu, expected a request for at most %I64d bytes, got a request for %I64d bytes",
(unsigned long) tif->tif_row,
(signed __int64) tif->tif_rawcc,
(signed __int64) cc);
#else
TIFFErrorExt(tif->tif_clientdata, module,
"Not enough data for scanline %lu, expected a request for at most %lld bytes, got a request for %lld bytes",
(unsigned long) tif->tif_row,
(signed long long) tif->tif_rawcc,
(signed long long) cc);
#endif
return (0); return (0);
} }
/* /*
@ -86,7 +102,7 @@ DumpModeDecode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s)
if (tif->tif_rawcp != buf) if (tif->tif_rawcp != buf)
_TIFFmemcpy(buf, tif->tif_rawcp, cc); _TIFFmemcpy(buf, tif->tif_rawcp, cc);
tif->tif_rawcp += cc; tif->tif_rawcp += cc;
tif->tif_rawcc -= cc; tif->tif_rawcc -= cc;
return (1); return (1);
} }
@ -108,12 +124,13 @@ int
TIFFInitDumpMode(TIFF* tif, int scheme) TIFFInitDumpMode(TIFF* tif, int scheme)
{ {
(void) scheme; (void) scheme;
tif->tif_fixuptags = DumpFixupTags;
tif->tif_decoderow = DumpModeDecode; tif->tif_decoderow = DumpModeDecode;
tif->tif_decodestrip = DumpModeDecode; tif->tif_decodestrip = DumpModeDecode;
tif->tif_decodetile = DumpModeDecode; tif->tif_decodetile = DumpModeDecode;
tif->tif_encoderow = DumpModeEncode; tif->tif_encoderow = DumpModeEncode;
tif->tif_encodestrip = DumpModeEncode; tif->tif_encodestrip = DumpModeEncode;
tif->tif_encodetile = DumpModeEncode; tif->tif_encodetile = DumpModeEncode;
tif->tif_seek = DumpModeSeek; tif->tif_seek = DumpModeSeek;
return (1); return (1);
} }

View File

@ -1,4 +1,4 @@
/* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/tif_error.c,v 1.4.2.1 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/tif_error.c,v 1.5 2010-03-10 18:56:48 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler

View File

@ -1,4 +1,4 @@
/* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/tif_extension.c,v 1.4.2.1 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/tif_extension.c,v 1.7 2010-03-10 18:56:48 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -41,13 +41,13 @@ int TIFFGetTagListCount( TIFF *tif )
return td->td_customValueCount; return td->td_customValueCount;
} }
ttag_t TIFFGetTagListEntry( TIFF *tif, int tag_index ) uint32 TIFFGetTagListEntry( TIFF *tif, int tag_index )
{ {
TIFFDirectory* td = &tif->tif_dir; TIFFDirectory* td = &tif->tif_dir;
if( tag_index < 0 || tag_index >= td->td_customValueCount ) if( tag_index < 0 || tag_index >= td->td_customValueCount )
return (ttag_t) -1; return (uint32)(-1);
else else
return td->td_customValues[tag_index].info->field_tag; return td->td_customValues[tag_index].info->field_tag;
} }
@ -102,7 +102,7 @@ void TIFFSetClientInfo( TIFF *tif, void *data, const char *name )
link = (TIFFClientInfoLink *) _TIFFmalloc(sizeof(TIFFClientInfoLink)); link = (TIFFClientInfoLink *) _TIFFmalloc(sizeof(TIFFClientInfoLink));
assert (link != NULL); assert (link != NULL);
link->next = tif->tif_clientinfo; link->next = tif->tif_clientinfo;
link->name = (char *) _TIFFmalloc(strlen(name)+1); link->name = (char *) _TIFFmalloc((tmsize_t)(strlen(name)+1));
assert (link->name != NULL); assert (link->name != NULL);
strcpy(link->name, name); strcpy(link->name, name);
link->data = data; link->data = data;

View File

@ -1,4 +1,4 @@
/* $Id: tif_fax3.c,v 1.43.2.10 2010-06-09 17:16:58 bfriesen Exp $ */ /* $Id: tif_fax3.c,v 1.72 2010-06-09 17:17:13 bfriesen Exp $ */
/* /*
* Copyright (c) 1990-1997 Sam Leffler * Copyright (c) 1990-1997 Sam Leffler
@ -48,22 +48,19 @@
* derived from this ``base state'' block. * derived from this ``base state'' block.
*/ */
typedef struct { typedef struct {
int rw_mode; /* O_RDONLY for decode, else encode */ int rw_mode; /* O_RDONLY for decode, else encode */
int mode; /* operating mode */ int mode; /* operating mode */
uint32 rowbytes; /* bytes in a decoded scanline */ tmsize_t rowbytes; /* bytes in a decoded scanline */
uint32 rowpixels; /* pixels in a scanline */ uint32 rowpixels; /* pixels in a scanline */
uint16 cleanfaxdata; /* CleanFaxData tag */ uint16 cleanfaxdata; /* CleanFaxData tag */
uint32 badfaxrun; /* BadFaxRun tag */ uint32 badfaxrun; /* BadFaxRun tag */
uint32 badfaxlines; /* BadFaxLines tag */ uint32 badfaxlines; /* BadFaxLines tag */
uint32 groupoptions; /* Group 3/4 options tag */ uint32 groupoptions; /* Group 3/4 options tag */
uint32 recvparams; /* encoded Class 2 session params */
char* subaddress; /* subaddress string */ TIFFVGetMethod vgetparent; /* super-class method */
uint32 recvtime; /* time spent receiving (secs) */ TIFFVSetMethod vsetparent; /* super-class method */
char* faxdcs; /* Table 2/T.30 encoded session params */ TIFFPrintMethod printdir; /* super-class method */
TIFFVGetMethod vgetparent; /* super-class method */
TIFFVSetMethod vsetparent; /* super-class method */
TIFFPrintMethod printdir; /* super-class method */
} Fax3BaseState; } Fax3BaseState;
#define Fax3State(tif) ((Fax3BaseState*) (tif)->tif_data) #define Fax3State(tif) ((Fax3BaseState*) (tif)->tif_data)
@ -89,12 +86,11 @@ typedef struct {
int line; int line;
} Fax3CodecState; } Fax3CodecState;
#define DecoderState(tif) ((Fax3CodecState*) Fax3State(tif)) #define DecoderState(tif) ((Fax3CodecState*) Fax3State(tif))
#define EncoderState(tif) ((Fax3CodecState*) Fax3State(tif)) #define EncoderState(tif) ((Fax3CodecState*) Fax3State(tif))
#define is2DEncoding(sp) \ #define is2DEncoding(sp) (sp->b.groupoptions & GROUP3OPT_2DENCODING)
(sp->b.groupoptions & GROUP3OPT_2DENCODING) #define isAligned(p,t) ((((size_t)(p)) & (sizeof (t)-1)) == 0)
#define isAligned(p,t) ((((unsigned long)(p)) & (sizeof (t)-1)) == 0)
/* /*
* Group 3 and Group 4 Decoding. * Group 3 and Group 4 Decoding.
@ -140,15 +136,15 @@ typedef struct {
sp->bit = BitsAvail; \ sp->bit = BitsAvail; \
sp->data = BitAcc; \ sp->data = BitAcc; \
sp->EOLcnt = EOLcnt; \ sp->EOLcnt = EOLcnt; \
tif->tif_rawcc -= (tidata_t) cp - tif->tif_rawcp; \ tif->tif_rawcc -= (tmsize_t)((uint8*) cp - tif->tif_rawcp); \
tif->tif_rawcp = (tidata_t) cp; \ tif->tif_rawcp = (uint8*) cp; \
} while (0) } while (0)
/* /*
* Setup state for decoding a strip. * Setup state for decoding a strip.
*/ */
static int static int
Fax3PreDecode(TIFF* tif, tsample_t s) Fax3PreDecode(TIFF* tif, uint16 s)
{ {
Fax3CodecState* sp = DecoderState(tif); Fax3CodecState* sp = DecoderState(tif);
@ -183,10 +179,10 @@ Fax3PreDecode(TIFF* tif, tsample_t s)
static void static void
Fax3Unexpected(const char* module, TIFF* tif, uint32 line, uint32 a0) Fax3Unexpected(const char* module, TIFF* tif, uint32 line, uint32 a0)
{ {
TIFFErrorExt(tif->tif_clientdata, module, "%s: Bad code word at line %u of %s %u (x %u)", TIFFErrorExt(tif->tif_clientdata, module, "Bad code word at line %u of %s %u (x %u)",
tif->tif_name, line, isTiled(tif) ? "tile" : "strip", line, isTiled(tif) ? "tile" : "strip",
(isTiled(tif) ? tif->tif_curtile : tif->tif_curstrip), (isTiled(tif) ? tif->tif_curtile : tif->tif_curstrip),
a0); a0);
} }
#define unexpected(table, a0) Fax3Unexpected(module, tif, sp->line, a0) #define unexpected(table, a0) Fax3Unexpected(module, tif, sp->line, a0)
@ -194,33 +190,31 @@ static void
Fax3Extension(const char* module, TIFF* tif, uint32 line, uint32 a0) Fax3Extension(const char* module, TIFF* tif, uint32 line, uint32 a0)
{ {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"%s: Uncompressed data (not supported) at line %u of %s %u (x %u)", "Uncompressed data (not supported) at line %u of %s %u (x %u)",
tif->tif_name, line, isTiled(tif) ? "tile" : "strip", line, isTiled(tif) ? "tile" : "strip",
(isTiled(tif) ? tif->tif_curtile : tif->tif_curstrip), (isTiled(tif) ? tif->tif_curtile : tif->tif_curstrip),
a0); a0);
} }
#define extension(a0) Fax3Extension(module, tif, sp->line, a0) #define extension(a0) Fax3Extension(module, tif, sp->line, a0)
static void static void
Fax3BadLength(const char* module, TIFF* tif, uint32 line, uint32 a0, uint32 lastx) Fax3BadLength(const char* module, TIFF* tif, uint32 line, uint32 a0, uint32 lastx)
{ {
TIFFWarningExt(tif->tif_clientdata, module, "%s: %s at line %u of %s %u (got %u, expected %u)", TIFFWarningExt(tif->tif_clientdata, module, "%s at line %u of %s %u (got %u, expected %u)",
tif->tif_name, a0 < lastx ? "Premature EOL" : "Line length mismatch",
a0 < lastx ? "Premature EOL" : "Line length mismatch", line, isTiled(tif) ? "tile" : "strip",
line, isTiled(tif) ? "tile" : "strip", (isTiled(tif) ? tif->tif_curtile : tif->tif_curstrip),
(isTiled(tif) ? tif->tif_curtile : tif->tif_curstrip), a0, lastx);
a0, lastx);
} }
#define badlength(a0,lastx) Fax3BadLength(module, tif, sp->line, a0, lastx) #define badlength(a0,lastx) Fax3BadLength(module, tif, sp->line, a0, lastx)
static void static void
Fax3PrematureEOF(const char* module, TIFF* tif, uint32 line, uint32 a0) Fax3PrematureEOF(const char* module, TIFF* tif, uint32 line, uint32 a0)
{ {
TIFFWarningExt(tif->tif_clientdata, module, "%s: Premature EOF at line %u of %s %u (x %u)", TIFFWarningExt(tif->tif_clientdata, module, "Premature EOF at line %u of %s %u (x %u)",
tif->tif_name, line, isTiled(tif) ? "tile" : "strip",
line, isTiled(tif) ? "tile" : "strip", (isTiled(tif) ? tif->tif_curtile : tif->tif_curstrip),
(isTiled(tif) ? tif->tif_curtile : tif->tif_curstrip), a0);
a0);
} }
#define prematureEOF(a0) Fax3PrematureEOF(module, tif, sp->line, a0) #define prematureEOF(a0) Fax3PrematureEOF(module, tif, sp->line, a0)
@ -230,14 +224,18 @@ Fax3PrematureEOF(const char* module, TIFF* tif, uint32 line, uint32 a0)
* Decode the requested amount of G3 1D-encoded data. * Decode the requested amount of G3 1D-encoded data.
*/ */
static int static int
Fax3Decode1D(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s) Fax3Decode1D(TIFF* tif, uint8* buf, tmsize_t occ, uint16 s)
{ {
DECLARE_STATE(tif, sp, "Fax3Decode1D"); DECLARE_STATE(tif, sp, "Fax3Decode1D");
(void) s; (void) s;
if (occ % sp->b.rowbytes)
{
TIFFErrorExt(tif->tif_clientdata, module, "Fractional scanlines cannot be read");
return (-1);
}
CACHE_STATE(tif, sp); CACHE_STATE(tif, sp);
thisrun = sp->curruns; thisrun = sp->curruns;
while ((long)occ > 0) { while (occ > 0) {
a0 = 0; a0 = 0;
RunLength = 0; RunLength = 0;
pa = thisrun; pa = thisrun;
@ -269,14 +267,18 @@ Fax3Decode1D(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s)
* Decode the requested amount of G3 2D-encoded data. * Decode the requested amount of G3 2D-encoded data.
*/ */
static int static int
Fax3Decode2D(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s) Fax3Decode2D(TIFF* tif, uint8* buf, tmsize_t occ, uint16 s)
{ {
DECLARE_STATE_2D(tif, sp, "Fax3Decode2D"); DECLARE_STATE_2D(tif, sp, "Fax3Decode2D");
int is1D; /* current line is 1d/2d-encoded */ int is1D; /* current line is 1d/2d-encoded */
(void) s; (void) s;
if (occ % sp->b.rowbytes)
{
TIFFErrorExt(tif->tif_clientdata, module, "Fractional scanlines cannot be read");
return (-1);
}
CACHE_STATE(tif, sp); CACHE_STATE(tif, sp);
while ((long)occ > 0) { while (occ > 0) {
a0 = 0; a0 = 0;
RunLength = 0; RunLength = 0;
pa = thisrun = sp->curruns; pa = thisrun = sp->curruns;
@ -324,7 +326,7 @@ Fax3Decode2D(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s)
* this is <8 bytes. We optimize the code here to reflect the * this is <8 bytes. We optimize the code here to reflect the
* machine characteristics. * machine characteristics.
*/ */
#if SIZEOF_LONG == 8 #if SIZEOF_UNSIGNED_LONG == 8
# define FILL(n, cp) \ # define FILL(n, cp) \
switch (n) { \ switch (n) { \
case 15:(cp)[14] = 0xff; case 14:(cp)[13] = 0xff; case 13: (cp)[12] = 0xff;\ case 15:(cp)[14] = 0xff; case 14:(cp)[13] = 0xff; case 13: (cp)[12] = 0xff;\
@ -452,6 +454,13 @@ _TIFFFax3fillruns(unsigned char* buf, uint32* runs, uint32* erun, uint32 lastx)
#undef ZERO #undef ZERO
#undef FILL #undef FILL
static int
Fax3FixupTags(TIFF* tif)
{
(void) tif;
return (1);
}
/* /*
* Setup G3/G4-related compression/decompression state * Setup G3/G4-related compression/decompression state
* before data is processed. This routine is called once * before data is processed. This routine is called once
@ -462,14 +471,16 @@ _TIFFFax3fillruns(unsigned char* buf, uint32* runs, uint32* erun, uint32 lastx)
static int static int
Fax3SetupState(TIFF* tif) Fax3SetupState(TIFF* tif)
{ {
static const char module[] = "Fax3SetupState";
TIFFDirectory* td = &tif->tif_dir; TIFFDirectory* td = &tif->tif_dir;
Fax3BaseState* sp = Fax3State(tif); Fax3BaseState* sp = Fax3State(tif);
int needsRefLine; int needsRefLine;
Fax3CodecState* dsp = (Fax3CodecState*) Fax3State(tif); Fax3CodecState* dsp = (Fax3CodecState*) Fax3State(tif);
uint32 rowbytes, rowpixels, nruns; tmsize_t rowbytes;
uint32 rowpixels, nruns;
if (td->td_bitspersample != 1) { if (td->td_bitspersample != 1) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"Bits/sample must be 1 for Group 3/4 encoding/decoding"); "Bits/sample must be 1 for Group 3/4 encoding/decoding");
return (0); return (0);
} }
@ -483,8 +494,8 @@ Fax3SetupState(TIFF* tif)
rowbytes = TIFFScanlineSize(tif); rowbytes = TIFFScanlineSize(tif);
rowpixels = td->td_imagewidth; rowpixels = td->td_imagewidth;
} }
sp->rowbytes = (uint32) rowbytes; sp->rowbytes = rowbytes;
sp->rowpixels = (uint32) rowpixels; sp->rowpixels = rowpixels;
/* /*
* Allocate any additional space required for decoding/encoding. * Allocate any additional space required for decoding/encoding.
*/ */
@ -495,11 +506,11 @@ Fax3SetupState(TIFF* tif)
/* /*
Assure that allocation computations do not overflow. Assure that allocation computations do not overflow.
TIFFroundup and TIFFSafeMultiply return zero on integer overflow TIFFroundup and TIFFSafeMultiply return zero on integer overflow
*/ */
dsp->runs=(uint32*) NULL; dsp->runs=(uint32*) NULL;
nruns = TIFFroundup(rowpixels,32); nruns = TIFFroundup_32(rowpixels,32);
if (needsRefLine) { if (needsRefLine) {
nruns = TIFFSafeMultiply(uint32,nruns,2); nruns = TIFFSafeMultiply(uint32,nruns,2);
} }
@ -538,9 +549,8 @@ Fax3SetupState(TIFF* tif)
*/ */
esp->refline = (unsigned char*) _TIFFmalloc(rowbytes); esp->refline = (unsigned char*) _TIFFmalloc(rowbytes);
if (esp->refline == NULL) { if (esp->refline == NULL) {
TIFFErrorExt(tif->tif_clientdata, "Fax3SetupState", TIFFErrorExt(tif->tif_clientdata, module,
"%s: No space for Group 3/4 reference line", "No space for Group 3/4 reference line");
tif->tif_name);
return (0); return (0);
} }
} else /* 1d encoding */ } else /* 1d encoding */
@ -556,14 +566,14 @@ Fax3SetupState(TIFF* tif)
#define Fax3FlushBits(tif, sp) { \ #define Fax3FlushBits(tif, sp) { \
if ((tif)->tif_rawcc >= (tif)->tif_rawdatasize) \ if ((tif)->tif_rawcc >= (tif)->tif_rawdatasize) \
(void) TIFFFlushData1(tif); \ (void) TIFFFlushData1(tif); \
*(tif)->tif_rawcp++ = (tidataval_t) (sp)->data; \ *(tif)->tif_rawcp++ = (uint8) (sp)->data; \
(tif)->tif_rawcc++; \ (tif)->tif_rawcc++; \
(sp)->data = 0, (sp)->bit = 8; \ (sp)->data = 0, (sp)->bit = 8; \
} }
#define _FlushBits(tif) { \ #define _FlushBits(tif) { \
if ((tif)->tif_rawcc >= (tif)->tif_rawdatasize) \ if ((tif)->tif_rawcc >= (tif)->tif_rawdatasize) \
(void) TIFFFlushData1(tif); \ (void) TIFFFlushData1(tif); \
*(tif)->tif_rawcp++ = (tidataval_t) data; \ *(tif)->tif_rawcp++ = (uint8) data; \
(tif)->tif_rawcc++; \ (tif)->tif_rawcc++; \
data = 0, bit = 8; \ data = 0, bit = 8; \
} }
@ -575,6 +585,7 @@ static const int _msbmask[9] =
length -= bit; \ length -= bit; \
_FlushBits(tif); \ _FlushBits(tif); \
} \ } \
assert( length < 9 ); \
data |= (bits & _msbmask[length]) << (bit - length); \ data |= (bits & _msbmask[length]) << (bit - length); \
bit -= length; \ bit -= length; \
if (bit == 0) \ if (bit == 0) \
@ -702,7 +713,7 @@ Fax3PutEOL(TIFF* tif)
* Reset encoding state at the start of a strip. * Reset encoding state at the start of a strip.
*/ */
static int static int
Fax3PreEncode(TIFF* tif, tsample_t s) Fax3PreEncode(TIFF* tif, uint16 s)
{ {
Fax3CodecState* sp = EncoderState(tif); Fax3CodecState* sp = EncoderState(tif);
@ -792,7 +803,7 @@ static int32 find1span(unsigned char*, int32, int32);
* table. The ``base'' of the bit string is supplied * table. The ``base'' of the bit string is supplied
* along with the start+end bit indices. * along with the start+end bit indices.
*/ */
static int32 inline static int32
find0span(unsigned char* bp, int32 bs, int32 be) find0span(unsigned char* bp, int32 bs, int32 be)
{ {
int32 bits = be - bs; int32 bits = be - bs;
@ -851,7 +862,7 @@ find0span(unsigned char* bp, int32 bs, int32 be)
return (span); return (span);
} }
static int32 inline static int32
find1span(unsigned char* bp, int32 bs, int32 be) find1span(unsigned char* bp, int32 bs, int32 be)
{ {
int32 bits = be - bs; int32 bits = be - bs;
@ -1023,12 +1034,17 @@ Fax3Encode2DRow(TIFF* tif, unsigned char* bp, unsigned char* rp, uint32 bits)
* Encode a buffer of pixels. * Encode a buffer of pixels.
*/ */
static int static int
Fax3Encode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) Fax3Encode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
static const char module[] = "Fax3Encode";
Fax3CodecState* sp = EncoderState(tif); Fax3CodecState* sp = EncoderState(tif);
(void) s; (void) s;
while ((long)cc > 0) { if (cc % sp->b.rowbytes)
{
TIFFErrorExt(tif->tif_clientdata, module, "Fractional scanlines cannot be written");
return (0);
}
while (cc > 0) {
if ((sp->b.mode & FAXMODE_NOEOL) == 0) if ((sp->b.mode & FAXMODE_NOEOL) == 0)
Fax3PutEOL(tif); Fax3PutEOL(tif);
if (is2DEncoding(sp)) { if (is2DEncoding(sp)) {
@ -1038,7 +1054,7 @@ Fax3Encode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
sp->tag = G3_2D; sp->tag = G3_2D;
} else { } else {
if (!Fax3Encode2DRow(tif, bp, sp->refline, if (!Fax3Encode2DRow(tif, bp, sp->refline,
sp->b.rowpixels)) sp->b.rowpixels))
return (0); return (0);
sp->k--; sp->k--;
} }
@ -1100,11 +1116,6 @@ Fax3Cleanup(TIFF* tif)
if (sp->refline) if (sp->refline)
_TIFFfree(sp->refline); _TIFFfree(sp->refline);
if (Fax3State(tif)->subaddress)
_TIFFfree(Fax3State(tif)->subaddress);
if (Fax3State(tif)->faxdcs)
_TIFFfree(Fax3State(tif)->faxdcs);
_TIFFfree(tif->tif_data); _TIFFfree(tif->tif_data);
tif->tif_data = NULL; tif->tif_data = NULL;
@ -1114,59 +1125,34 @@ Fax3Cleanup(TIFF* tif)
#define FIELD_BADFAXLINES (FIELD_CODEC+0) #define FIELD_BADFAXLINES (FIELD_CODEC+0)
#define FIELD_CLEANFAXDATA (FIELD_CODEC+1) #define FIELD_CLEANFAXDATA (FIELD_CODEC+1)
#define FIELD_BADFAXRUN (FIELD_CODEC+2) #define FIELD_BADFAXRUN (FIELD_CODEC+2)
#define FIELD_RECVPARAMS (FIELD_CODEC+3)
#define FIELD_SUBADDRESS (FIELD_CODEC+4)
#define FIELD_RECVTIME (FIELD_CODEC+5)
#define FIELD_FAXDCS (FIELD_CODEC+6)
#define FIELD_OPTIONS (FIELD_CODEC+7) #define FIELD_OPTIONS (FIELD_CODEC+7)
static const TIFFFieldInfo faxFieldInfo[] = { static const TIFFField faxFields[] = {
{ TIFFTAG_FAXMODE, 0, 0, TIFF_ANY, FIELD_PSEUDO, { TIFFTAG_FAXMODE, 0, 0, TIFF_ANY, 0, TIFF_SETGET_INT, TIFF_SETGET_UNDEFINED, FIELD_PSEUDO, FALSE, FALSE, "FaxMode", NULL },
FALSE, FALSE, "FaxMode" }, { TIFFTAG_FAXFILLFUNC, 0, 0, TIFF_ANY, 0, TIFF_SETGET_OTHER, TIFF_SETGET_UNDEFINED, FIELD_PSEUDO, FALSE, FALSE, "FaxFillFunc", NULL },
{ TIFFTAG_FAXFILLFUNC, 0, 0, TIFF_ANY, FIELD_PSEUDO, { TIFFTAG_BADFAXLINES, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32, TIFF_SETGET_UINT32, FIELD_BADFAXLINES, TRUE, FALSE, "BadFaxLines", NULL },
FALSE, FALSE, "FaxFillFunc" }, { TIFFTAG_CLEANFAXDATA, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16, TIFF_SETGET_UINT16, FIELD_CLEANFAXDATA, TRUE, FALSE, "CleanFaxData", NULL },
{ TIFFTAG_BADFAXLINES, 1, 1, TIFF_LONG, FIELD_BADFAXLINES, { TIFFTAG_CONSECUTIVEBADFAXLINES, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32, TIFF_SETGET_UINT32, FIELD_BADFAXRUN, TRUE, FALSE, "ConsecutiveBadFaxLines", NULL }};
TRUE, FALSE, "BadFaxLines" }, static const TIFFField fax3Fields[] = {
{ TIFFTAG_BADFAXLINES, 1, 1, TIFF_SHORT, FIELD_BADFAXLINES, { TIFFTAG_GROUP3OPTIONS, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32, TIFF_SETGET_UINT32, FIELD_OPTIONS, FALSE, FALSE, "Group3Options", NULL },
TRUE, FALSE, "BadFaxLines" },
{ TIFFTAG_CLEANFAXDATA, 1, 1, TIFF_SHORT, FIELD_CLEANFAXDATA,
TRUE, FALSE, "CleanFaxData" },
{ TIFFTAG_CONSECUTIVEBADFAXLINES,1,1, TIFF_LONG, FIELD_BADFAXRUN,
TRUE, FALSE, "ConsecutiveBadFaxLines" },
{ TIFFTAG_CONSECUTIVEBADFAXLINES,1,1, TIFF_SHORT, FIELD_BADFAXRUN,
TRUE, FALSE, "ConsecutiveBadFaxLines" },
{ TIFFTAG_FAXRECVPARAMS, 1, 1, TIFF_LONG, FIELD_RECVPARAMS,
TRUE, FALSE, "FaxRecvParams" },
{ TIFFTAG_FAXSUBADDRESS, -1,-1, TIFF_ASCII, FIELD_SUBADDRESS,
TRUE, FALSE, "FaxSubAddress" },
{ TIFFTAG_FAXRECVTIME, 1, 1, TIFF_LONG, FIELD_RECVTIME,
TRUE, FALSE, "FaxRecvTime" },
{ TIFFTAG_FAXDCS, -1,-1, TIFF_ASCII, FIELD_FAXDCS,
TRUE, FALSE, "FaxDcs" },
}; };
static const TIFFFieldInfo fax3FieldInfo[] = { static const TIFFField fax4Fields[] = {
{ TIFFTAG_GROUP3OPTIONS, 1, 1, TIFF_LONG, FIELD_OPTIONS, { TIFFTAG_GROUP4OPTIONS, 1, 1, TIFF_LONG, 0, TIFF_SETGET_UINT32, TIFF_SETGET_UINT32, FIELD_OPTIONS, FALSE, FALSE, "Group4Options", NULL },
FALSE, FALSE, "Group3Options" },
}; };
static const TIFFFieldInfo fax4FieldInfo[] = {
{ TIFFTAG_GROUP4OPTIONS, 1, 1, TIFF_LONG, FIELD_OPTIONS,
FALSE, FALSE, "Group4Options" },
};
#define N(a) (sizeof (a) / sizeof (a[0]))
static int static int
Fax3VSetField(TIFF* tif, ttag_t tag, va_list ap) Fax3VSetField(TIFF* tif, uint32 tag, va_list ap)
{ {
Fax3BaseState* sp = Fax3State(tif); Fax3BaseState* sp = Fax3State(tif);
const TIFFFieldInfo* fip; const TIFFField* fip;
assert(sp != 0); assert(sp != 0);
assert(sp->vsetparent != 0); assert(sp->vsetparent != 0);
switch (tag) { switch (tag) {
case TIFFTAG_FAXMODE: case TIFFTAG_FAXMODE:
sp->mode = va_arg(ap, int); sp->mode = (int) va_arg(ap, int);
return 1; /* NB: pseudo tag */ return 1; /* NB: pseudo tag */
case TIFFTAG_FAXFILLFUNC: case TIFFTAG_FAXFILLFUNC:
DecoderState(tif)->fill = va_arg(ap, TIFFFaxFillFunc); DecoderState(tif)->fill = va_arg(ap, TIFFFaxFillFunc);
@ -1174,39 +1160,27 @@ Fax3VSetField(TIFF* tif, ttag_t tag, va_list ap)
case TIFFTAG_GROUP3OPTIONS: case TIFFTAG_GROUP3OPTIONS:
/* XXX: avoid reading options if compression mismatches. */ /* XXX: avoid reading options if compression mismatches. */
if (tif->tif_dir.td_compression == COMPRESSION_CCITTFAX3) if (tif->tif_dir.td_compression == COMPRESSION_CCITTFAX3)
sp->groupoptions = va_arg(ap, uint32); sp->groupoptions = (uint32) va_arg(ap, uint32);
break; break;
case TIFFTAG_GROUP4OPTIONS: case TIFFTAG_GROUP4OPTIONS:
/* XXX: avoid reading options if compression mismatches. */ /* XXX: avoid reading options if compression mismatches. */
if (tif->tif_dir.td_compression == COMPRESSION_CCITTFAX4) if (tif->tif_dir.td_compression == COMPRESSION_CCITTFAX4)
sp->groupoptions = va_arg(ap, uint32); sp->groupoptions = (uint32) va_arg(ap, uint32);
break; break;
case TIFFTAG_BADFAXLINES: case TIFFTAG_BADFAXLINES:
sp->badfaxlines = va_arg(ap, uint32); sp->badfaxlines = (uint32) va_arg(ap, uint32);
break; break;
case TIFFTAG_CLEANFAXDATA: case TIFFTAG_CLEANFAXDATA:
sp->cleanfaxdata = (uint16) va_arg(ap, int); sp->cleanfaxdata = (uint16) va_arg(ap, uint16_vap);
break; break;
case TIFFTAG_CONSECUTIVEBADFAXLINES: case TIFFTAG_CONSECUTIVEBADFAXLINES:
sp->badfaxrun = va_arg(ap, uint32); sp->badfaxrun = (uint32) va_arg(ap, uint32);
break;
case TIFFTAG_FAXRECVPARAMS:
sp->recvparams = va_arg(ap, uint32);
break;
case TIFFTAG_FAXSUBADDRESS:
_TIFFsetString(&sp->subaddress, va_arg(ap, char*));
break;
case TIFFTAG_FAXRECVTIME:
sp->recvtime = va_arg(ap, uint32);
break;
case TIFFTAG_FAXDCS:
_TIFFsetString(&sp->faxdcs, va_arg(ap, char*));
break; break;
default: default:
return (*sp->vsetparent)(tif, tag, ap); return (*sp->vsetparent)(tif, tag, ap);
} }
if ((fip = _TIFFFieldWithTag(tif, tag))) if ((fip = TIFFFieldWithTag(tif, tag)))
TIFFSetFieldBit(tif, fip->field_bit); TIFFSetFieldBit(tif, fip->field_bit);
else else
return 0; return 0;
@ -1216,7 +1190,7 @@ Fax3VSetField(TIFF* tif, ttag_t tag, va_list ap)
} }
static int static int
Fax3VGetField(TIFF* tif, ttag_t tag, va_list ap) Fax3VGetField(TIFF* tif, uint32 tag, va_list ap)
{ {
Fax3BaseState* sp = Fax3State(tif); Fax3BaseState* sp = Fax3State(tif);
@ -1242,18 +1216,6 @@ Fax3VGetField(TIFF* tif, ttag_t tag, va_list ap)
case TIFFTAG_CONSECUTIVEBADFAXLINES: case TIFFTAG_CONSECUTIVEBADFAXLINES:
*va_arg(ap, uint32*) = sp->badfaxrun; *va_arg(ap, uint32*) = sp->badfaxrun;
break; break;
case TIFFTAG_FAXRECVPARAMS:
*va_arg(ap, uint32*) = sp->recvparams;
break;
case TIFFTAG_FAXSUBADDRESS:
*va_arg(ap, char**) = sp->subaddress;
break;
case TIFFTAG_FAXRECVTIME:
*va_arg(ap, uint32*) = sp->recvtime;
break;
case TIFFTAG_FAXDCS:
*va_arg(ap, char**) = sp->faxdcs;
break;
default: default:
return (*sp->vgetparent)(tif, tag, ap); return (*sp->vgetparent)(tif, tag, ap);
} }
@ -1310,27 +1272,20 @@ Fax3PrintDir(TIFF* tif, FILE* fd, long flags)
if (TIFFFieldSet(tif,FIELD_BADFAXRUN)) if (TIFFFieldSet(tif,FIELD_BADFAXRUN))
fprintf(fd, " Consecutive Bad Fax Lines: %lu\n", fprintf(fd, " Consecutive Bad Fax Lines: %lu\n",
(unsigned long) sp->badfaxrun); (unsigned long) sp->badfaxrun);
if (TIFFFieldSet(tif,FIELD_RECVPARAMS)) if (sp->printdir)
fprintf(fd, " Fax Receive Parameters: %08lx\n", (*sp->printdir)(tif, fd, flags);
(unsigned long) sp->recvparams);
if (TIFFFieldSet(tif,FIELD_SUBADDRESS))
fprintf(fd, " Fax SubAddress: %s\n", sp->subaddress);
if (TIFFFieldSet(tif,FIELD_RECVTIME))
fprintf(fd, " Fax Receive Time: %lu secs\n",
(unsigned long) sp->recvtime);
if (TIFFFieldSet(tif,FIELD_FAXDCS))
fprintf(fd, " Fax DCS: %s\n", sp->faxdcs);
} }
static int static int
InitCCITTFax3(TIFF* tif) InitCCITTFax3(TIFF* tif)
{ {
static const char module[] = "InitCCITTFax3";
Fax3BaseState* sp; Fax3BaseState* sp;
/* /*
* Merge codec-specific tag information. * Merge codec-specific tag information.
*/ */
if (!_TIFFMergeFieldInfo(tif, faxFieldInfo, N(faxFieldInfo))) { if (!_TIFFMergeFields(tif, faxFields, TIFFArrayCount(faxFields))) {
TIFFErrorExt(tif->tif_clientdata, "InitCCITTFax3", TIFFErrorExt(tif->tif_clientdata, "InitCCITTFax3",
"Merging common CCITT Fax codec-specific tags failed"); "Merging common CCITT Fax codec-specific tags failed");
return 0; return 0;
@ -1339,12 +1294,12 @@ InitCCITTFax3(TIFF* tif)
/* /*
* Allocate state block so tag methods have storage to record values. * Allocate state block so tag methods have storage to record values.
*/ */
tif->tif_data = (tidata_t) tif->tif_data = (uint8*)
_TIFFmalloc(sizeof (Fax3CodecState)); _TIFFmalloc(sizeof (Fax3CodecState));
if (tif->tif_data == NULL) { if (tif->tif_data == NULL) {
TIFFErrorExt(tif->tif_clientdata, "TIFFInitCCITTFax3", TIFFErrorExt(tif->tif_clientdata, module,
"%s: No space for state block", tif->tif_name); "No space for state block");
return (0); return (0);
} }
@ -1361,9 +1316,6 @@ InitCCITTFax3(TIFF* tif)
sp->printdir = tif->tif_tagmethods.printdir; sp->printdir = tif->tif_tagmethods.printdir;
tif->tif_tagmethods.printdir = Fax3PrintDir; /* hook for codec tags */ tif->tif_tagmethods.printdir = Fax3PrintDir; /* hook for codec tags */
sp->groupoptions = 0; sp->groupoptions = 0;
sp->recvparams = 0;
sp->subaddress = NULL;
sp->faxdcs = NULL;
if (sp->rw_mode == O_RDONLY) /* FIXME: improve for in place update */ if (sp->rw_mode == O_RDONLY) /* FIXME: improve for in place update */
tif->tif_flags |= TIFF_NOBITREV; /* decoder does bit reversal */ tif->tif_flags |= TIFF_NOBITREV; /* decoder does bit reversal */
@ -1374,6 +1326,7 @@ InitCCITTFax3(TIFF* tif)
/* /*
* Install codec methods. * Install codec methods.
*/ */
tif->tif_fixuptags = Fax3FixupTags;
tif->tif_setupdecode = Fax3SetupState; tif->tif_setupdecode = Fax3SetupState;
tif->tif_predecode = Fax3PreDecode; tif->tif_predecode = Fax3PreDecode;
tif->tif_decoderow = Fax3Decode1D; tif->tif_decoderow = Fax3Decode1D;
@ -1399,7 +1352,8 @@ TIFFInitCCITTFax3(TIFF* tif, int scheme)
/* /*
* Merge codec-specific tag information. * Merge codec-specific tag information.
*/ */
if (!_TIFFMergeFieldInfo(tif, fax3FieldInfo, N(fax3FieldInfo))) { if (!_TIFFMergeFields(tif, fax3Fields,
TIFFArrayCount(fax3Fields))) {
TIFFErrorExt(tif->tif_clientdata, "TIFFInitCCITTFax3", TIFFErrorExt(tif->tif_clientdata, "TIFFInitCCITTFax3",
"Merging CCITT Fax 3 codec-specific tags failed"); "Merging CCITT Fax 3 codec-specific tags failed");
return 0; return 0;
@ -1418,18 +1372,22 @@ TIFFInitCCITTFax3(TIFF* tif, int scheme)
* Compression Scheme Support. * Compression Scheme Support.
*/ */
#define SWAP(t,a,b) { t x; x = (a); (a) = (b); (b) = x; } #define SWAP(t,a,b) { t x; x = (a); (a) = (b); (b) = x; }
/* /*
* Decode the requested amount of G4-encoded data. * Decode the requested amount of G4-encoded data.
*/ */
static int static int
Fax4Decode(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s) Fax4Decode(TIFF* tif, uint8* buf, tmsize_t occ, uint16 s)
{ {
DECLARE_STATE_2D(tif, sp, "Fax4Decode"); DECLARE_STATE_2D(tif, sp, "Fax4Decode");
(void) s; (void) s;
if (occ % sp->b.rowbytes)
{
TIFFErrorExt(tif->tif_clientdata, module, "Fractional scanlines cannot be read");
return (-1);
}
CACHE_STATE(tif, sp); CACHE_STATE(tif, sp);
while ((long)occ > 0) { while (occ > 0) {
a0 = 0; a0 = 0;
RunLength = 0; RunLength = 0;
pa = thisrun = sp->curruns; pa = thisrun = sp->curruns;
@ -1471,12 +1429,17 @@ Fax4Decode(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s)
* Encode the requested amount of data. * Encode the requested amount of data.
*/ */
static int static int
Fax4Encode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) Fax4Encode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
static const char module[] = "Fax4Encode";
Fax3CodecState *sp = EncoderState(tif); Fax3CodecState *sp = EncoderState(tif);
(void) s; (void) s;
while ((long)cc > 0) { if (cc % sp->b.rowbytes)
{
TIFFErrorExt(tif->tif_clientdata, module, "Fractional scanlines cannot be written");
return (0);
}
while (cc > 0) {
if (!Fax3Encode2DRow(tif, bp, sp->refline, sp->b.rowpixels)) if (!Fax3Encode2DRow(tif, bp, sp->refline, sp->b.rowpixels))
return (0); return (0);
_TIFFmemcpy(sp->refline, bp, sp->b.rowbytes); _TIFFmemcpy(sp->refline, bp, sp->b.rowbytes);
@ -1507,7 +1470,8 @@ TIFFInitCCITTFax4(TIFF* tif, int scheme)
/* /*
* Merge codec-specific tag information. * Merge codec-specific tag information.
*/ */
if (!_TIFFMergeFieldInfo(tif, fax4FieldInfo, N(fax4FieldInfo))) { if (!_TIFFMergeFields(tif, fax4Fields,
TIFFArrayCount(fax4Fields))) {
TIFFErrorExt(tif->tif_clientdata, "TIFFInitCCITTFax4", TIFFErrorExt(tif->tif_clientdata, "TIFFInitCCITTFax4",
"Merging CCITT Fax 4 codec-specific tags failed"); "Merging CCITT Fax 4 codec-specific tags failed");
return 0; return 0;
@ -1537,15 +1501,19 @@ TIFFInitCCITTFax4(TIFF* tif, int scheme)
* Decode the requested amount of RLE-encoded data. * Decode the requested amount of RLE-encoded data.
*/ */
static int static int
Fax3DecodeRLE(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s) Fax3DecodeRLE(TIFF* tif, uint8* buf, tmsize_t occ, uint16 s)
{ {
DECLARE_STATE(tif, sp, "Fax3DecodeRLE"); DECLARE_STATE(tif, sp, "Fax3DecodeRLE");
int mode = sp->b.mode; int mode = sp->b.mode;
(void) s; (void) s;
if (occ % sp->b.rowbytes)
{
TIFFErrorExt(tif->tif_clientdata, module, "Fractional scanlines cannot be read");
return (-1);
}
CACHE_STATE(tif, sp); CACHE_STATE(tif, sp);
thisrun = sp->curruns; thisrun = sp->curruns;
while ((long)occ > 0) { while (occ > 0) {
a0 = 0; a0 = 0;
RunLength = 0; RunLength = 0;
pa = thisrun; pa = thisrun;
@ -1605,7 +1573,7 @@ TIFFInitCCITTRLEW(TIFF* tif, int scheme)
if (InitCCITTFax3(tif)) { /* reuse G3 support */ if (InitCCITTFax3(tif)) { /* reuse G3 support */
tif->tif_decoderow = Fax3DecodeRLE; tif->tif_decoderow = Fax3DecodeRLE;
tif->tif_decodestrip = Fax3DecodeRLE; tif->tif_decodestrip = Fax3DecodeRLE;
tif->tif_decodetile = Fax3DecodeRLE; tif->tif_decodetile = Fax3DecodeRLE;
/* /*
* Suppress RTC+EOLs when encoding and word-align data. * Suppress RTC+EOLs when encoding and word-align data.
*/ */

View File

@ -1,4 +1,4 @@
/* $Id: tif_fax3.h,v 1.5.2.1 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_fax3.h,v 1.9 2011-03-10 20:23:07 fwarmerdam Exp $ */
/* /*
* Copyright (c) 1990-1997 Sam Leffler * Copyright (c) 1990-1997 Sam Leffler
@ -52,7 +52,7 @@
* data in the run array as needed (e.g. to append zero runs to bring * data in the run array as needed (e.g. to append zero runs to bring
* the count up to a nice multiple). * the count up to a nice multiple).
*/ */
typedef void (*TIFFFaxFillFunc)(unsigned char*, uint32*, uint32*, uint32); typedef void (*TIFFFaxFillFunc)(unsigned char*, uint32*, uint32*, uint32);
/* /*
* The default run filler; made external for other decoders. * The default run filler; made external for other decoders.
@ -60,36 +60,36 @@ typedef void (*TIFFFaxFillFunc)(unsigned char*, uint32*, uint32*, uint32);
#if defined(__cplusplus) #if defined(__cplusplus)
extern "C" { extern "C" {
#endif #endif
extern void _TIFFFax3fillruns(unsigned char*, uint32*, uint32*, uint32); extern void _TIFFFax3fillruns(unsigned char*, uint32*, uint32*, uint32);
#if defined(__cplusplus) #if defined(__cplusplus)
} }
#endif #endif
/* finite state machine codes */ /* finite state machine codes */
#define S_Null 0 #define S_Null 0
#define S_Pass 1 #define S_Pass 1
#define S_Horiz 2 #define S_Horiz 2
#define S_V0 3 #define S_V0 3
#define S_VR 4 #define S_VR 4
#define S_VL 5 #define S_VL 5
#define S_Ext 6 #define S_Ext 6
#define S_TermW 7 #define S_TermW 7
#define S_TermB 8 #define S_TermB 8
#define S_MakeUpW 9 #define S_MakeUpW 9
#define S_MakeUpB 10 #define S_MakeUpB 10
#define S_MakeUp 11 #define S_MakeUp 11
#define S_EOL 12 #define S_EOL 12
typedef struct { /* state table entry */ typedef struct { /* state table entry */
unsigned char State; /* see above */ unsigned char State; /* see above */
unsigned char Width; /* width of code in bits */ unsigned char Width; /* width of code in bits */
uint32 Param; /* unsigned 32-bit run length in bits */ uint32 Param; /* unsigned 32-bit run length in bits */
} TIFFFaxTabEnt; } TIFFFaxTabEnt;
extern const TIFFFaxTabEnt TIFFFaxMainTable[]; extern const TIFFFaxTabEnt TIFFFaxMainTable[];
extern const TIFFFaxTabEnt TIFFFaxWhiteTable[]; extern const TIFFFaxTabEnt TIFFFaxWhiteTable[];
extern const TIFFFaxTabEnt TIFFFaxBlackTable[]; extern const TIFFFaxTabEnt TIFFFaxBlackTable[];
/* /*
* The following macros define the majority of the G3/G4 decoder * The following macros define the majority of the G3/G4 decoder
@ -478,6 +478,12 @@ done1d: \
break; \ break; \
case S_VL: \ case S_VL: \
CHECK_b1; \ CHECK_b1; \
if (b1 <= (int) (a0 + TabEnt->Param)) { \
if (b1 < (int) (a0 + TabEnt->Param) || pa != thisrun) { \
unexpected("VL", a0); \
goto eol2d; \
} \
} \
SETVALUE(b1 - a0 - TabEnt->Param); \ SETVALUE(b1 - a0 - TabEnt->Param); \
b1 -= *--pb; \ b1 -= *--pb; \
break; \ break; \

View File

@ -1,4 +1,4 @@
/* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/tif_flush.c,v 1.3.2.1 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_flush.c,v 1.9 2010-03-31 06:40:10 fwarmerdam Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -32,15 +32,58 @@
int int
TIFFFlush(TIFF* tif) TIFFFlush(TIFF* tif)
{ {
if( tif->tif_mode == O_RDONLY )
return 1;
if (tif->tif_mode != O_RDONLY) { if (!TIFFFlushData(tif))
if (!TIFFFlushData(tif)) return (0);
return (0);
if ((tif->tif_flags & TIFF_DIRTYDIRECT) && /* In update (r+) mode we try to detect the case where
!TIFFWriteDirectory(tif)) only the strip/tile map has been altered, and we try to
return (0); rewrite only that portion of the directory without
} making any other changes */
return (1);
if( (tif->tif_flags & TIFF_DIRTYSTRIP)
&& !(tif->tif_flags & TIFF_DIRTYDIRECT)
&& tif->tif_mode == O_RDWR )
{
uint64 *offsets=NULL, *sizes=NULL;
if( TIFFIsTiled(tif) )
{
if( TIFFGetField( tif, TIFFTAG_TILEOFFSETS, &offsets )
&& TIFFGetField( tif, TIFFTAG_TILEBYTECOUNTS, &sizes )
&& _TIFFRewriteField( tif, TIFFTAG_TILEOFFSETS, TIFF_LONG8,
tif->tif_dir.td_nstrips, offsets )
&& _TIFFRewriteField( tif, TIFFTAG_TILEBYTECOUNTS, TIFF_LONG8,
tif->tif_dir.td_nstrips, sizes ) )
{
tif->tif_flags &= ~TIFF_DIRTYSTRIP;
tif->tif_flags &= ~TIFF_BEENWRITING;
return 1;
}
}
else
{
if( TIFFGetField( tif, TIFFTAG_STRIPOFFSETS, &offsets )
&& TIFFGetField( tif, TIFFTAG_STRIPBYTECOUNTS, &sizes )
&& _TIFFRewriteField( tif, TIFFTAG_STRIPOFFSETS, TIFF_LONG8,
tif->tif_dir.td_nstrips, offsets )
&& _TIFFRewriteField( tif, TIFFTAG_STRIPBYTECOUNTS, TIFF_LONG8,
tif->tif_dir.td_nstrips, sizes ) )
{
tif->tif_flags &= ~TIFF_DIRTYSTRIP;
tif->tif_flags &= ~TIFF_BEENWRITING;
return 1;
}
}
}
if ((tif->tif_flags & (TIFF_DIRTYDIRECT|TIFF_DIRTYSTRIP))
&& !TIFFRewriteDirectory(tif))
return (0);
return (1);
} }
/* /*
@ -56,7 +99,7 @@ int
TIFFFlushData(TIFF* tif) TIFFFlushData(TIFF* tif)
{ {
if ((tif->tif_flags & TIFF_BEENWRITING) == 0) if ((tif->tif_flags & TIFF_BEENWRITING) == 0)
return (0); return (1);
if (tif->tif_flags & TIFF_POSTENCODE) { if (tif->tif_flags & TIFF_POSTENCODE) {
tif->tif_flags &= ~TIFF_POSTENCODE; tif->tif_flags &= ~TIFF_POSTENCODE;
if (!(*tif->tif_postencode)(tif)) if (!(*tif->tif_postencode)(tif))
@ -65,6 +108,7 @@ TIFFFlushData(TIFF* tif)
return (TIFFFlushData1(tif)); return (TIFFFlushData1(tif));
} }
/* vim: set ts=8 sts=8 sw=8 noet: */
/* /*
* Local Variables: * Local Variables:
* mode: c * mode: c

View File

@ -1,4 +1,4 @@
/* $Id: tif_getimage.c,v 1.63.2.4 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_getimage.c,v 1.78 2011-02-23 21:46:09 fwarmerdam Exp $ */
/* /*
* Copyright (c) 1991-1997 Sam Leffler * Copyright (c) 1991-1997 Sam Leffler
@ -38,6 +38,10 @@ static int gtStripContig(TIFFRGBAImage*, uint32*, uint32, uint32);
static int gtStripSeparate(TIFFRGBAImage*, uint32*, uint32, uint32); static int gtStripSeparate(TIFFRGBAImage*, uint32*, uint32, uint32);
static int PickContigCase(TIFFRGBAImage*); static int PickContigCase(TIFFRGBAImage*);
static int PickSeparateCase(TIFFRGBAImage*); static int PickSeparateCase(TIFFRGBAImage*);
static int BuildMapUaToAa(TIFFRGBAImage* img);
static int BuildMapBitdepth16To8(TIFFRGBAImage* img);
static const char photoTag[] = "PhotometricInterpretation"; static const char photoTag[] = "PhotometricInterpretation";
/* /*
@ -50,7 +54,7 @@ static const char photoTag[] = "PhotometricInterpretation";
* Color conversion constants. We will define display types here. * Color conversion constants. We will define display types here.
*/ */
TIFFDisplay display_sRGB = { static const TIFFDisplay display_sRGB = {
{ /* XYZ -> luminance matrix */ { /* XYZ -> luminance matrix */
{ 3.2410F, -1.5374F, -0.4986F }, { 3.2410F, -1.5374F, -0.4986F },
{ -0.9692F, 1.8760F, 0.0416F }, { -0.9692F, 1.8760F, 0.0416F },
@ -202,10 +206,16 @@ TIFFRGBAImageEnd(TIFFRGBAImage* img)
_TIFFfree(img->ycbcr), img->ycbcr = NULL; _TIFFfree(img->ycbcr), img->ycbcr = NULL;
if (img->cielab) if (img->cielab)
_TIFFfree(img->cielab), img->cielab = NULL; _TIFFfree(img->cielab), img->cielab = NULL;
if (img->UaToAa)
_TIFFfree(img->UaToAa), img->UaToAa = NULL;
if (img->Bitdepth16To8)
_TIFFfree(img->Bitdepth16To8), img->Bitdepth16To8 = NULL;
if( img->redcmap ) { if( img->redcmap ) {
_TIFFfree( img->redcmap ); _TIFFfree( img->redcmap );
_TIFFfree( img->greencmap ); _TIFFfree( img->greencmap );
_TIFFfree( img->bluecmap ); _TIFFfree( img->bluecmap );
img->redcmap = img->greencmap = img->bluecmap = NULL;
} }
} }
@ -252,7 +262,7 @@ TIFFRGBAImageBegin(TIFFRGBAImage* img, TIFF* tif, int stop, char emsg[1024])
default: default:
sprintf(emsg, "Sorry, can not handle images with %d-bit samples", sprintf(emsg, "Sorry, can not handle images with %d-bit samples",
img->bitspersample); img->bitspersample);
return (0); goto fail_return;
} }
img->alpha = 0; img->alpha = 0;
TIFFGetFieldDefaulted(tif, TIFFTAG_SAMPLESPERPIXEL, &img->samplesperpixel); TIFFGetFieldDefaulted(tif, TIFFTAG_SAMPLESPERPIXEL, &img->samplesperpixel);
@ -301,7 +311,7 @@ TIFFRGBAImageBegin(TIFFRGBAImage* img, TIFF* tif, int stop, char emsg[1024])
break; break;
default: default:
sprintf(emsg, "Missing needed %s tag", photoTag); sprintf(emsg, "Missing needed %s tag", photoTag);
return (0); goto fail_return;
} }
} }
switch (img->photometric) { switch (img->photometric) {
@ -309,7 +319,7 @@ TIFFRGBAImageBegin(TIFFRGBAImage* img, TIFF* tif, int stop, char emsg[1024])
if (!TIFFGetField(tif, TIFFTAG_COLORMAP, if (!TIFFGetField(tif, TIFFTAG_COLORMAP,
&red_orig, &green_orig, &blue_orig)) { &red_orig, &green_orig, &blue_orig)) {
sprintf(emsg, "Missing required \"Colormap\" tag"); sprintf(emsg, "Missing required \"Colormap\" tag");
return (0); goto fail_return;
} }
/* copy the colormaps so we can modify them */ /* copy the colormaps so we can modify them */
@ -319,7 +329,7 @@ TIFFRGBAImageBegin(TIFFRGBAImage* img, TIFF* tif, int stop, char emsg[1024])
img->bluecmap = (uint16 *) _TIFFmalloc(sizeof(uint16)*n_color); img->bluecmap = (uint16 *) _TIFFmalloc(sizeof(uint16)*n_color);
if( !img->redcmap || !img->greencmap || !img->bluecmap ) { if( !img->redcmap || !img->greencmap || !img->bluecmap ) {
sprintf(emsg, "Out of memory for colormap copy"); sprintf(emsg, "Out of memory for colormap copy");
return (0); goto fail_return;
} }
_TIFFmemcpy( img->redcmap, red_orig, n_color * 2 ); _TIFFmemcpy( img->redcmap, red_orig, n_color * 2 );
@ -338,7 +348,7 @@ TIFFRGBAImageBegin(TIFFRGBAImage* img, TIFF* tif, int stop, char emsg[1024])
photoTag, img->photometric, photoTag, img->photometric,
"Samples/pixel", img->samplesperpixel, "Samples/pixel", img->samplesperpixel,
img->bitspersample); img->bitspersample);
return (0); goto fail_return;
} }
break; break;
case PHOTOMETRIC_YCBCR: case PHOTOMETRIC_YCBCR:
@ -371,7 +381,7 @@ TIFFRGBAImageBegin(TIFFRGBAImage* img, TIFF* tif, int stop, char emsg[1024])
if (colorchannels < 3) { if (colorchannels < 3) {
sprintf(emsg, "Sorry, can not handle RGB image with %s=%d", sprintf(emsg, "Sorry, can not handle RGB image with %s=%d",
"Color channels", colorchannels); "Color channels", colorchannels);
return (0); goto fail_return;
} }
break; break;
case PHOTOMETRIC_SEPARATED: case PHOTOMETRIC_SEPARATED:
@ -381,12 +391,12 @@ TIFFRGBAImageBegin(TIFFRGBAImage* img, TIFF* tif, int stop, char emsg[1024])
if (inkset != INKSET_CMYK) { if (inkset != INKSET_CMYK) {
sprintf(emsg, "Sorry, can not handle separated image with %s=%d", sprintf(emsg, "Sorry, can not handle separated image with %s=%d",
"InkSet", inkset); "InkSet", inkset);
return (0); goto fail_return;
} }
if (img->samplesperpixel < 4) { if (img->samplesperpixel < 4) {
sprintf(emsg, "Sorry, can not handle separated image with %s=%d", sprintf(emsg, "Sorry, can not handle separated image with %s=%d",
"Samples/pixel", img->samplesperpixel); "Samples/pixel", img->samplesperpixel);
return (0); goto fail_return;
} }
} }
break; break;
@ -394,7 +404,7 @@ TIFFRGBAImageBegin(TIFFRGBAImage* img, TIFF* tif, int stop, char emsg[1024])
if (compress != COMPRESSION_SGILOG) { if (compress != COMPRESSION_SGILOG) {
sprintf(emsg, "Sorry, LogL data must have %s=%d", sprintf(emsg, "Sorry, LogL data must have %s=%d",
"Compression", COMPRESSION_SGILOG); "Compression", COMPRESSION_SGILOG);
return (0); goto fail_return;
} }
TIFFSetField(tif, TIFFTAG_SGILOGDATAFMT, SGILOGDATAFMT_8BIT); TIFFSetField(tif, TIFFTAG_SGILOGDATAFMT, SGILOGDATAFMT_8BIT);
img->photometric = PHOTOMETRIC_MINISBLACK; /* little white lie */ img->photometric = PHOTOMETRIC_MINISBLACK; /* little white lie */
@ -404,7 +414,7 @@ TIFFRGBAImageBegin(TIFFRGBAImage* img, TIFF* tif, int stop, char emsg[1024])
if (compress != COMPRESSION_SGILOG && compress != COMPRESSION_SGILOG24) { if (compress != COMPRESSION_SGILOG && compress != COMPRESSION_SGILOG24) {
sprintf(emsg, "Sorry, LogLuv data must have %s=%d or %d", sprintf(emsg, "Sorry, LogLuv data must have %s=%d or %d",
"Compression", COMPRESSION_SGILOG, COMPRESSION_SGILOG24); "Compression", COMPRESSION_SGILOG, COMPRESSION_SGILOG24);
return (0); goto fail_return;
} }
if (planarconfig != PLANARCONFIG_CONTIG) { if (planarconfig != PLANARCONFIG_CONTIG) {
sprintf(emsg, "Sorry, can not handle LogLuv images with %s=%d", sprintf(emsg, "Sorry, can not handle LogLuv images with %s=%d",
@ -420,30 +430,39 @@ TIFFRGBAImageBegin(TIFFRGBAImage* img, TIFF* tif, int stop, char emsg[1024])
default: default:
sprintf(emsg, "Sorry, can not handle image with %s=%d", sprintf(emsg, "Sorry, can not handle image with %s=%d",
photoTag, img->photometric); photoTag, img->photometric);
return (0); goto fail_return;
} }
img->Map = NULL; img->Map = NULL;
img->BWmap = NULL; img->BWmap = NULL;
img->PALmap = NULL; img->PALmap = NULL;
img->ycbcr = NULL; img->ycbcr = NULL;
img->cielab = NULL; img->cielab = NULL;
img->UaToAa = NULL;
img->Bitdepth16To8 = NULL;
TIFFGetField(tif, TIFFTAG_IMAGEWIDTH, &img->width); TIFFGetField(tif, TIFFTAG_IMAGEWIDTH, &img->width);
TIFFGetField(tif, TIFFTAG_IMAGELENGTH, &img->height); TIFFGetField(tif, TIFFTAG_IMAGELENGTH, &img->height);
TIFFGetFieldDefaulted(tif, TIFFTAG_ORIENTATION, &img->orientation); TIFFGetFieldDefaulted(tif, TIFFTAG_ORIENTATION, &img->orientation);
img->isContig = img->isContig =
!(planarconfig == PLANARCONFIG_SEPARATE && colorchannels > 1); !(planarconfig == PLANARCONFIG_SEPARATE && img->samplesperpixel > 1);
if (img->isContig) { if (img->isContig) {
if (!PickContigCase(img)) { if (!PickContigCase(img)) {
sprintf(emsg, "Sorry, can not handle image"); sprintf(emsg, "Sorry, can not handle image");
return 0; goto fail_return;
} }
} else { } else {
if (!PickSeparateCase(img)) { if (!PickSeparateCase(img)) {
sprintf(emsg, "Sorry, can not handle image"); sprintf(emsg, "Sorry, can not handle image");
return 0; goto fail_return;
} }
} }
return 1; return 1;
fail_return:
_TIFFfree( img->redcmap );
_TIFFfree( img->greencmap );
_TIFFfree( img->bluecmap );
img->redcmap = img->greencmap = img->bluecmap = NULL;
return 0;
} }
int int
@ -572,7 +591,7 @@ gtTileContig(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
TIFF* tif = img->tif; TIFF* tif = img->tif;
tileContigRoutine put = img->put.contig; tileContigRoutine put = img->put.contig;
uint32 col, row, y, rowstoread; uint32 col, row, y, rowstoread;
uint32 pos; tmsize_t pos;
uint32 tw, th; uint32 tw, th;
unsigned char* buf; unsigned char* buf;
int32 fromskew, toskew; int32 fromskew, toskew;
@ -581,7 +600,7 @@ gtTileContig(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
buf = (unsigned char*) _TIFFmalloc(TIFFTileSize(tif)); buf = (unsigned char*) _TIFFmalloc(TIFFTileSize(tif));
if (buf == 0) { if (buf == 0) {
TIFFErrorExt(tif->tif_clientdata, TIFFFileName(tif), "No space for tile buffer"); TIFFErrorExt(tif->tif_clientdata, TIFFFileName(tif), "%s", "No space for tile buffer");
return (0); return (0);
} }
_TIFFmemset(buf, 0, TIFFTileSize(tif)); _TIFFmemset(buf, 0, TIFFTileSize(tif));
@ -604,14 +623,14 @@ gtTileContig(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
nrow = (row + rowstoread > h ? h - row : rowstoread); nrow = (row + rowstoread > h ? h - row : rowstoread);
for (col = 0; col < w; col += tw) for (col = 0; col < w; col += tw)
{ {
if (TIFFReadTile(tif, buf, col+img->col_offset, if (TIFFReadTile(tif, buf, col+img->col_offset,
row+img->row_offset, 0, 0) < 0 && img->stoponerr) row+img->row_offset, 0, 0)==(tmsize_t)(-1) && img->stoponerr)
{ {
ret = 0; ret = 0;
break; break;
} }
pos = ((row+img->row_offset) % th) * TIFFTileRowSize(tif); pos = ((row+img->row_offset) % th) * TIFFTileRowSize(tif);
if (col + tw > w) if (col + tw > w)
{ {
@ -665,23 +684,24 @@ gtTileSeparate(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
TIFF* tif = img->tif; TIFF* tif = img->tif;
tileSeparateRoutine put = img->put.separate; tileSeparateRoutine put = img->put.separate;
uint32 col, row, y, rowstoread; uint32 col, row, y, rowstoread;
uint32 pos; tmsize_t pos;
uint32 tw, th; uint32 tw, th;
unsigned char* buf; unsigned char* buf;
unsigned char* p0; unsigned char* p0;
unsigned char* p1; unsigned char* p1;
unsigned char* p2; unsigned char* p2;
unsigned char* pa; unsigned char* pa;
tsize_t tilesize; tmsize_t tilesize;
int32 fromskew, toskew; int32 fromskew, toskew;
int alpha = img->alpha; int alpha = img->alpha;
uint32 nrow; uint32 nrow;
int ret = 1, flip; int ret = 1, flip;
int colorchannels;
tilesize = TIFFTileSize(tif); tilesize = TIFFTileSize(tif);
buf = (unsigned char*) _TIFFmalloc((alpha?4:3)*tilesize); buf = (unsigned char*) _TIFFmalloc((alpha?4:3)*tilesize);
if (buf == 0) { if (buf == 0) {
TIFFErrorExt(tif->tif_clientdata, TIFFFileName(tif), "No space for tile buffer"); TIFFErrorExt(tif->tif_clientdata, TIFFFileName(tif), "%s", "No space for tile buffer");
return (0); return (0);
} }
_TIFFmemset(buf, 0, (alpha?4:3)*tilesize); _TIFFmemset(buf, 0, (alpha?4:3)*tilesize);
@ -702,41 +722,58 @@ gtTileSeparate(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
toskew = -(int32)(tw - w); toskew = -(int32)(tw - w);
} }
switch( img->photometric )
{
case PHOTOMETRIC_MINISWHITE:
case PHOTOMETRIC_MINISBLACK:
case PHOTOMETRIC_PALETTE:
colorchannels = 1;
p2 = p1 = p0;
break;
default:
colorchannels = 3;
break;
}
for (row = 0; row < h; row += nrow) for (row = 0; row < h; row += nrow)
{ {
rowstoread = th - (row + img->row_offset) % th; rowstoread = th - (row + img->row_offset) % th;
nrow = (row + rowstoread > h ? h - row : rowstoread); nrow = (row + rowstoread > h ? h - row : rowstoread);
for (col = 0; col < w; col += tw) for (col = 0; col < w; col += tw)
{ {
if (TIFFReadTile(tif, p0, col+img->col_offset, if (TIFFReadTile(tif, p0, col+img->col_offset,
row+img->row_offset,0,0) < 0 && img->stoponerr) row+img->row_offset,0,0)==(tmsize_t)(-1) && img->stoponerr)
{ {
ret = 0; ret = 0;
break; break;
} }
if (TIFFReadTile(tif, p1, col+img->col_offset, if (colorchannels > 1
row+img->row_offset,0,1) < 0 && img->stoponerr) && TIFFReadTile(tif, p1, col+img->col_offset,
row+img->row_offset,0,1) == (tmsize_t)(-1)
&& img->stoponerr)
{ {
ret = 0; ret = 0;
break; break;
} }
if (TIFFReadTile(tif, p2, col+img->col_offset, if (colorchannels > 1
row+img->row_offset,0,2) < 0 && img->stoponerr) && TIFFReadTile(tif, p2, col+img->col_offset,
row+img->row_offset,0,2) == (tmsize_t)(-1)
&& img->stoponerr)
{ {
ret = 0; ret = 0;
break; break;
} }
if (alpha) if (alpha
{ && TIFFReadTile(tif,pa,col+img->col_offset,
if (TIFFReadTile(tif,pa,col+img->col_offset, row+img->row_offset,0,colorchannels) == (tmsize_t)(-1)
row+img->row_offset,0,3) < 0 && img->stoponerr) && img->stoponerr)
{ {
ret = 0; ret = 0;
break; break;
}
} }
pos = ((row+img->row_offset) % th) * TIFFTileRowSize(tif); pos = ((row+img->row_offset) % th) * TIFFTileRowSize(tif);
if (col + tw > w) if (col + tw > w)
{ {
@ -790,12 +827,12 @@ gtStripContig(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
TIFF* tif = img->tif; TIFF* tif = img->tif;
tileContigRoutine put = img->put.contig; tileContigRoutine put = img->put.contig;
uint32 row, y, nrow, nrowsub, rowstoread; uint32 row, y, nrow, nrowsub, rowstoread;
uint32 pos; tmsize_t pos;
unsigned char* buf; unsigned char* buf;
uint32 rowsperstrip; uint32 rowsperstrip;
uint16 subsamplinghor,subsamplingver; uint16 subsamplinghor,subsamplingver;
uint32 imagewidth = img->width; uint32 imagewidth = img->width;
tsize_t scanline; tmsize_t scanline;
int32 fromskew, toskew; int32 fromskew, toskew;
int ret = 1, flip; int ret = 1, flip;
@ -817,7 +854,7 @@ gtStripContig(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
TIFFGetFieldDefaulted(tif, TIFFTAG_ROWSPERSTRIP, &rowsperstrip); TIFFGetFieldDefaulted(tif, TIFFTAG_ROWSPERSTRIP, &rowsperstrip);
TIFFGetFieldDefaulted(tif, TIFFTAG_YCBCRSUBSAMPLING, &subsamplinghor, &subsamplingver); TIFFGetFieldDefaulted(tif, TIFFTAG_YCBCRSUBSAMPLING, &subsamplinghor, &subsamplingver);
scanline = TIFFNewScanlineSize(tif); scanline = TIFFScanlineSize(tif);
fromskew = (w < imagewidth ? imagewidth - w : 0); fromskew = (w < imagewidth ? imagewidth - w : 0);
for (row = 0; row < h; row += nrow) for (row = 0; row < h; row += nrow)
{ {
@ -829,7 +866,7 @@ gtStripContig(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
if (TIFFReadEncodedStrip(tif, if (TIFFReadEncodedStrip(tif,
TIFFComputeStrip(tif,row+img->row_offset, 0), TIFFComputeStrip(tif,row+img->row_offset, 0),
buf, buf,
((row + img->row_offset)%rowsperstrip + nrowsub) * scanline) < 0 ((row + img->row_offset)%rowsperstrip + nrowsub) * scanline)==(tmsize_t)(-1)
&& img->stoponerr) && img->stoponerr)
{ {
ret = 0; ret = 0;
@ -875,16 +912,16 @@ gtStripSeparate(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
unsigned char *buf; unsigned char *buf;
unsigned char *p0, *p1, *p2, *pa; unsigned char *p0, *p1, *p2, *pa;
uint32 row, y, nrow, rowstoread; uint32 row, y, nrow, rowstoread;
uint32 pos; tmsize_t pos;
tsize_t scanline; tmsize_t scanline;
uint32 rowsperstrip, offset_row; uint32 rowsperstrip, offset_row;
uint32 imagewidth = img->width; uint32 imagewidth = img->width;
tsize_t stripsize; tmsize_t stripsize;
int32 fromskew, toskew; int32 fromskew, toskew;
int alpha = img->alpha; int alpha = img->alpha;
int ret = 1, flip; int ret = 1, flip, colorchannels;
stripsize = TIFFStripSize(tif); stripsize = TIFFStripSize(tif);
p0 = buf = (unsigned char *)_TIFFmalloc((alpha?4:3)*stripsize); p0 = buf = (unsigned char *)_TIFFmalloc((alpha?4:3)*stripsize);
if (buf == 0) { if (buf == 0) {
TIFFErrorExt(tif->tif_clientdata, TIFFFileName(tif), "No space for tile buffer"); TIFFErrorExt(tif->tif_clientdata, TIFFFileName(tif), "No space for tile buffer");
@ -905,8 +942,22 @@ gtStripSeparate(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
toskew = -(int32)(w - w); toskew = -(int32)(w - w);
} }
switch( img->photometric )
{
case PHOTOMETRIC_MINISWHITE:
case PHOTOMETRIC_MINISBLACK:
case PHOTOMETRIC_PALETTE:
colorchannels = 1;
p2 = p1 = p0;
break;
default:
colorchannels = 3;
break;
}
TIFFGetFieldDefaulted(tif, TIFFTAG_ROWSPERSTRIP, &rowsperstrip); TIFFGetFieldDefaulted(tif, TIFFTAG_ROWSPERSTRIP, &rowsperstrip);
scanline = TIFFScanlineSize(tif); scanline = TIFFScanlineSize(tif);
fromskew = (w < imagewidth ? imagewidth - w : 0); fromskew = (w < imagewidth ? imagewidth - w : 0);
for (row = 0; row < h; row += nrow) for (row = 0; row < h; row += nrow)
{ {
@ -914,21 +965,23 @@ gtStripSeparate(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
nrow = (row + rowstoread > h ? h - row : rowstoread); nrow = (row + rowstoread > h ? h - row : rowstoread);
offset_row = row + img->row_offset; offset_row = row + img->row_offset;
if (TIFFReadEncodedStrip(tif, TIFFComputeStrip(tif, offset_row, 0), if (TIFFReadEncodedStrip(tif, TIFFComputeStrip(tif, offset_row, 0),
p0, ((row + img->row_offset)%rowsperstrip + nrow) * scanline) < 0 p0, ((row + img->row_offset)%rowsperstrip + nrow) * scanline)==(tmsize_t)(-1)
&& img->stoponerr) && img->stoponerr)
{ {
ret = 0; ret = 0;
break; break;
} }
if (TIFFReadEncodedStrip(tif, TIFFComputeStrip(tif, offset_row, 1), if (colorchannels > 1
p1, ((row + img->row_offset)%rowsperstrip + nrow) * scanline) < 0 && TIFFReadEncodedStrip(tif, TIFFComputeStrip(tif, offset_row, 1),
p1, ((row + img->row_offset)%rowsperstrip + nrow) * scanline) == (tmsize_t)(-1)
&& img->stoponerr) && img->stoponerr)
{ {
ret = 0; ret = 0;
break; break;
} }
if (TIFFReadEncodedStrip(tif, TIFFComputeStrip(tif, offset_row, 2), if (colorchannels > 1
p2, ((row + img->row_offset)%rowsperstrip + nrow) * scanline) < 0 && TIFFReadEncodedStrip(tif, TIFFComputeStrip(tif, offset_row, 2),
p2, ((row + img->row_offset)%rowsperstrip + nrow) * scanline) == (tmsize_t)(-1)
&& img->stoponerr) && img->stoponerr)
{ {
ret = 0; ret = 0;
@ -936,8 +989,8 @@ gtStripSeparate(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
} }
if (alpha) if (alpha)
{ {
if (TIFFReadEncodedStrip(tif, TIFFComputeStrip(tif, offset_row, 3), if (TIFFReadEncodedStrip(tif, TIFFComputeStrip(tif, offset_row, colorchannels),
pa, ((row + img->row_offset)%rowsperstrip + nrow) * scanline) < 0 pa, ((row + img->row_offset)%rowsperstrip + nrow) * scanline)==(tmsize_t)(-1)
&& img->stoponerr) && img->stoponerr)
{ {
ret = 0; ret = 0;
@ -1036,6 +1089,7 @@ gtStripSeparate(TIFFRGBAImage* img, uint32* raster, uint32 w, uint32 h)
#define PACK4(r,g,b,a) \ #define PACK4(r,g,b,a) \
((uint32)(r)|((uint32)(g)<<8)|((uint32)(b)<<16)|((uint32)(a)<<24)) ((uint32)(r)|((uint32)(g)<<8)|((uint32)(b)<<16)|((uint32)(a)<<24))
#define W2B(v) (((v)>>8)&0xff) #define W2B(v) (((v)>>8)&0xff)
/* TODO: PACKW should have be made redundant in favor of Bitdepth16To8 LUT */
#define PACKW(r,g,b) \ #define PACKW(r,g,b) \
((uint32)W2B(r)|((uint32)W2B(g)<<8)|((uint32)W2B(b)<<16)|A1) ((uint32)W2B(r)|((uint32)W2B(g)<<8)|((uint32)W2B(b)<<16)|A1)
#define PACKW4(r,g,b,a) \ #define PACKW4(r,g,b,a) \
@ -1266,11 +1320,13 @@ DECLAREContigPutFunc(putRGBUAcontig8bittile)
fromskew *= samplesperpixel; fromskew *= samplesperpixel;
while (h-- > 0) { while (h-- > 0) {
uint32 r, g, b, a; uint32 r, g, b, a;
uint8* m;
for (x = w; x-- > 0;) { for (x = w; x-- > 0;) {
a = pp[3]; a = pp[3];
r = (a*pp[0] + 127) / 255; m = img->UaToAa+(a<<8);
g = (a*pp[1] + 127) / 255; r = m[pp[0]];
b = (a*pp[2] + 127) / 255; g = m[pp[1]];
b = m[pp[2]];
*cp++ = PACK4(r,g,b,a); *cp++ = PACK4(r,g,b,a);
pp += samplesperpixel; pp += samplesperpixel;
} }
@ -1290,8 +1346,10 @@ DECLAREContigPutFunc(putRGBcontig16bittile)
fromskew *= samplesperpixel; fromskew *= samplesperpixel;
while (h-- > 0) { while (h-- > 0) {
for (x = w; x-- > 0;) { for (x = w; x-- > 0;) {
*cp++ = PACKW(wp[0],wp[1],wp[2]); *cp++ = PACK(img->Bitdepth16To8[wp[0]],
wp += samplesperpixel; img->Bitdepth16To8[wp[1]],
img->Bitdepth16To8[wp[2]]);
wp += samplesperpixel;
} }
cp += toskew; cp += toskew;
wp += fromskew; wp += fromskew;
@ -1310,8 +1368,11 @@ DECLAREContigPutFunc(putRGBAAcontig16bittile)
fromskew *= samplesperpixel; fromskew *= samplesperpixel;
while (h-- > 0) { while (h-- > 0) {
for (x = w; x-- > 0;) { for (x = w; x-- > 0;) {
*cp++ = PACKW4(wp[0],wp[1],wp[2],wp[3]); *cp++ = PACK4(img->Bitdepth16To8[wp[0]],
wp += samplesperpixel; img->Bitdepth16To8[wp[1]],
img->Bitdepth16To8[wp[2]],
img->Bitdepth16To8[wp[3]]);
wp += samplesperpixel;
} }
cp += toskew; cp += toskew;
wp += fromskew; wp += fromskew;
@ -1330,13 +1391,15 @@ DECLAREContigPutFunc(putRGBUAcontig16bittile)
fromskew *= samplesperpixel; fromskew *= samplesperpixel;
while (h-- > 0) { while (h-- > 0) {
uint32 r,g,b,a; uint32 r,g,b,a;
uint8* m;
for (x = w; x-- > 0;) { for (x = w; x-- > 0;) {
a = W2B(wp[3]); a = img->Bitdepth16To8[wp[3]];
r = (a*W2B(wp[0]) + 127) / 255; m = img->UaToAa+(a<<8);
g = (a*W2B(wp[1]) + 127) / 255; r = m[img->Bitdepth16To8[wp[0]]];
b = (a*W2B(wp[2]) + 127) / 255; g = m[img->Bitdepth16To8[wp[1]]];
*cp++ = PACK4(r,g,b,a); b = m[img->Bitdepth16To8[wp[2]]];
wp += samplesperpixel; *cp++ = PACK4(r,g,b,a);
wp += samplesperpixel;
} }
cp += toskew; cp += toskew;
wp += fromskew; wp += fromskew;
@ -1423,7 +1486,7 @@ DECLARESepPutFunc(putRGBseparate8bittile)
*/ */
DECLARESepPutFunc(putRGBAAseparate8bittile) DECLARESepPutFunc(putRGBAAseparate8bittile)
{ {
(void) img; (void) x; (void) y; (void) img; (void) x; (void) y;
while (h-- > 0) { while (h-- > 0) {
UNROLL8(w, NOP, *cp++ = PACK4(*r++, *g++, *b++, *a++)); UNROLL8(w, NOP, *cp++ = PACK4(*r++, *g++, *b++, *a++));
SKEW4(r, g, b, a, fromskew); SKEW4(r, g, b, a, fromskew);
@ -1439,11 +1502,13 @@ DECLARESepPutFunc(putRGBUAseparate8bittile)
(void) img; (void) y; (void) img; (void) y;
while (h-- > 0) { while (h-- > 0) {
uint32 rv, gv, bv, av; uint32 rv, gv, bv, av;
uint8* m;
for (x = w; x-- > 0;) { for (x = w; x-- > 0;) {
av = *a++; av = *a++;
rv = (av* *r++ + 127) / 255; m = img->UaToAa+(av<<8);
gv = (av* *g++ + 127) / 255; rv = m[*r++];
bv = (av* *b++ + 127) / 255; gv = m[*g++];
bv = m[*b++];
*cp++ = PACK4(rv,gv,bv,av); *cp++ = PACK4(rv,gv,bv,av);
} }
SKEW4(r, g, b, a, fromskew); SKEW4(r, g, b, a, fromskew);
@ -1462,7 +1527,9 @@ DECLARESepPutFunc(putRGBseparate16bittile)
(void) img; (void) y; (void) a; (void) img; (void) y; (void) a;
while (h-- > 0) { while (h-- > 0) {
for (x = 0; x < w; x++) for (x = 0; x < w; x++)
*cp++ = PACKW(*wr++,*wg++,*wb++); *cp++ = PACK(img->Bitdepth16To8[*wr++],
img->Bitdepth16To8[*wg++],
img->Bitdepth16To8[*wb++]);
SKEW(wr, wg, wb, fromskew); SKEW(wr, wg, wb, fromskew);
cp += toskew; cp += toskew;
} }
@ -1480,7 +1547,10 @@ DECLARESepPutFunc(putRGBAAseparate16bittile)
(void) img; (void) y; (void) img; (void) y;
while (h-- > 0) { while (h-- > 0) {
for (x = 0; x < w; x++) for (x = 0; x < w; x++)
*cp++ = PACKW4(*wr++,*wg++,*wb++,*wa++); *cp++ = PACK4(img->Bitdepth16To8[*wr++],
img->Bitdepth16To8[*wg++],
img->Bitdepth16To8[*wb++],
img->Bitdepth16To8[*wa++]);
SKEW4(wr, wg, wb, wa, fromskew); SKEW4(wr, wg, wb, wa, fromskew);
cp += toskew; cp += toskew;
} }
@ -1498,12 +1568,14 @@ DECLARESepPutFunc(putRGBUAseparate16bittile)
(void) img; (void) y; (void) img; (void) y;
while (h-- > 0) { while (h-- > 0) {
uint32 r,g,b,a; uint32 r,g,b,a;
uint8* m;
for (x = w; x-- > 0;) { for (x = w; x-- > 0;) {
a = W2B(*wa++); a = img->Bitdepth16To8[*wa++];
r = (a*W2B(*wr++) + 127) / 255; m = img->UaToAa+(a<<8);
g = (a*W2B(*wg++) + 127) / 255; r = m[img->Bitdepth16To8[*wr++]];
b = (a*W2B(*wb++) + 127) / 255; g = m[img->Bitdepth16To8[*wg++]];
*cp++ = PACK4(r,g,b,a); b = m[img->Bitdepth16To8[*wb++]];
*cp++ = PACK4(r,g,b,a);
} }
SKEW4(wr, wg, wb, wa, fromskew); SKEW4(wr, wg, wb, wa, fromskew);
cp += toskew; cp += toskew;
@ -1846,6 +1918,7 @@ DECLAREContigPutFunc(putcontig8bitYCbCr41tile)
DECLAREContigPutFunc(putcontig8bitYCbCr22tile) DECLAREContigPutFunc(putcontig8bitYCbCr22tile)
{ {
uint32* cp2; uint32* cp2;
int32 incr = 2*toskew+w;
(void) y; (void) y;
fromskew = (fromskew / 2) * 6; fromskew = (fromskew / 2) * 6;
cp2 = cp+w+toskew; cp2 = cp+w+toskew;
@ -1872,8 +1945,8 @@ DECLAREContigPutFunc(putcontig8bitYCbCr22tile)
cp2 ++ ; cp2 ++ ;
pp += 6; pp += 6;
} }
cp += toskew*2+w; cp += incr;
cp2 += toskew*2+w; cp2 += incr;
pp += fromskew; pp += fromskew;
h-=2; h-=2;
} }
@ -1939,6 +2012,7 @@ DECLAREContigPutFunc(putcontig8bitYCbCr21tile)
DECLAREContigPutFunc(putcontig8bitYCbCr12tile) DECLAREContigPutFunc(putcontig8bitYCbCr12tile)
{ {
uint32* cp2; uint32* cp2;
int32 incr = 2*toskew+w;
(void) y; (void) y;
fromskew = (fromskew / 2) * 4; fromskew = (fromskew / 2) * 4;
cp2 = cp+w+toskew; cp2 = cp+w+toskew;
@ -1953,8 +2027,8 @@ DECLAREContigPutFunc(putcontig8bitYCbCr12tile)
cp2 ++; cp2 ++;
pp += 4; pp += 4;
} while (--x); } while (--x);
cp += toskew*2+w; cp += incr;
cp2 += toskew*2+w; cp2 += incr;
pp += fromskew; pp += fromskew;
h-=2; h-=2;
} }
@ -2016,13 +2090,13 @@ DECLARESepPutFunc(putseparate8bitYCbCr11tile)
static int static int
initYCbCrConversion(TIFFRGBAImage* img) initYCbCrConversion(TIFFRGBAImage* img)
{ {
static char module[] = "initYCbCrConversion"; static const char module[] = "initYCbCrConversion";
float *luma, *refBlackWhite; float *luma, *refBlackWhite;
if (img->ycbcr == NULL) { if (img->ycbcr == NULL) {
img->ycbcr = (TIFFYCbCrToRGB*) _TIFFmalloc( img->ycbcr = (TIFFYCbCrToRGB*) _TIFFmalloc(
TIFFroundup(sizeof (TIFFYCbCrToRGB), sizeof (long)) TIFFroundup_32(sizeof (TIFFYCbCrToRGB), sizeof (long))
+ 4*256*sizeof (TIFFRGBValue) + 4*256*sizeof (TIFFRGBValue)
+ 2*256*sizeof (int) + 2*256*sizeof (int)
+ 3*256*sizeof (int32) + 3*256*sizeof (int32)
@ -2045,7 +2119,7 @@ initYCbCrConversion(TIFFRGBAImage* img)
static tileContigRoutine static tileContigRoutine
initCIELabConversion(TIFFRGBAImage* img) initCIELabConversion(TIFFRGBAImage* img)
{ {
static char module[] = "initCIELabConversion"; static const char module[] = "initCIELabConversion";
float *whitePoint; float *whitePoint;
float refWhite[3]; float refWhite[3];
@ -2325,23 +2399,28 @@ PickContigCase(TIFFRGBAImage* img)
img->put.contig = putRGBAAcontig8bittile; img->put.contig = putRGBAAcontig8bittile;
else if (img->alpha == EXTRASAMPLE_UNASSALPHA) else if (img->alpha == EXTRASAMPLE_UNASSALPHA)
{ {
img->put.contig = putRGBUAcontig8bittile; if (BuildMapUaToAa(img))
img->put.contig = putRGBUAcontig8bittile;
} }
else else
img->put.contig = putRGBcontig8bittile; img->put.contig = putRGBcontig8bittile;
break; break;
case 16: case 16:
if (img->alpha == EXTRASAMPLE_ASSOCALPHA) if (img->alpha == EXTRASAMPLE_ASSOCALPHA)
{ {
img->put.contig = putRGBAAcontig16bittile; if (BuildMapBitdepth16To8(img))
img->put.contig = putRGBAAcontig16bittile;
} }
else if (img->alpha == EXTRASAMPLE_UNASSALPHA) else if (img->alpha == EXTRASAMPLE_UNASSALPHA)
{ {
img->put.contig = putRGBUAcontig16bittile; if (BuildMapBitdepth16To8(img) &&
BuildMapUaToAa(img))
img->put.contig = putRGBUAcontig16bittile;
} }
else else
{ {
img->put.contig = putRGBcontig16bittile; if (BuildMapBitdepth16To8(img))
img->put.contig = putRGBcontig16bittile;
} }
break; break;
} }
@ -2397,7 +2476,7 @@ PickContigCase(TIFFRGBAImage* img)
} }
break; break;
case PHOTOMETRIC_YCBCR: case PHOTOMETRIC_YCBCR:
if (img->bitspersample == 8) if ((img->bitspersample==8) && (img->samplesperpixel==3))
{ {
if (initYCbCrConversion(img)!=0) if (initYCbCrConversion(img)!=0)
{ {
@ -2461,6 +2540,9 @@ PickSeparateCase(TIFFRGBAImage* img)
img->get = TIFFIsTiled(img->tif) ? gtTileSeparate : gtStripSeparate; img->get = TIFFIsTiled(img->tif) ? gtTileSeparate : gtStripSeparate;
img->put.separate = NULL; img->put.separate = NULL;
switch (img->photometric) { switch (img->photometric) {
case PHOTOMETRIC_MINISWHITE:
case PHOTOMETRIC_MINISBLACK:
/* greyscale images processed pretty much as RGB by gtTileSeparate */
case PHOTOMETRIC_RGB: case PHOTOMETRIC_RGB:
switch (img->bitspersample) { switch (img->bitspersample) {
case 8: case 8:
@ -2468,7 +2550,8 @@ PickSeparateCase(TIFFRGBAImage* img)
img->put.separate = putRGBAAseparate8bittile; img->put.separate = putRGBAAseparate8bittile;
else if (img->alpha == EXTRASAMPLE_UNASSALPHA) else if (img->alpha == EXTRASAMPLE_UNASSALPHA)
{ {
img->put.separate = putRGBUAseparate8bittile; if (BuildMapUaToAa(img))
img->put.separate = putRGBUAseparate8bittile;
} }
else else
img->put.separate = putRGBseparate8bittile; img->put.separate = putRGBseparate8bittile;
@ -2476,15 +2559,19 @@ PickSeparateCase(TIFFRGBAImage* img)
case 16: case 16:
if (img->alpha == EXTRASAMPLE_ASSOCALPHA) if (img->alpha == EXTRASAMPLE_ASSOCALPHA)
{ {
img->put.separate = putRGBAAseparate16bittile; if (BuildMapBitdepth16To8(img))
img->put.separate = putRGBAAseparate16bittile;
} }
else if (img->alpha == EXTRASAMPLE_UNASSALPHA) else if (img->alpha == EXTRASAMPLE_UNASSALPHA)
{ {
img->put.separate = putRGBUAseparate16bittile; if (BuildMapBitdepth16To8(img) &&
BuildMapUaToAa(img))
img->put.separate = putRGBUAseparate16bittile;
} }
else else
{ {
img->put.separate = putRGBseparate16bittile; if (BuildMapBitdepth16To8(img))
img->put.separate = putRGBseparate16bittile;
} }
break; break;
} }
@ -2509,6 +2596,48 @@ PickSeparateCase(TIFFRGBAImage* img)
return ((img->get!=NULL) && (img->put.separate!=NULL)); return ((img->get!=NULL) && (img->put.separate!=NULL));
} }
static int
BuildMapUaToAa(TIFFRGBAImage* img)
{
static const char module[]="BuildMapUaToAa";
uint8* m;
uint16 na,nv;
assert(img->UaToAa==NULL);
img->UaToAa=_TIFFmalloc(65536);
if (img->UaToAa==NULL)
{
TIFFErrorExt(img->tif->tif_clientdata,module,"Out of memory");
return(0);
}
m=img->UaToAa;
for (na=0; na<256; na++)
{
for (nv=0; nv<256; nv++)
*m++=(nv*na+127)/255;
}
return(1);
}
static int
BuildMapBitdepth16To8(TIFFRGBAImage* img)
{
static const char module[]="BuildMapBitdepth16To8";
uint8* m;
uint32 n;
assert(img->Bitdepth16To8==NULL);
img->Bitdepth16To8=_TIFFmalloc(65536);
if (img->Bitdepth16To8==NULL)
{
TIFFErrorExt(img->tif->tif_clientdata,module,"Out of memory");
return(0);
}
m=img->Bitdepth16To8;
for (n=0; n<65536; n++)
*m++=(n+128)/257;
return(1);
}
/* /*
* Read a whole strip off data from the file, and convert to RGBA form. * Read a whole strip off data from the file, and convert to RGBA form.
* If this is the last strip, then it will only contain the portion of * If this is the last strip, then it will only contain the portion of

View File

@ -1,26 +1,26 @@
/* $Id: tif_jbig.c,v 1.2.2.3 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_jbig.c,v 1.15 2010-03-10 18:56:48 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
* Copyright (c) 1991-1997 Silicon Graphics, Inc. * Copyright (c) 1991-1997 Silicon Graphics, Inc.
* *
* Permission to use, copy, modify, distribute, and sell this software and * Permission to use, copy, modify, distribute, and sell this software and
* its documentation for any purpose is hereby granted without fee, provided * its documentation for any purpose is hereby granted without fee, provided
* that (i) the above copyright notices and this permission notice appear in * that (i) the above copyright notices and this permission notice appear in
* all copies of the software and related documentation, and (ii) the names of * all copies of the software and related documentation, and (ii) the names of
* Sam Leffler and Silicon Graphics may not be used in any advertising or * Sam Leffler and Silicon Graphics may not be used in any advertising or
* publicity relating to the software without the specific, prior written * publicity relating to the software without the specific, prior written
* permission of Sam Leffler and Silicon Graphics. * permission of Sam Leffler and Silicon Graphics.
* *
* THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND, * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
* EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
* WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
* *
* IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
* ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
* OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
* WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
* LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
* OF THIS SOFTWARE. * OF THIS SOFTWARE.
*/ */
@ -29,7 +29,7 @@
* *
* JBIG Compression Algorithm Support. * JBIG Compression Algorithm Support.
* Contributed by Lee Howard <faxguy@deanox.com> * Contributed by Lee Howard <faxguy@deanox.com>
* *
*/ */
#include "tiffiop.h" #include "tiffiop.h"
@ -37,339 +37,167 @@
#ifdef JBIG_SUPPORT #ifdef JBIG_SUPPORT
#include "jbig.h" #include "jbig.h"
typedef struct
{
uint32 recvparams; /* encoded Class 2 session params */
char* subaddress; /* subaddress string */
uint32 recvtime; /* time spend receiving in seconds */
char* faxdcs; /* encoded fax parameters (DCS, Table 2/T.30) */
TIFFVGetMethod vgetparent;
TIFFVSetMethod vsetparent;
} JBIGState;
#define GetJBIGState(tif) ((JBIGState*)(tif)->tif_data)
#define FIELD_RECVPARAMS (FIELD_CODEC+0)
#define FIELD_SUBADDRESS (FIELD_CODEC+1)
#define FIELD_RECVTIME (FIELD_CODEC+2)
#define FIELD_FAXDCS (FIELD_CODEC+3)
static const TIFFFieldInfo jbigFieldInfo[] =
{
{TIFFTAG_FAXRECVPARAMS, 1, 1, TIFF_LONG, FIELD_RECVPARAMS, TRUE, FALSE, "FaxRecvParams"},
{TIFFTAG_FAXSUBADDRESS, -1, -1, TIFF_ASCII, FIELD_SUBADDRESS, TRUE, FALSE, "FaxSubAddress"},
{TIFFTAG_FAXRECVTIME, 1, 1, TIFF_LONG, FIELD_RECVTIME, TRUE, FALSE, "FaxRecvTime"},
{TIFFTAG_FAXDCS, -1, -1, TIFF_ASCII, FIELD_FAXDCS, TRUE, FALSE, "FaxDcs"},
};
static int JBIGSetupDecode(TIFF* tif) static int JBIGSetupDecode(TIFF* tif)
{ {
if (TIFFNumberOfStrips(tif) != 1) if (TIFFNumberOfStrips(tif) != 1)
{ {
TIFFError("JBIG", "Multistrip images not supported in decoder"); TIFFErrorExt(tif->tif_clientdata, "JBIG", "Multistrip images not supported in decoder");
return 0; return 0;
} }
return 1; return 1;
} }
static int JBIGDecode(TIFF* tif, tidata_t buffer, tsize_t size, tsample_t s) static int JBIGDecode(TIFF* tif, uint8* buffer, tmsize_t size, uint16 s)
{ {
struct jbg_dec_state decoder; struct jbg_dec_state decoder;
int decodeStatus = 0; int decodeStatus = 0;
unsigned char* pImage = NULL; unsigned char* pImage = NULL;
(void) size, (void) s; (void) size, (void) s;
if (isFillOrder(tif, tif->tif_dir.td_fillorder)) if (isFillOrder(tif, tif->tif_dir.td_fillorder))
{ {
TIFFReverseBits(tif->tif_rawdata, tif->tif_rawdatasize); TIFFReverseBits(tif->tif_rawdata, tif->tif_rawdatasize);
} }
jbg_dec_init(&decoder); jbg_dec_init(&decoder);
#if defined(HAVE_JBG_NEWLEN) #if defined(HAVE_JBG_NEWLEN)
jbg_newlen(tif->tif_rawdata, tif->tif_rawdatasize); jbg_newlen(tif->tif_rawdata, (size_t)tif->tif_rawdatasize);
/* /*
* I do not check the return status of jbg_newlen because even if this * I do not check the return status of jbg_newlen because even if this
* function fails it does not necessarily mean that decoding the image * function fails it does not necessarily mean that decoding the image
* will fail. It is generally only needed for received fax images * will fail. It is generally only needed for received fax images
* that do not contain the actual length of the image in the BIE * that do not contain the actual length of the image in the BIE
* header. I do not log when an error occurs because that will cause * header. I do not log when an error occurs because that will cause
* problems when converting JBIG encoded TIFF's to * problems when converting JBIG encoded TIFF's to
* PostScript. As long as the actual image length is contained in the * PostScript. As long as the actual image length is contained in the
* BIE header jbg_dec_in should succeed. * BIE header jbg_dec_in should succeed.
*/ */
#endif /* HAVE_JBG_NEWLEN */ #endif /* HAVE_JBG_NEWLEN */
decodeStatus = jbg_dec_in(&decoder, tif->tif_rawdata, decodeStatus = jbg_dec_in(&decoder, (unsigned char*)tif->tif_rawdata,
tif->tif_rawdatasize, NULL); (size_t)tif->tif_rawdatasize, NULL);
if (JBG_EOK != decodeStatus) if (JBG_EOK != decodeStatus)
{ {
/* /*
* XXX: JBG_EN constant was defined in pre-2.0 releases of the * XXX: JBG_EN constant was defined in pre-2.0 releases of the
* JBIG-KIT. Since the 2.0 the error reporting functions were * JBIG-KIT. Since the 2.0 the error reporting functions were
* changed. We will handle both cases here. * changed. We will handle both cases here.
*/ */
TIFFError("JBIG", "Error (%d) decoding: %s", decodeStatus, TIFFErrorExt(tif->tif_clientdata,
"JBIG", "Error (%d) decoding: %s",
decodeStatus,
#if defined(JBG_EN) #if defined(JBG_EN)
jbg_strerror(decodeStatus, JBG_EN) jbg_strerror(decodeStatus, JBG_EN)
#else #else
jbg_strerror(decodeStatus) jbg_strerror(decodeStatus)
#endif #endif
); );
return 0; return 0;
} }
pImage = jbg_dec_getimage(&decoder, 0); pImage = jbg_dec_getimage(&decoder, 0);
_TIFFmemcpy(buffer, pImage, jbg_dec_getsize(&decoder)); _TIFFmemcpy(buffer, pImage, jbg_dec_getsize(&decoder));
jbg_dec_free(&decoder); jbg_dec_free(&decoder);
return 1; return 1;
} }
static int JBIGSetupEncode(TIFF* tif) static int JBIGSetupEncode(TIFF* tif)
{ {
if (TIFFNumberOfStrips(tif) != 1) if (TIFFNumberOfStrips(tif) != 1)
{ {
TIFFError("JBIG", "Multistrip images not supported in encoder"); TIFFErrorExt(tif->tif_clientdata, "JBIG", "Multistrip images not supported in encoder");
return 0; return 0;
} }
return 1; return 1;
} }
static int JBIGCopyEncodedData(TIFF* tif, tidata_t pp, tsize_t cc, tsample_t s) static int JBIGCopyEncodedData(TIFF* tif, unsigned char* pp, size_t cc, uint16 s)
{ {
(void) s; (void) s;
while (cc > 0) while (cc > 0)
{ {
tsize_t n = cc; tmsize_t n = (tmsize_t)cc;
if (tif->tif_rawcc + n > tif->tif_rawdatasize) if (tif->tif_rawcc + n > tif->tif_rawdatasize)
{ {
n = tif->tif_rawdatasize - tif->tif_rawcc; n = tif->tif_rawdatasize - tif->tif_rawcc;
} }
assert(n > 0); assert(n > 0);
_TIFFmemcpy(tif->tif_rawcp, pp, n); _TIFFmemcpy(tif->tif_rawcp, pp, n);
tif->tif_rawcp += n; tif->tif_rawcp += n;
tif->tif_rawcc += n; tif->tif_rawcc += n;
pp += n; pp += n;
cc -= n; cc -= (size_t)n;
if (tif->tif_rawcc >= tif->tif_rawdatasize && if (tif->tif_rawcc >= tif->tif_rawdatasize &&
!TIFFFlushData1(tif)) !TIFFFlushData1(tif))
{ {
return (-1); return (-1);
} }
} }
return (1); return (1);
} }
static void JBIGOutputBie(unsigned char* buffer, size_t len, void *userData) static void JBIGOutputBie(unsigned char* buffer, size_t len, void* userData)
{ {
TIFF* tif = (TIFF*)userData; TIFF* tif = (TIFF*)userData;
if (isFillOrder(tif, tif->tif_dir.td_fillorder)) if (isFillOrder(tif, tif->tif_dir.td_fillorder))
{ {
TIFFReverseBits(buffer, len); TIFFReverseBits(buffer, (tmsize_t)len);
} }
JBIGCopyEncodedData(tif, buffer, len, 0); JBIGCopyEncodedData(tif, buffer, len, 0);
} }
static int JBIGEncode(TIFF* tif, tidata_t buffer, tsize_t size, tsample_t s) static int JBIGEncode(TIFF* tif, uint8* buffer, tmsize_t size, uint16 s)
{ {
TIFFDirectory* dir = &tif->tif_dir; TIFFDirectory* dir = &tif->tif_dir;
struct jbg_enc_state encoder; struct jbg_enc_state encoder;
(void) size, (void) s; (void) size, (void) s;
jbg_enc_init(&encoder, jbg_enc_init(&encoder,
dir->td_imagewidth, dir->td_imagewidth,
dir->td_imagelength, dir->td_imagelength,
1, 1,
&buffer, &buffer,
JBIGOutputBie, JBIGOutputBie,
tif); tif);
/* /*
* jbg_enc_out does the "real" encoding. As data is encoded, * jbg_enc_out does the "real" encoding. As data is encoded,
* JBIGOutputBie is called, which writes the data to the directory. * JBIGOutputBie is called, which writes the data to the directory.
*/ */
jbg_enc_out(&encoder); jbg_enc_out(&encoder);
jbg_enc_free(&encoder); jbg_enc_free(&encoder);
return 1; return 1;
}
static void JBIGCleanup(TIFF* tif)
{
JBIGState *sp = GetJBIGState(tif);
assert(sp != 0);
tif->tif_tagmethods.vgetfield = sp->vgetparent;
tif->tif_tagmethods.vsetfield = sp->vsetparent;
_TIFFfree(tif->tif_data);
tif->tif_data = NULL;
_TIFFSetDefaultCompressionState(tif);
}
static void JBIGPrintDir(TIFF* tif, FILE* fd, long flags)
{
JBIGState* codec = GetJBIGState(tif);
(void)flags;
if (TIFFFieldSet(tif, FIELD_RECVPARAMS))
{
fprintf(fd,
" Fax Receive Parameters: %08lx\n",
(unsigned long)codec->recvparams);
}
if (TIFFFieldSet(tif, FIELD_SUBADDRESS))
{
fprintf(fd,
" Fax SubAddress: %s\n",
codec->subaddress);
}
if (TIFFFieldSet(tif, FIELD_RECVTIME))
{
fprintf(fd,
" Fax Receive Time: %lu secs\n",
(unsigned long)codec->recvtime);
}
if (TIFFFieldSet(tif, FIELD_FAXDCS))
{
fprintf(fd,
" Fax DCS: %s\n",
codec->faxdcs);
}
}
static int JBIGVGetField(TIFF* tif, ttag_t tag, va_list ap)
{
JBIGState* codec = GetJBIGState(tif);
switch (tag)
{
case TIFFTAG_FAXRECVPARAMS:
*va_arg(ap, uint32*) = codec->recvparams;
break;
case TIFFTAG_FAXSUBADDRESS:
*va_arg(ap, char**) = codec->subaddress;
break;
case TIFFTAG_FAXRECVTIME:
*va_arg(ap, uint32*) = codec->recvtime;
break;
case TIFFTAG_FAXDCS:
*va_arg(ap, char**) = codec->faxdcs;
break;
default:
return (*codec->vgetparent)(tif, tag, ap);
}
return 1;
}
static int JBIGVSetField(TIFF* tif, ttag_t tag, va_list ap)
{
JBIGState* codec = GetJBIGState(tif);
switch (tag)
{
case TIFFTAG_FAXRECVPARAMS:
codec->recvparams = va_arg(ap, uint32);
break;
case TIFFTAG_FAXSUBADDRESS:
_TIFFsetString(&codec->subaddress, va_arg(ap, char*));
break;
case TIFFTAG_FAXRECVTIME:
codec->recvtime = va_arg(ap, uint32);
break;
case TIFFTAG_FAXDCS:
_TIFFsetString(&codec->faxdcs, va_arg(ap, char*));
break;
default:
return (*codec->vsetparent)(tif, tag, ap);
}
TIFFSetFieldBit(tif, _TIFFFieldWithTag(tif, tag)->field_bit);
tif->tif_flags |= TIFF_DIRTYDIRECT;
return 1;
} }
int TIFFInitJBIG(TIFF* tif, int scheme) int TIFFInitJBIG(TIFF* tif, int scheme)
{ {
JBIGState* codec = NULL;
assert(scheme == COMPRESSION_JBIG); assert(scheme == COMPRESSION_JBIG);
/* /*
* Merge codec-specific tag information. * These flags are set so the JBIG Codec can control when to reverse
* bits and when not to and to allow the jbig decoder and bit reverser
* to write to memory when necessary.
*/ */
if (!_TIFFMergeFieldInfo(tif, jbigFieldInfo, tif->tif_flags |= TIFF_NOBITREV;
TIFFArrayCount(jbigFieldInfo))) { tif->tif_flags &= ~TIFF_MAPPED;
TIFFErrorExt(tif->tif_clientdata, "TIFFInitJBIG",
"Merging JBIG codec-specific tags failed");
return 0;
}
/* Allocate memory for the JBIGState structure.*/ /* Setup the function pointers for encode, decode, and cleanup. */
tif->tif_data = (tdata_t)_TIFFmalloc(sizeof(JBIGState)); tif->tif_setupdecode = JBIGSetupDecode;
if (tif->tif_data == NULL) tif->tif_decodestrip = JBIGDecode;
{
TIFFError("TIFFInitJBIG", "Not enough memory for JBIGState");
return 0;
}
_TIFFmemset(tif->tif_data, 0, sizeof(JBIGState));
codec = GetJBIGState(tif);
/* Initialize codec private fields */ tif->tif_setupencode = JBIGSetupEncode;
codec->recvparams = 0; tif->tif_encodestrip = JBIGEncode;
codec->subaddress = NULL;
codec->faxdcs = NULL;
codec->recvtime = 0;
/* return 1;
* Override parent get/set field methods.
*/
codec->vgetparent = tif->tif_tagmethods.vgetfield;
codec->vsetparent = tif->tif_tagmethods.vsetfield;
tif->tif_tagmethods.vgetfield = JBIGVGetField;
tif->tif_tagmethods.vsetfield = JBIGVSetField;
tif->tif_tagmethods.printdir = JBIGPrintDir;
/*
* These flags are set so the JBIG Codec can control when to reverse
* bits and when not to and to allow the jbig decoder and bit reverser
* to write to memory when necessary.
*/
tif->tif_flags |= TIFF_NOBITREV;
tif->tif_flags &= ~TIFF_MAPPED;
/* Setup the function pointers for encode, decode, and cleanup. */
tif->tif_setupdecode = JBIGSetupDecode;
tif->tif_decodestrip = JBIGDecode;
tif->tif_setupencode = JBIGSetupEncode;
tif->tif_encodestrip = JBIGEncode;
tif->tif_cleanup = JBIGCleanup;
return 1;
} }
#endif /* JBIG_SUPPORT */ #endif /* JBIG_SUPPORT */

File diff suppressed because it is too large Load Diff

65
thirdparty/libtiff/tif_jpeg_12.c vendored Normal file
View File

@ -0,0 +1,65 @@
#include "tiffiop.h"
#if defined(JPEG_DUAL_MODE_8_12)
# define TIFFInitJPEG TIFFInitJPEG_12
# include LIBJPEG_12_PATH
# include "tif_jpeg.c"
int TIFFReInitJPEG_12( TIFF *tif, int scheme, int is_encode )
{
JPEGState* sp;
assert(scheme == COMPRESSION_JPEG);
sp = JState(tif);
sp->tif = tif; /* back link */
/*
* Override parent get/set field methods.
*/
tif->tif_tagmethods.vgetfield = JPEGVGetField; /* hook for codec tags */
tif->tif_tagmethods.vsetfield = JPEGVSetField; /* hook for codec tags */
tif->tif_tagmethods.printdir = JPEGPrintDir; /* hook for codec tags */
/*
* Install codec methods.
*/
tif->tif_fixuptags = JPEGFixupTags;
tif->tif_setupdecode = JPEGSetupDecode;
tif->tif_predecode = JPEGPreDecode;
tif->tif_decoderow = JPEGDecode;
tif->tif_decodestrip = JPEGDecode;
tif->tif_decodetile = JPEGDecode;
tif->tif_setupencode = JPEGSetupEncode;
tif->tif_preencode = JPEGPreEncode;
tif->tif_postencode = JPEGPostEncode;
tif->tif_encoderow = JPEGEncode;
tif->tif_encodestrip = JPEGEncode;
tif->tif_encodetile = JPEGEncode;
tif->tif_cleanup = JPEGCleanup;
tif->tif_defstripsize = JPEGDefaultStripSize;
tif->tif_deftilesize = JPEGDefaultTileSize;
tif->tif_flags |= TIFF_NOBITREV; /* no bit reversal, please */
sp->cinfo_initialized = FALSE;
if( is_encode )
return JPEGSetupEncode(tif);
else
return JPEGSetupDecode(tif);
}
#endif /* defined(JPEG_DUAL_MODE_8_12) */
/*
* Local Variables:
* mode: c
* c-basic-offset: 8
* fill-column: 78
* End:
*/

View File

@ -1,4 +1,4 @@
/* $Id: tif_luv.c,v 1.17.2.4 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_luv.c,v 1.35 2011-04-02 20:54:09 bfriesen Exp $ */
/* /*
* Copyright (c) 1997 Greg Ward Larson * Copyright (c) 1997 Greg Ward Larson
@ -155,40 +155,44 @@
* State block for each open TIFF * State block for each open TIFF
* file using LogLuv compression/decompression. * file using LogLuv compression/decompression.
*/ */
typedef struct logLuvState LogLuvState; typedef struct logLuvState LogLuvState;
struct logLuvState { struct logLuvState {
int user_datafmt; /* user data format */ int user_datafmt; /* user data format */
int encode_meth; /* encoding method */ int encode_meth; /* encoding method */
int pixel_size; /* bytes per pixel */ int pixel_size; /* bytes per pixel */
tidata_t* tbuf; /* translation buffer */ uint8* tbuf; /* translation buffer */
int tbuflen; /* buffer length */ tmsize_t tbuflen; /* buffer length */
void (*tfunc)(LogLuvState*, tidata_t, int); void (*tfunc)(LogLuvState*, uint8*, tmsize_t);
TIFFVSetMethod vgetparent; /* super-class method */ TIFFVSetMethod vgetparent; /* super-class method */
TIFFVSetMethod vsetparent; /* super-class method */ TIFFVSetMethod vsetparent; /* super-class method */
}; };
#define DecoderState(tif) ((LogLuvState*) (tif)->tif_data) #define DecoderState(tif) ((LogLuvState*) (tif)->tif_data)
#define EncoderState(tif) ((LogLuvState*) (tif)->tif_data) #define EncoderState(tif) ((LogLuvState*) (tif)->tif_data)
#define SGILOGDATAFMT_UNKNOWN -1 #define SGILOGDATAFMT_UNKNOWN -1
#define MINRUN 4 /* minimum run length */ #define MINRUN 4 /* minimum run length */
/* /*
* Decode a string of 16-bit gray pixels. * Decode a string of 16-bit gray pixels.
*/ */
static int static int
LogL16Decode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s) LogL16Decode(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
{ {
static const char module[] = "LogL16Decode";
LogLuvState* sp = DecoderState(tif); LogLuvState* sp = DecoderState(tif);
int shft, i, npixels; int shft;
tmsize_t i;
tmsize_t npixels;
unsigned char* bp; unsigned char* bp;
int16* tp; int16* tp;
int16 b; int16 b;
int cc, rc; tmsize_t cc;
int rc;
assert(s == 0); assert(s == 0);
assert(sp != NULL); assert(sp != NULL);
@ -201,15 +205,15 @@ LogL16Decode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
assert(sp->tbuflen >= npixels); assert(sp->tbuflen >= npixels);
tp = (int16*) sp->tbuf; tp = (int16*) sp->tbuf;
} }
_TIFFmemset((tdata_t) tp, 0, npixels*sizeof (tp[0])); _TIFFmemset((void*) tp, 0, npixels*sizeof (tp[0]));
bp = (unsigned char*) tif->tif_rawcp; bp = (unsigned char*) tif->tif_rawcp;
cc = tif->tif_rawcc; cc = tif->tif_rawcc;
/* get each byte string */ /* get each byte string */
for (shft = 2*8; (shft -= 8) >= 0; ) { for (shft = 2*8; (shft -= 8) >= 0; ) {
for (i = 0; i < npixels && cc > 0; ) for (i = 0; i < npixels && cc > 0; )
if (*bp >= 128) { /* run */ if (*bp >= 128) { /* run */
rc = *bp++ + (2-128); rc = *bp++ + (2-128); /* TODO: potential input buffer overrun when decoding corrupt or truncated data */
b = (int16)(*bp++ << shft); b = (int16)(*bp++ << shft);
cc -= 2; cc -= 2;
while (rc-- && i < npixels) while (rc-- && i < npixels)
@ -220,16 +224,24 @@ LogL16Decode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
tp[i++] |= (int16)*bp++ << shft; tp[i++] |= (int16)*bp++ << shft;
} }
if (i != npixels) { if (i != npixels) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
"LogL16Decode: Not enough data at row %d (short %d pixels)", TIFFErrorExt(tif->tif_clientdata, module,
tif->tif_row, npixels - i); "Not enough data at row %lu (short %I64d pixels)",
tif->tif_rawcp = (tidata_t) bp; (unsigned long) tif->tif_row,
(unsigned __int64) (npixels - i));
#else
TIFFErrorExt(tif->tif_clientdata, module,
"Not enough data at row %lu (short %llu pixels)",
(unsigned long) tif->tif_row,
(unsigned long long) (npixels - i));
#endif
tif->tif_rawcp = (uint8*) bp;
tif->tif_rawcc = cc; tif->tif_rawcc = cc;
return (0); return (0);
} }
} }
(*sp->tfunc)(sp, op, npixels); (*sp->tfunc)(sp, op, npixels);
tif->tif_rawcp = (tidata_t) bp; tif->tif_rawcp = (uint8*) bp;
tif->tif_rawcc = cc; tif->tif_rawcc = cc;
return (1); return (1);
} }
@ -238,10 +250,13 @@ LogL16Decode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
* Decode a string of 24-bit pixels. * Decode a string of 24-bit pixels.
*/ */
static int static int
LogLuvDecode24(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s) LogLuvDecode24(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
{ {
static const char module[] = "LogLuvDecode24";
LogLuvState* sp = DecoderState(tif); LogLuvState* sp = DecoderState(tif);
int cc, i, npixels; tmsize_t cc;
tmsize_t i;
tmsize_t npixels;
unsigned char* bp; unsigned char* bp;
uint32* tp; uint32* tp;
@ -256,7 +271,7 @@ LogLuvDecode24(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
assert(sp->tbuflen >= npixels); assert(sp->tbuflen >= npixels);
tp = (uint32 *) sp->tbuf; tp = (uint32 *) sp->tbuf;
} }
/* copy to array of uint32 */ /* copy to array of uint32 */
bp = (unsigned char*) tif->tif_rawcp; bp = (unsigned char*) tif->tif_rawcp;
cc = tif->tif_rawcc; cc = tif->tif_rawcc;
for (i = 0; i < npixels && cc > 0; i++) { for (i = 0; i < npixels && cc > 0; i++) {
@ -264,12 +279,20 @@ LogLuvDecode24(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
bp += 3; bp += 3;
cc -= 3; cc -= 3;
} }
tif->tif_rawcp = (tidata_t) bp; tif->tif_rawcp = (uint8*) bp;
tif->tif_rawcc = cc; tif->tif_rawcc = cc;
if (i != npixels) { if (i != npixels) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
"LogLuvDecode24: Not enough data at row %d (short %d pixels)", TIFFErrorExt(tif->tif_clientdata, module,
tif->tif_row, npixels - i); "Not enough data at row %lu (short %I64d pixels)",
(unsigned long) tif->tif_row,
(unsigned __int64) (npixels - i));
#else
TIFFErrorExt(tif->tif_clientdata, module,
"Not enough data at row %lu (short %llu pixels)",
(unsigned long) tif->tif_row,
(unsigned long long) (npixels - i));
#endif
return (0); return (0);
} }
(*sp->tfunc)(sp, op, npixels); (*sp->tfunc)(sp, op, npixels);
@ -280,14 +303,18 @@ LogLuvDecode24(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
* Decode a string of 32-bit pixels. * Decode a string of 32-bit pixels.
*/ */
static int static int
LogLuvDecode32(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s) LogLuvDecode32(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
{ {
static const char module[] = "LogLuvDecode32";
LogLuvState* sp; LogLuvState* sp;
int shft, i, npixels; int shft;
tmsize_t i;
tmsize_t npixels;
unsigned char* bp; unsigned char* bp;
uint32* tp; uint32* tp;
uint32 b; uint32 b;
int cc, rc; tmsize_t cc;
int rc;
assert(s == 0); assert(s == 0);
sp = DecoderState(tif); sp = DecoderState(tif);
@ -301,17 +328,17 @@ LogLuvDecode32(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
assert(sp->tbuflen >= npixels); assert(sp->tbuflen >= npixels);
tp = (uint32*) sp->tbuf; tp = (uint32*) sp->tbuf;
} }
_TIFFmemset((tdata_t) tp, 0, npixels*sizeof (tp[0])); _TIFFmemset((void*) tp, 0, npixels*sizeof (tp[0]));
bp = (unsigned char*) tif->tif_rawcp; bp = (unsigned char*) tif->tif_rawcp;
cc = tif->tif_rawcc; cc = tif->tif_rawcc;
/* get each byte string */ /* get each byte string */
for (shft = 4*8; (shft -= 8) >= 0; ) { for (shft = 4*8; (shft -= 8) >= 0; ) {
for (i = 0; i < npixels && cc > 0; ) for (i = 0; i < npixels && cc > 0; )
if (*bp >= 128) { /* run */ if (*bp >= 128) { /* run */
rc = *bp++ + (2-128); rc = *bp++ + (2-128);
b = (uint32)*bp++ << shft; b = (uint32)*bp++ << shft;
cc -= 2; cc -= 2; /* TODO: potential input buffer overrun when decoding corrupt or truncated data */
while (rc-- && i < npixels) while (rc-- && i < npixels)
tp[i++] |= b; tp[i++] |= b;
} else { /* non-run */ } else { /* non-run */
@ -320,16 +347,24 @@ LogLuvDecode32(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
tp[i++] |= (uint32)*bp++ << shft; tp[i++] |= (uint32)*bp++ << shft;
} }
if (i != npixels) { if (i != npixels) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
"LogLuvDecode32: Not enough data at row %d (short %d pixels)", TIFFErrorExt(tif->tif_clientdata, module,
tif->tif_row, npixels - i); "Not enough data at row %lu (short %I64d pixels)",
tif->tif_rawcp = (tidata_t) bp; (unsigned long) tif->tif_row,
(unsigned __int64) (npixels - i));
#else
TIFFErrorExt(tif->tif_clientdata, module,
"Not enough data at row %lu (short %llu pixels)",
(unsigned long) tif->tif_row,
(unsigned long long) (npixels - i));
#endif
tif->tif_rawcp = (uint8*) bp;
tif->tif_rawcc = cc; tif->tif_rawcc = cc;
return (0); return (0);
} }
} }
(*sp->tfunc)(sp, op, npixels); (*sp->tfunc)(sp, op, npixels);
tif->tif_rawcp = (tidata_t) bp; tif->tif_rawcp = (uint8*) bp;
tif->tif_rawcc = cc; tif->tif_rawcc = cc;
return (1); return (1);
} }
@ -340,9 +375,9 @@ LogLuvDecode32(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
* is row by row. * is row by row.
*/ */
static int static int
LogLuvDecodeStrip(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) LogLuvDecodeStrip(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
tsize_t rowlen = TIFFScanlineSize(tif); tmsize_t rowlen = TIFFScanlineSize(tif);
assert(cc%rowlen == 0); assert(cc%rowlen == 0);
while (cc && (*tif->tif_decoderow)(tif, bp, rowlen, s)) while (cc && (*tif->tif_decoderow)(tif, bp, rowlen, s))
@ -356,9 +391,9 @@ LogLuvDecodeStrip(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
* is row by row. * is row by row.
*/ */
static int static int
LogLuvDecodeTile(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) LogLuvDecodeTile(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
tsize_t rowlen = TIFFTileRowSize(tif); tmsize_t rowlen = TIFFTileRowSize(tif);
assert(cc%rowlen == 0); assert(cc%rowlen == 0);
while (cc && (*tif->tif_decoderow)(tif, bp, rowlen, s)) while (cc && (*tif->tif_decoderow)(tif, bp, rowlen, s))
@ -370,14 +405,19 @@ LogLuvDecodeTile(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
* Encode a row of 16-bit pixels. * Encode a row of 16-bit pixels.
*/ */
static int static int
LogL16Encode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) LogL16Encode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
LogLuvState* sp = EncoderState(tif); LogLuvState* sp = EncoderState(tif);
int shft, i, j, npixels; int shft;
tidata_t op; tmsize_t i;
tmsize_t j;
tmsize_t npixels;
uint8* op;
int16* tp; int16* tp;
int16 b; int16 b;
int occ, rc=0, mask, beg; tmsize_t occ;
int rc=0, mask;
tmsize_t beg;
assert(s == 0); assert(s == 0);
assert(sp != NULL); assert(sp != NULL);
@ -390,7 +430,7 @@ LogL16Encode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
assert(sp->tbuflen >= npixels); assert(sp->tbuflen >= npixels);
(*sp->tfunc)(sp, bp, npixels); (*sp->tfunc)(sp, bp, npixels);
} }
/* compress each byte string */ /* compress each byte string */
op = tif->tif_rawcp; op = tif->tif_rawcp;
occ = tif->tif_rawdatasize - tif->tif_rawcc; occ = tif->tif_rawdatasize - tif->tif_rawcc;
for (shft = 2*8; (shft -= 8) >= 0; ) for (shft = 2*8; (shft -= 8) >= 0; )
@ -408,7 +448,7 @@ LogL16Encode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
b = (int16) (tp[beg] & mask); b = (int16) (tp[beg] & mask);
rc = 1; rc = 1;
while (rc < 127+2 && beg+rc < npixels && while (rc < 127+2 && beg+rc < npixels &&
(tp[beg+rc] & mask) == b) (tp[beg+rc] & mask) == b)
rc++; rc++;
if (rc >= MINRUN) if (rc >= MINRUN)
break; /* long enough */ break; /* long enough */
@ -417,33 +457,33 @@ LogL16Encode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
b = (int16) (tp[i] & mask);/*check short run */ b = (int16) (tp[i] & mask);/*check short run */
j = i+1; j = i+1;
while ((tp[j++] & mask) == b) while ((tp[j++] & mask) == b)
if (j == beg) { if (j == beg) {
*op++ = (tidataval_t)(128-2+j-i); *op++ = (uint8)(128-2+j-i);
*op++ = (tidataval_t) (b >> shft); *op++ = (uint8)(b >> shft);
occ -= 2; occ -= 2;
i = beg; i = beg;
break; break;
} }
} }
while (i < beg) { /* write out non-run */ while (i < beg) { /* write out non-run */
if ((j = beg-i) > 127) j = 127; if ((j = beg-i) > 127) j = 127;
if (occ < j+3) { if (occ < j+3) {
tif->tif_rawcp = op; tif->tif_rawcp = op;
tif->tif_rawcc = tif->tif_rawdatasize - occ; tif->tif_rawcc = tif->tif_rawdatasize - occ;
if (!TIFFFlushData1(tif)) if (!TIFFFlushData1(tif))
return (-1); return (-1);
op = tif->tif_rawcp; op = tif->tif_rawcp;
occ = tif->tif_rawdatasize - tif->tif_rawcc; occ = tif->tif_rawdatasize - tif->tif_rawcc;
} }
*op++ = (tidataval_t) j; occ--; *op++ = (uint8) j; occ--;
while (j--) { while (j--) {
*op++ = (tidataval_t) (tp[i++] >> shft & 0xff); *op++ = (uint8) (tp[i++] >> shft & 0xff);
occ--; occ--;
} }
} }
if (rc >= MINRUN) { /* write out run */ if (rc >= MINRUN) { /* write out run */
*op++ = (tidataval_t) (128-2+rc); *op++ = (uint8) (128-2+rc);
*op++ = (tidataval_t) (tp[beg] >> shft & 0xff); *op++ = (uint8) (tp[beg] >> shft & 0xff);
occ -= 2; occ -= 2;
} else } else
rc = 0; rc = 0;
@ -458,11 +498,13 @@ LogL16Encode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
* Encode a row of 24-bit pixels. * Encode a row of 24-bit pixels.
*/ */
static int static int
LogLuvEncode24(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) LogLuvEncode24(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
LogLuvState* sp = EncoderState(tif); LogLuvState* sp = EncoderState(tif);
int i, npixels, occ; tmsize_t i;
tidata_t op; tmsize_t npixels;
tmsize_t occ;
uint8* op;
uint32* tp; uint32* tp;
assert(s == 0); assert(s == 0);
@ -476,7 +518,7 @@ LogLuvEncode24(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
assert(sp->tbuflen >= npixels); assert(sp->tbuflen >= npixels);
(*sp->tfunc)(sp, bp, npixels); (*sp->tfunc)(sp, bp, npixels);
} }
/* write out encoded pixels */ /* write out encoded pixels */
op = tif->tif_rawcp; op = tif->tif_rawcp;
occ = tif->tif_rawdatasize - tif->tif_rawcc; occ = tif->tif_rawdatasize - tif->tif_rawcc;
for (i = npixels; i--; ) { for (i = npixels; i--; ) {
@ -488,9 +530,9 @@ LogLuvEncode24(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
op = tif->tif_rawcp; op = tif->tif_rawcp;
occ = tif->tif_rawdatasize - tif->tif_rawcc; occ = tif->tif_rawdatasize - tif->tif_rawcc;
} }
*op++ = (tidataval_t)(*tp >> 16); *op++ = (uint8)(*tp >> 16);
*op++ = (tidataval_t)(*tp >> 8 & 0xff); *op++ = (uint8)(*tp >> 8 & 0xff);
*op++ = (tidataval_t)(*tp++ & 0xff); *op++ = (uint8)(*tp++ & 0xff);
occ -= 3; occ -= 3;
} }
tif->tif_rawcp = op; tif->tif_rawcp = op;
@ -503,14 +545,19 @@ LogLuvEncode24(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
* Encode a row of 32-bit pixels. * Encode a row of 32-bit pixels.
*/ */
static int static int
LogLuvEncode32(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) LogLuvEncode32(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
LogLuvState* sp = EncoderState(tif); LogLuvState* sp = EncoderState(tif);
int shft, i, j, npixels; int shft;
tidata_t op; tmsize_t i;
tmsize_t j;
tmsize_t npixels;
uint8* op;
uint32* tp; uint32* tp;
uint32 b; uint32 b;
int occ, rc=0, mask, beg; tmsize_t occ;
int rc=0, mask;
tmsize_t beg;
assert(s == 0); assert(s == 0);
assert(sp != NULL); assert(sp != NULL);
@ -524,7 +571,7 @@ LogLuvEncode32(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
assert(sp->tbuflen >= npixels); assert(sp->tbuflen >= npixels);
(*sp->tfunc)(sp, bp, npixels); (*sp->tfunc)(sp, bp, npixels);
} }
/* compress each byte string */ /* compress each byte string */
op = tif->tif_rawcp; op = tif->tif_rawcp;
occ = tif->tif_rawdatasize - tif->tif_rawcc; occ = tif->tif_rawdatasize - tif->tif_rawcc;
for (shft = 4*8; (shft -= 8) >= 0; ) for (shft = 4*8; (shft -= 8) >= 0; )
@ -552,8 +599,8 @@ LogLuvEncode32(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
j = i+1; j = i+1;
while ((tp[j++] & mask) == b) while ((tp[j++] & mask) == b)
if (j == beg) { if (j == beg) {
*op++ = (tidataval_t)(128-2+j-i); *op++ = (uint8)(128-2+j-i);
*op++ = (tidataval_t)(b >> shft); *op++ = (uint8)(b >> shft);
occ -= 2; occ -= 2;
i = beg; i = beg;
break; break;
@ -569,15 +616,15 @@ LogLuvEncode32(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
op = tif->tif_rawcp; op = tif->tif_rawcp;
occ = tif->tif_rawdatasize - tif->tif_rawcc; occ = tif->tif_rawdatasize - tif->tif_rawcc;
} }
*op++ = (tidataval_t) j; occ--; *op++ = (uint8) j; occ--;
while (j--) { while (j--) {
*op++ = (tidataval_t)(tp[i++] >> shft & 0xff); *op++ = (uint8)(tp[i++] >> shft & 0xff);
occ--; occ--;
} }
} }
if (rc >= MINRUN) { /* write out run */ if (rc >= MINRUN) { /* write out run */
*op++ = (tidataval_t) (128-2+rc); *op++ = (uint8) (128-2+rc);
*op++ = (tidataval_t)(tp[beg] >> shft & 0xff); *op++ = (uint8)(tp[beg] >> shft & 0xff);
occ -= 2; occ -= 2;
} else } else
rc = 0; rc = 0;
@ -593,9 +640,9 @@ LogLuvEncode32(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
* avoid encoding runs across row boundaries. * avoid encoding runs across row boundaries.
*/ */
static int static int
LogLuvEncodeStrip(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) LogLuvEncodeStrip(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
tsize_t rowlen = TIFFScanlineSize(tif); tmsize_t rowlen = TIFFScanlineSize(tif);
assert(cc%rowlen == 0); assert(cc%rowlen == 0);
while (cc && (*tif->tif_encoderow)(tif, bp, rowlen, s) == 1) while (cc && (*tif->tif_encoderow)(tif, bp, rowlen, s) == 1)
@ -608,9 +655,9 @@ LogLuvEncodeStrip(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
* avoid encoding runs across row boundaries. * avoid encoding runs across row boundaries.
*/ */
static int static int
LogLuvEncodeTile(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) LogLuvEncodeTile(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
tsize_t rowlen = TIFFTileRowSize(tif); tmsize_t rowlen = TIFFTileRowSize(tif);
assert(cc%rowlen == 0); assert(cc%rowlen == 0);
while (cc && (*tif->tif_encoderow)(tif, bp, rowlen, s) == 1) while (cc && (*tif->tif_encoderow)(tif, bp, rowlen, s) == 1)
@ -676,7 +723,7 @@ LogL16fromY(double Y, int em) /* get 16-bit LogL from Y */
} }
static void static void
L16toY(LogLuvState* sp, tidata_t op, int n) L16toY(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
int16* l16 = (int16*) sp->tbuf; int16* l16 = (int16*) sp->tbuf;
float* yp = (float*) op; float* yp = (float*) op;
@ -686,7 +733,7 @@ L16toY(LogLuvState* sp, tidata_t op, int n)
} }
static void static void
L16toGry(LogLuvState* sp, tidata_t op, int n) L16toGry(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
int16* l16 = (int16*) sp->tbuf; int16* l16 = (int16*) sp->tbuf;
uint8* gp = (uint8*) op; uint8* gp = (uint8*) op;
@ -698,7 +745,7 @@ L16toGry(LogLuvState* sp, tidata_t op, int n)
} }
static void static void
L16fromY(LogLuvState* sp, tidata_t op, int n) L16fromY(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
int16* l16 = (int16*) sp->tbuf; int16* l16 = (int16*) sp->tbuf;
float* yp = (float*) op; float* yp = (float*) op;
@ -760,7 +807,7 @@ oog_encode(double u, double v) /* encode out-of-gamut chroma */
static int oog_table[NANGLES]; static int oog_table[NANGLES];
static int initialized = 0; static int initialized = 0;
register int i; register int i;
if (!initialized) { /* set up perimeter table */ if (!initialized) { /* set up perimeter table */
double eps[NANGLES], ua, va, ang, epsa; double eps[NANGLES], ua, va, ang, epsa;
int ui, vi, ustep; int ui, vi, ustep;
@ -774,7 +821,7 @@ oog_encode(double u, double v) /* encode out-of-gamut chroma */
for (ui = uv_row[vi].nus-1; ui >= 0; ui -= ustep) { for (ui = uv_row[vi].nus-1; ui >= 0; ui -= ustep) {
ua = uv_row[vi].ustart + (ui+.5)*UV_SQSIZ; ua = uv_row[vi].ustart + (ui+.5)*UV_SQSIZ;
ang = uv2ang(ua, va); ang = uv2ang(ua, va);
i = (int) ang; i = (int) ang;
epsa = fabs(ang - (i+.5)); epsa = fabs(ang - (i+.5));
if (epsa < eps[i]) { if (epsa < eps[i]) {
oog_table[i] = uv_row[vi].ncum + ui; oog_table[i] = uv_row[vi].ncum + ui;
@ -916,9 +963,9 @@ LogLuv24fromXYZ(float XYZ[3], int em)
} }
static void static void
Luv24toXYZ(LogLuvState* sp, tidata_t op, int n) Luv24toXYZ(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
uint32* luv = (uint32*) sp->tbuf; uint32* luv = (uint32*) sp->tbuf;
float* xyz = (float*) op; float* xyz = (float*) op;
while (n-- > 0) { while (n-- > 0) {
@ -929,9 +976,9 @@ Luv24toXYZ(LogLuvState* sp, tidata_t op, int n)
} }
static void static void
Luv24toLuv48(LogLuvState* sp, tidata_t op, int n) Luv24toLuv48(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
uint32* luv = (uint32*) sp->tbuf; uint32* luv = (uint32*) sp->tbuf;
int16* luv3 = (int16*) op; int16* luv3 = (int16*) op;
while (n-- > 0) { while (n-- > 0) {
@ -949,9 +996,9 @@ Luv24toLuv48(LogLuvState* sp, tidata_t op, int n)
} }
static void static void
Luv24toRGB(LogLuvState* sp, tidata_t op, int n) Luv24toRGB(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
uint32* luv = (uint32*) sp->tbuf; uint32* luv = (uint32*) sp->tbuf;
uint8* rgb = (uint8*) op; uint8* rgb = (uint8*) op;
while (n-- > 0) { while (n-- > 0) {
@ -964,9 +1011,9 @@ Luv24toRGB(LogLuvState* sp, tidata_t op, int n)
} }
static void static void
Luv24fromXYZ(LogLuvState* sp, tidata_t op, int n) Luv24fromXYZ(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
uint32* luv = (uint32*) sp->tbuf; uint32* luv = (uint32*) sp->tbuf;
float* xyz = (float*) op; float* xyz = (float*) op;
while (n-- > 0) { while (n-- > 0) {
@ -976,9 +1023,9 @@ Luv24fromXYZ(LogLuvState* sp, tidata_t op, int n)
} }
static void static void
Luv24fromLuv48(LogLuvState* sp, tidata_t op, int n) Luv24fromLuv48(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
uint32* luv = (uint32*) sp->tbuf; uint32* luv = (uint32*) sp->tbuf;
int16* luv3 = (int16*) op; int16* luv3 = (int16*) op;
while (n-- > 0) { while (n-- > 0) {
@ -1057,9 +1104,9 @@ LogLuv32fromXYZ(float XYZ[3], int em)
} }
static void static void
Luv32toXYZ(LogLuvState* sp, tidata_t op, int n) Luv32toXYZ(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
uint32* luv = (uint32*) sp->tbuf; uint32* luv = (uint32*) sp->tbuf;
float* xyz = (float*) op; float* xyz = (float*) op;
while (n-- > 0) { while (n-- > 0) {
@ -1069,9 +1116,9 @@ Luv32toXYZ(LogLuvState* sp, tidata_t op, int n)
} }
static void static void
Luv32toLuv48(LogLuvState* sp, tidata_t op, int n) Luv32toLuv48(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
uint32* luv = (uint32*) sp->tbuf; uint32* luv = (uint32*) sp->tbuf;
int16* luv3 = (int16*) op; int16* luv3 = (int16*) op;
while (n-- > 0) { while (n-- > 0) {
@ -1087,9 +1134,9 @@ Luv32toLuv48(LogLuvState* sp, tidata_t op, int n)
} }
static void static void
Luv32toRGB(LogLuvState* sp, tidata_t op, int n) Luv32toRGB(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
uint32* luv = (uint32*) sp->tbuf; uint32* luv = (uint32*) sp->tbuf;
uint8* rgb = (uint8*) op; uint8* rgb = (uint8*) op;
while (n-- > 0) { while (n-- > 0) {
@ -1102,9 +1149,9 @@ Luv32toRGB(LogLuvState* sp, tidata_t op, int n)
} }
static void static void
Luv32fromXYZ(LogLuvState* sp, tidata_t op, int n) Luv32fromXYZ(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
uint32* luv = (uint32*) sp->tbuf; uint32* luv = (uint32*) sp->tbuf;
float* xyz = (float*) op; float* xyz = (float*) op;
while (n-- > 0) { while (n-- > 0) {
@ -1114,7 +1161,7 @@ Luv32fromXYZ(LogLuvState* sp, tidata_t op, int n)
} }
static void static void
Luv32fromLuv48(LogLuvState* sp, tidata_t op, int n) Luv32fromLuv48(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
uint32* luv = (uint32*) sp->tbuf; uint32* luv = (uint32*) sp->tbuf;
int16* luv3 = (int16*) op; int16* luv3 = (int16*) op;
@ -1137,7 +1184,7 @@ Luv32fromLuv48(LogLuvState* sp, tidata_t op, int n)
} }
static void static void
_logLuvNop(LogLuvState* sp, tidata_t op, int n) _logLuvNop(LogLuvState* sp, uint8* op, tmsize_t n)
{ {
(void) sp; (void) op; (void) n; (void) sp; (void) op; (void) n;
} }
@ -1161,10 +1208,10 @@ LogL16GuessDataFmt(TIFFDirectory *td)
return (SGILOGDATAFMT_UNKNOWN); return (SGILOGDATAFMT_UNKNOWN);
} }
static uint32 static tmsize_t
multiply(size_t m1, size_t m2) multiply_ms(tmsize_t m1, tmsize_t m2)
{ {
uint32 bytes = m1 * m2; tmsize_t bytes = m1 * m2;
if (m1 && bytes / m1 != m2) if (m1 && bytes / m1 != m2)
bytes = 0; bytes = 0;
@ -1175,9 +1222,9 @@ multiply(size_t m1, size_t m2)
static int static int
LogL16InitState(TIFF* tif) LogL16InitState(TIFF* tif)
{ {
static const char module[] = "LogL16InitState";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
LogLuvState* sp = DecoderState(tif); LogLuvState* sp = DecoderState(tif);
static const char module[] = "LogL16InitState";
assert(sp != NULL); assert(sp != NULL);
assert(td->td_photometric == PHOTOMETRIC_LOGL); assert(td->td_photometric == PHOTOMETRIC_LOGL);
@ -1196,18 +1243,17 @@ LogL16InitState(TIFF* tif)
sp->pixel_size = sizeof (uint8); sp->pixel_size = sizeof (uint8);
break; break;
default: default:
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"No support for converting user data format to LogL"); "No support for converting user data format to LogL");
return (0); return (0);
} }
if( isTiled(tif) ) if( isTiled(tif) )
sp->tbuflen = multiply(td->td_tilewidth, td->td_tilelength); sp->tbuflen = multiply_ms(td->td_tilewidth, td->td_tilelength);
else else
sp->tbuflen = multiply(td->td_imagewidth, td->td_rowsperstrip); sp->tbuflen = multiply_ms(td->td_imagewidth, td->td_rowsperstrip);
if (multiply(sp->tbuflen, sizeof (int16)) == 0 || if (multiply_ms(sp->tbuflen, sizeof (int16)) == 0 ||
(sp->tbuf = (tidata_t*) _TIFFmalloc(sp->tbuflen * sizeof (int16))) == NULL) { (sp->tbuf = (uint8*) _TIFFmalloc(sp->tbuflen * sizeof (int16))) == NULL) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: No space for SGILog translation buffer", TIFFErrorExt(tif->tif_clientdata, module, "No space for SGILog translation buffer");
tif->tif_name);
return (0); return (0);
} }
return (1); return (1);
@ -1268,9 +1314,9 @@ LogLuvGuessDataFmt(TIFFDirectory *td)
static int static int
LogLuvInitState(TIFF* tif) LogLuvInitState(TIFF* tif)
{ {
static const char module[] = "LogLuvInitState";
TIFFDirectory* td = &tif->tif_dir; TIFFDirectory* td = &tif->tif_dir;
LogLuvState* sp = DecoderState(tif); LogLuvState* sp = DecoderState(tif);
static const char module[] = "LogLuvInitState";
assert(sp != NULL); assert(sp != NULL);
assert(td->td_photometric == PHOTOMETRIC_LOGLUV); assert(td->td_photometric == PHOTOMETRIC_LOGLUV);
@ -1297,26 +1343,33 @@ LogLuvInitState(TIFF* tif)
sp->pixel_size = 3*sizeof (uint8); sp->pixel_size = 3*sizeof (uint8);
break; break;
default: default:
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"No support for converting user data format to LogLuv"); "No support for converting user data format to LogLuv");
return (0); return (0);
} }
if( isTiled(tif) ) if( isTiled(tif) )
sp->tbuflen = multiply(td->td_tilewidth, td->td_tilelength); sp->tbuflen = multiply_ms(td->td_tilewidth, td->td_tilelength);
else else
sp->tbuflen = multiply(td->td_imagewidth, td->td_rowsperstrip); sp->tbuflen = multiply_ms(td->td_imagewidth, td->td_rowsperstrip);
if (multiply(sp->tbuflen, sizeof (uint32)) == 0 || if (multiply_ms(sp->tbuflen, sizeof (uint32)) == 0 ||
(sp->tbuf = (tidata_t*) _TIFFmalloc(sp->tbuflen * sizeof (uint32))) == NULL) { (sp->tbuf = (uint8*) _TIFFmalloc(sp->tbuflen * sizeof (uint32))) == NULL) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: No space for SGILog translation buffer", TIFFErrorExt(tif->tif_clientdata, module, "No space for SGILog translation buffer");
tif->tif_name);
return (0); return (0);
} }
return (1); return (1);
} }
static int
LogLuvFixupTags(TIFF* tif)
{
(void) tif;
return (1);
}
static int static int
LogLuvSetupDecode(TIFF* tif) LogLuvSetupDecode(TIFF* tif)
{ {
static const char module[] = "LogLuvSetupDecode";
LogLuvState* sp = DecoderState(tif); LogLuvState* sp = DecoderState(tif);
TIFFDirectory* td = &tif->tif_dir; TIFFDirectory* td = &tif->tif_dir;
@ -1329,10 +1382,10 @@ LogLuvSetupDecode(TIFF* tif)
tif->tif_decoderow = LogLuvDecode24; tif->tif_decoderow = LogLuvDecode24;
switch (sp->user_datafmt) { switch (sp->user_datafmt) {
case SGILOGDATAFMT_FLOAT: case SGILOGDATAFMT_FLOAT:
sp->tfunc = Luv24toXYZ; sp->tfunc = Luv24toXYZ;
break; break;
case SGILOGDATAFMT_16BIT: case SGILOGDATAFMT_16BIT:
sp->tfunc = Luv24toLuv48; sp->tfunc = Luv24toLuv48;
break; break;
case SGILOGDATAFMT_8BIT: case SGILOGDATAFMT_8BIT:
sp->tfunc = Luv24toRGB; sp->tfunc = Luv24toRGB;
@ -1367,8 +1420,8 @@ LogLuvSetupDecode(TIFF* tif)
} }
return (1); return (1);
default: default:
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"Inappropriate photometric interpretation %d for SGILog compression; %s", "Inappropriate photometric interpretation %d for SGILog compression; %s",
td->td_photometric, "must be either LogLUV or LogL"); td->td_photometric, "must be either LogLUV or LogL");
break; break;
} }
@ -1378,6 +1431,7 @@ LogLuvSetupDecode(TIFF* tif)
static int static int
LogLuvSetupEncode(TIFF* tif) LogLuvSetupEncode(TIFF* tif)
{ {
static const char module[] = "LogLuvSetupEncode";
LogLuvState* sp = EncoderState(tif); LogLuvState* sp = EncoderState(tif);
TIFFDirectory* td = &tif->tif_dir; TIFFDirectory* td = &tif->tif_dir;
@ -1392,7 +1446,7 @@ LogLuvSetupEncode(TIFF* tif)
sp->tfunc = Luv24fromXYZ; sp->tfunc = Luv24fromXYZ;
break; break;
case SGILOGDATAFMT_16BIT: case SGILOGDATAFMT_16BIT:
sp->tfunc = Luv24fromLuv48; sp->tfunc = Luv24fromLuv48;
break; break;
case SGILOGDATAFMT_RAW: case SGILOGDATAFMT_RAW:
break; break;
@ -1400,13 +1454,13 @@ LogLuvSetupEncode(TIFF* tif)
goto notsupported; goto notsupported;
} }
} else { } else {
tif->tif_encoderow = LogLuvEncode32; tif->tif_encoderow = LogLuvEncode32;
switch (sp->user_datafmt) { switch (sp->user_datafmt) {
case SGILOGDATAFMT_FLOAT: case SGILOGDATAFMT_FLOAT:
sp->tfunc = Luv32fromXYZ; sp->tfunc = Luv32fromXYZ;
break; break;
case SGILOGDATAFMT_16BIT: case SGILOGDATAFMT_16BIT:
sp->tfunc = Luv32fromLuv48; sp->tfunc = Luv32fromLuv48;
break; break;
case SGILOGDATAFMT_RAW: case SGILOGDATAFMT_RAW:
break; break;
@ -1418,7 +1472,7 @@ LogLuvSetupEncode(TIFF* tif)
case PHOTOMETRIC_LOGL: case PHOTOMETRIC_LOGL:
if (!LogL16InitState(tif)) if (!LogL16InitState(tif))
break; break;
tif->tif_encoderow = LogL16Encode; tif->tif_encoderow = LogL16Encode;
switch (sp->user_datafmt) { switch (sp->user_datafmt) {
case SGILOGDATAFMT_FLOAT: case SGILOGDATAFMT_FLOAT:
sp->tfunc = L16fromY; sp->tfunc = L16fromY;
@ -1430,14 +1484,14 @@ LogLuvSetupEncode(TIFF* tif)
} }
break; break;
default: default:
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"Inappropriate photometric interpretation %d for SGILog compression; %s", "Inappropriate photometric interpretation %d for SGILog compression; %s",
td->td_photometric, "must be either LogLUV or LogL"); td->td_photometric, "must be either LogLUV or LogL");
break; break;
} }
return (1); return (1);
notsupported: notsupported:
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"SGILog compression supported only for %s, or raw data", "SGILog compression supported only for %s, or raw data",
td->td_photometric == PHOTOMETRIC_LOGL ? "Y, L" : "XYZ, Luv"); td->td_photometric == PHOTOMETRIC_LOGL ? "Y, L" : "XYZ, Luv");
return (0); return (0);
@ -1480,14 +1534,15 @@ LogLuvCleanup(TIFF* tif)
} }
static int static int
LogLuvVSetField(TIFF* tif, ttag_t tag, va_list ap) LogLuvVSetField(TIFF* tif, uint32 tag, va_list ap)
{ {
static const char module[] = "LogLuvVSetField";
LogLuvState* sp = DecoderState(tif); LogLuvState* sp = DecoderState(tif);
int bps, fmt; int bps, fmt;
switch (tag) { switch (tag) {
case TIFFTAG_SGILOGDATAFMT: case TIFFTAG_SGILOGDATAFMT:
sp->user_datafmt = va_arg(ap, int); sp->user_datafmt = (int) va_arg(ap, int);
/* /*
* Tweak the TIFF header so that the rest of libtiff knows what * Tweak the TIFF header so that the rest of libtiff knows what
* size of data will be passed between app and library, and * size of data will be passed between app and library, and
@ -1519,16 +1574,16 @@ LogLuvVSetField(TIFF* tif, ttag_t tag, va_list ap)
/* /*
* Must recalculate sizes should bits/sample change. * Must recalculate sizes should bits/sample change.
*/ */
tif->tif_tilesize = isTiled(tif) ? TIFFTileSize(tif) : (tsize_t) -1; tif->tif_tilesize = isTiled(tif) ? TIFFTileSize(tif) : (tmsize_t) -1;
tif->tif_scanlinesize = TIFFScanlineSize(tif); tif->tif_scanlinesize = TIFFScanlineSize(tif);
return (1); return (1);
case TIFFTAG_SGILOGENCODE: case TIFFTAG_SGILOGENCODE:
sp->encode_meth = va_arg(ap, int); sp->encode_meth = (int) va_arg(ap, int);
if (sp->encode_meth != SGILOGENCODE_NODITHER && if (sp->encode_meth != SGILOGENCODE_NODITHER &&
sp->encode_meth != SGILOGENCODE_RANDITHER) { sp->encode_meth != SGILOGENCODE_RANDITHER) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"Unknown encoding %d for LogLuv compression", "Unknown encoding %d for LogLuv compression",
sp->encode_meth); sp->encode_meth);
return (0); return (0);
} }
return (1); return (1);
@ -1538,7 +1593,7 @@ LogLuvVSetField(TIFF* tif, ttag_t tag, va_list ap)
} }
static int static int
LogLuvVGetField(TIFF* tif, ttag_t tag, va_list ap) LogLuvVGetField(TIFF* tif, uint32 tag, va_list ap)
{ {
LogLuvState *sp = (LogLuvState *)tif->tif_data; LogLuvState *sp = (LogLuvState *)tif->tif_data;
@ -1551,11 +1606,9 @@ LogLuvVGetField(TIFF* tif, ttag_t tag, va_list ap)
} }
} }
static const TIFFFieldInfo LogLuvFieldInfo[] = { static const TIFFField LogLuvFields[] = {
{ TIFFTAG_SGILOGDATAFMT, 0, 0, TIFF_SHORT, FIELD_PSEUDO, { TIFFTAG_SGILOGDATAFMT, 0, 0, TIFF_SHORT, 0, TIFF_SETGET_INT, TIFF_SETGET_UNDEFINED, FIELD_PSEUDO, TRUE, FALSE, "SGILogDataFmt", NULL},
TRUE, FALSE, "SGILogDataFmt"}, { TIFFTAG_SGILOGENCODE, 0, 0, TIFF_SHORT, 0, TIFF_SETGET_INT, TIFF_SETGET_UNDEFINED, FIELD_PSEUDO, TRUE, FALSE, "SGILogEncode", NULL}
{ TIFFTAG_SGILOGENCODE, 0, 0, TIFF_SHORT, FIELD_PSEUDO,
TRUE, FALSE, "SGILogEncode"}
}; };
int int
@ -1569,24 +1622,24 @@ TIFFInitSGILog(TIFF* tif, int scheme)
/* /*
* Merge codec-specific tag information. * Merge codec-specific tag information.
*/ */
if (!_TIFFMergeFieldInfo(tif, LogLuvFieldInfo, if (!_TIFFMergeFields(tif, LogLuvFields,
TIFFArrayCount(LogLuvFieldInfo))) { TIFFArrayCount(LogLuvFields))) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"Merging SGILog codec-specific tags failed"); "Merging SGILog codec-specific tags failed");
return 0; return 0;
} }
/* /*
* Allocate state block so tag methods have storage to record values. * Allocate state block so tag methods have storage to record values.
*/ */
tif->tif_data = (tidata_t) _TIFFmalloc(sizeof (LogLuvState)); tif->tif_data = (uint8*) _TIFFmalloc(sizeof (LogLuvState));
if (tif->tif_data == NULL) if (tif->tif_data == NULL)
goto bad; goto bad;
sp = (LogLuvState*) tif->tif_data; sp = (LogLuvState*) tif->tif_data;
_TIFFmemset((tdata_t)sp, 0, sizeof (*sp)); _TIFFmemset((void*)sp, 0, sizeof (*sp));
sp->user_datafmt = SGILOGDATAFMT_UNKNOWN; sp->user_datafmt = SGILOGDATAFMT_UNKNOWN;
sp->encode_meth = (scheme == COMPRESSION_SGILOG24) ? sp->encode_meth = (scheme == COMPRESSION_SGILOG24) ?
SGILOGENCODE_RANDITHER : SGILOGENCODE_NODITHER; SGILOGENCODE_RANDITHER : SGILOGENCODE_NODITHER;
sp->tfunc = _logLuvNop; sp->tfunc = _logLuvNop;
/* /*
@ -1594,16 +1647,17 @@ TIFFInitSGILog(TIFF* tif, int scheme)
* NB: tif_decoderow & tif_encoderow are filled * NB: tif_decoderow & tif_encoderow are filled
* in at setup time. * in at setup time.
*/ */
tif->tif_fixuptags = LogLuvFixupTags;
tif->tif_setupdecode = LogLuvSetupDecode; tif->tif_setupdecode = LogLuvSetupDecode;
tif->tif_decodestrip = LogLuvDecodeStrip; tif->tif_decodestrip = LogLuvDecodeStrip;
tif->tif_decodetile = LogLuvDecodeTile; tif->tif_decodetile = LogLuvDecodeTile;
tif->tif_setupencode = LogLuvSetupEncode; tif->tif_setupencode = LogLuvSetupEncode;
tif->tif_encodestrip = LogLuvEncodeStrip; tif->tif_encodestrip = LogLuvEncodeStrip;
tif->tif_encodetile = LogLuvEncodeTile; tif->tif_encodetile = LogLuvEncodeTile;
tif->tif_close = LogLuvClose; tif->tif_close = LogLuvClose;
tif->tif_cleanup = LogLuvCleanup; tif->tif_cleanup = LogLuvCleanup;
/* /*
* Override parent get/set field methods. * Override parent get/set field methods.
*/ */
sp->vgetparent = tif->tif_tagmethods.vgetfield; sp->vgetparent = tif->tif_tagmethods.vgetfield;

495
thirdparty/libtiff/tif_lzma.c vendored Normal file
View File

@ -0,0 +1,495 @@
/* $Id: tif_lzma.c,v 1.4 2011-12-22 00:29:29 bfriesen Exp $ */
/*
* Copyright (c) 2010, Andrey Kiselev <dron@ak4719.spb.edu>
*
* Permission to use, copy, modify, distribute, and sell this software and
* its documentation for any purpose is hereby granted without fee, provided
* that (i) the above copyright notices and this permission notice appear in
* all copies of the software and related documentation, and (ii) the names of
* Sam Leffler and Silicon Graphics may not be used in any advertising or
* publicity relating to the software without the specific, prior written
* permission of Sam Leffler and Silicon Graphics.
*
* THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
* EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
* WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
*
* IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
* ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
* OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
* WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
* LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
* OF THIS SOFTWARE.
*/
#include "tiffiop.h"
#ifdef LZMA_SUPPORT
/*
* TIFF Library.
*
* LZMA2 Compression Support
*
* You need an LZMA2 SDK to link with. See http://tukaani.org/xz/ for details.
*
* The codec is derived from ZLIB codec (tif_zip.c).
*/
#include "tif_predict.h"
#include "lzma.h"
#include <stdio.h>
/*
* State block for each open TIFF file using LZMA2 compression/decompression.
*/
typedef struct {
TIFFPredictorState predict;
lzma_stream stream;
lzma_filter filters[LZMA_FILTERS_MAX + 1];
lzma_options_delta opt_delta; /* delta filter options */
lzma_options_lzma opt_lzma; /* LZMA2 filter options */
int preset; /* compression level */
lzma_check check; /* type of the integrity check */
int state; /* state flags */
#define LSTATE_INIT_DECODE 0x01
#define LSTATE_INIT_ENCODE 0x02
TIFFVGetMethod vgetparent; /* super-class method */
TIFFVSetMethod vsetparent; /* super-class method */
} LZMAState;
#define LState(tif) ((LZMAState*) (tif)->tif_data)
#define DecoderState(tif) LState(tif)
#define EncoderState(tif) LState(tif)
static int LZMAEncode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s);
static int LZMADecode(TIFF* tif, uint8* op, tmsize_t occ, uint16 s);
static const char *
LZMAStrerror(lzma_ret ret)
{
switch (ret) {
case LZMA_OK:
return "operation completed successfully";
case LZMA_STREAM_END:
return "end of stream was reached";
case LZMA_NO_CHECK:
return "input stream has no integrity check";
case LZMA_UNSUPPORTED_CHECK:
return "cannot calculate the integrity check";
case LZMA_GET_CHECK:
return "integrity check type is now available";
case LZMA_MEM_ERROR:
return "cannot allocate memory";
case LZMA_MEMLIMIT_ERROR:
return "memory usage limit was reached";
case LZMA_FORMAT_ERROR:
return "file format not recognized";
case LZMA_OPTIONS_ERROR:
return "invalid or unsupported options";
case LZMA_DATA_ERROR:
return "data is corrupt";
case LZMA_BUF_ERROR:
return "no progress is possible (stream is truncated or corrupt)";
case LZMA_PROG_ERROR:
return "programming error";
default:
return "unindentified liblzma error";
}
}
static int
LZMAFixupTags(TIFF* tif)
{
(void) tif;
return 1;
}
static int
LZMASetupDecode(TIFF* tif)
{
LZMAState* sp = DecoderState(tif);
assert(sp != NULL);
/* if we were last encoding, terminate this mode */
if (sp->state & LSTATE_INIT_ENCODE) {
lzma_end(&sp->stream);
sp->state = 0;
}
sp->state |= LSTATE_INIT_DECODE;
return 1;
}
/*
* Setup state for decoding a strip.
*/
static int
LZMAPreDecode(TIFF* tif, uint16 s)
{
static const char module[] = "LZMAPreDecode";
LZMAState* sp = DecoderState(tif);
lzma_ret ret;
(void) s;
assert(sp != NULL);
if( (sp->state & LSTATE_INIT_DECODE) == 0 )
tif->tif_setupdecode(tif);
sp->stream.next_in = tif->tif_rawdata;
sp->stream.avail_in = (size_t) tif->tif_rawcc;
if ((tmsize_t)sp->stream.avail_in != tif->tif_rawcc) {
TIFFErrorExt(tif->tif_clientdata, module,
"Liblzma cannot deal with buffers this size");
return 0;
}
/*
* Disable memory limit when decoding. UINT64_MAX is a flag to disable
* the limit, we are passing (uint64_t)-1 which should be the same.
*/
ret = lzma_stream_decoder(&sp->stream, (uint64_t)-1, 0);
if (ret != LZMA_OK) {
TIFFErrorExt(tif->tif_clientdata, module,
"Error initializing the stream decoder, %s",
LZMAStrerror(ret));
return 0;
}
return 1;
}
static int
LZMADecode(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
{
static const char module[] = "LZMADecode";
LZMAState* sp = DecoderState(tif);
(void) s;
assert(sp != NULL);
assert(sp->state == LSTATE_INIT_DECODE);
sp->stream.next_in = tif->tif_rawcp;
sp->stream.avail_in = (size_t) tif->tif_rawcc;
sp->stream.next_out = op;
sp->stream.avail_out = (size_t) occ;
if ((tmsize_t)sp->stream.avail_out != occ) {
TIFFErrorExt(tif->tif_clientdata, module,
"Liblzma cannot deal with buffers this size");
return 0;
}
do {
/*
* Save the current stream state to properly recover from the
* decoding errors later.
*/
const uint8_t *next_in = sp->stream.next_in;
size_t avail_in = sp->stream.avail_in;
lzma_ret ret = lzma_code(&sp->stream, LZMA_RUN);
if (ret == LZMA_STREAM_END)
break;
if (ret == LZMA_MEMLIMIT_ERROR) {
lzma_ret r = lzma_stream_decoder(&sp->stream,
lzma_memusage(&sp->stream), 0);
if (r != LZMA_OK) {
TIFFErrorExt(tif->tif_clientdata, module,
"Error initializing the stream decoder, %s",
LZMAStrerror(r));
break;
}
sp->stream.next_in = next_in;
sp->stream.avail_in = avail_in;
continue;
}
if (ret != LZMA_OK) {
TIFFErrorExt(tif->tif_clientdata, module,
"Decoding error at scanline %lu, %s",
(unsigned long) tif->tif_row, LZMAStrerror(ret));
break;
}
} while (sp->stream.avail_out > 0);
if (sp->stream.avail_out != 0) {
TIFFErrorExt(tif->tif_clientdata, module,
"Not enough data at scanline %lu (short %lu bytes)",
(unsigned long) tif->tif_row, (unsigned long) sp->stream.avail_out);
return 0;
}
tif->tif_rawcp = (uint8 *)sp->stream.next_in; /* cast away const */
tif->tif_rawcc = sp->stream.avail_in;
return 1;
}
static int
LZMASetupEncode(TIFF* tif)
{
LZMAState* sp = EncoderState(tif);
assert(sp != NULL);
if (sp->state & LSTATE_INIT_DECODE) {
lzma_end(&sp->stream);
sp->state = 0;
}
sp->state |= LSTATE_INIT_ENCODE;
return 1;
}
/*
* Reset encoding state at the start of a strip.
*/
static int
LZMAPreEncode(TIFF* tif, uint16 s)
{
static const char module[] = "LZMAPreEncode";
LZMAState *sp = EncoderState(tif);
(void) s;
assert(sp != NULL);
if( sp->state != LSTATE_INIT_ENCODE )
tif->tif_setupencode(tif);
sp->stream.next_out = tif->tif_rawdata;
sp->stream.avail_out = (size_t)tif->tif_rawdatasize;
if ((tmsize_t)sp->stream.avail_out != tif->tif_rawdatasize) {
TIFFErrorExt(tif->tif_clientdata, module,
"Liblzma cannot deal with buffers this size");
return 0;
}
return (lzma_stream_encoder(&sp->stream, sp->filters, sp->check) == LZMA_OK);
}
/*
* Encode a chunk of pixels.
*/
static int
LZMAEncode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{
static const char module[] = "LZMAEncode";
LZMAState *sp = EncoderState(tif);
assert(sp != NULL);
assert(sp->state == LSTATE_INIT_ENCODE);
(void) s;
sp->stream.next_in = bp;
sp->stream.avail_in = (size_t) cc;
if ((tmsize_t)sp->stream.avail_in != cc) {
TIFFErrorExt(tif->tif_clientdata, module,
"Liblzma cannot deal with buffers this size");
return 0;
}
do {
lzma_ret ret = lzma_code(&sp->stream, LZMA_RUN);
if (ret != LZMA_OK) {
TIFFErrorExt(tif->tif_clientdata, module,
"Encoding error at scanline %lu, %s",
(unsigned long) tif->tif_row, LZMAStrerror(ret));
return 0;
}
if (sp->stream.avail_out == 0) {
tif->tif_rawcc = tif->tif_rawdatasize;
TIFFFlushData1(tif);
sp->stream.next_out = tif->tif_rawdata;
sp->stream.avail_out = (size_t)tif->tif_rawdatasize; /* this is a safe typecast, as check is made already in LZMAPreEncode */
}
} while (sp->stream.avail_in > 0);
return 1;
}
/*
* Finish off an encoded strip by flushing the last
* string and tacking on an End Of Information code.
*/
static int
LZMAPostEncode(TIFF* tif)
{
static const char module[] = "LZMAPostEncode";
LZMAState *sp = EncoderState(tif);
lzma_ret ret;
sp->stream.avail_in = 0;
do {
ret = lzma_code(&sp->stream, LZMA_FINISH);
switch (ret) {
case LZMA_STREAM_END:
case LZMA_OK:
if ((tmsize_t)sp->stream.avail_out != tif->tif_rawdatasize) {
tif->tif_rawcc =
tif->tif_rawdatasize - sp->stream.avail_out;
TIFFFlushData1(tif);
sp->stream.next_out = tif->tif_rawdata;
sp->stream.avail_out = (size_t)tif->tif_rawdatasize; /* this is a safe typecast, as check is made already in ZIPPreEncode */
}
break;
default:
TIFFErrorExt(tif->tif_clientdata, module, "Liblzma error: %s",
LZMAStrerror(ret));
return 0;
}
} while (ret != LZMA_STREAM_END);
return 1;
}
static void
LZMACleanup(TIFF* tif)
{
LZMAState* sp = LState(tif);
assert(sp != 0);
(void)TIFFPredictorCleanup(tif);
tif->tif_tagmethods.vgetfield = sp->vgetparent;
tif->tif_tagmethods.vsetfield = sp->vsetparent;
if (sp->state) {
lzma_end(&sp->stream);
sp->state = 0;
}
_TIFFfree(sp);
tif->tif_data = NULL;
_TIFFSetDefaultCompressionState(tif);
}
static int
LZMAVSetField(TIFF* tif, uint32 tag, va_list ap)
{
static const char module[] = "LZMAVSetField";
LZMAState* sp = LState(tif);
switch (tag) {
case TIFFTAG_LZMAPRESET:
sp->preset = (int) va_arg(ap, int);
lzma_lzma_preset(&sp->opt_lzma, sp->preset);
if (sp->state & LSTATE_INIT_ENCODE) {
lzma_ret ret = lzma_stream_encoder(&sp->stream,
sp->filters,
sp->check);
if (ret != LZMA_OK) {
TIFFErrorExt(tif->tif_clientdata, module,
"Liblzma error: %s",
LZMAStrerror(ret));
}
}
return 1;
default:
return (*sp->vsetparent)(tif, tag, ap);
}
/*NOTREACHED*/
}
static int
LZMAVGetField(TIFF* tif, uint32 tag, va_list ap)
{
LZMAState* sp = LState(tif);
switch (tag) {
case TIFFTAG_LZMAPRESET:
*va_arg(ap, int*) = sp->preset;
break;
default:
return (*sp->vgetparent)(tif, tag, ap);
}
return 1;
}
static const TIFFField lzmaFields[] = {
{ TIFFTAG_LZMAPRESET, 0, 0, TIFF_ANY, 0, TIFF_SETGET_INT, TIFF_SETGET_UNDEFINED,
FIELD_PSEUDO, TRUE, FALSE, "LZMA2 Compression Preset", NULL },
};
int
TIFFInitLZMA(TIFF* tif, int scheme)
{
static const char module[] = "TIFFInitLZMA";
LZMAState* sp;
lzma_stream tmp_stream = LZMA_STREAM_INIT;
assert( scheme == COMPRESSION_LZMA );
/*
* Merge codec-specific tag information.
*/
if (!_TIFFMergeFields(tif, lzmaFields, TIFFArrayCount(lzmaFields))) {
TIFFErrorExt(tif->tif_clientdata, module,
"Merging LZMA2 codec-specific tags failed");
return 0;
}
/*
* Allocate state block so tag methods have storage to record values.
*/
tif->tif_data = (uint8*) _TIFFmalloc(sizeof(LZMAState));
if (tif->tif_data == NULL)
goto bad;
sp = LState(tif);
memcpy(&sp->stream, &tmp_stream, sizeof(lzma_stream));
/*
* Override parent get/set field methods.
*/
sp->vgetparent = tif->tif_tagmethods.vgetfield;
tif->tif_tagmethods.vgetfield = LZMAVGetField; /* hook for codec tags */
sp->vsetparent = tif->tif_tagmethods.vsetfield;
tif->tif_tagmethods.vsetfield = LZMAVSetField; /* hook for codec tags */
/* Default values for codec-specific fields */
sp->preset = LZMA_PRESET_DEFAULT; /* default comp. level */
sp->check = LZMA_CHECK_NONE;
sp->state = 0;
/* Data filters. So far we are using delta and LZMA2 filters only. */
sp->opt_delta.type = LZMA_DELTA_TYPE_BYTE;
/*
* The sample size in bytes seems to be reasonable distance for delta
* filter.
*/
sp->opt_delta.dist = (tif->tif_dir.td_bitspersample % 8) ?
1 : tif->tif_dir.td_bitspersample / 8;
sp->filters[0].id = LZMA_FILTER_DELTA;
sp->filters[0].options = &sp->opt_delta;
lzma_lzma_preset(&sp->opt_lzma, sp->preset);
sp->filters[1].id = LZMA_FILTER_LZMA2;
sp->filters[1].options = &sp->opt_lzma;
sp->filters[2].id = LZMA_VLI_UNKNOWN;
sp->filters[2].options = NULL;
/*
* Install codec methods.
*/
tif->tif_fixuptags = LZMAFixupTags;
tif->tif_setupdecode = LZMASetupDecode;
tif->tif_predecode = LZMAPreDecode;
tif->tif_decoderow = LZMADecode;
tif->tif_decodestrip = LZMADecode;
tif->tif_decodetile = LZMADecode;
tif->tif_setupencode = LZMASetupEncode;
tif->tif_preencode = LZMAPreEncode;
tif->tif_postencode = LZMAPostEncode;
tif->tif_encoderow = LZMAEncode;
tif->tif_encodestrip = LZMAEncode;
tif->tif_encodetile = LZMAEncode;
tif->tif_cleanup = LZMACleanup;
/*
* Setup predictor setup.
*/
(void) TIFFPredictorInit(tif);
return 1;
bad:
TIFFErrorExt(tif->tif_clientdata, module,
"No space for LZMA2 state block");
return 0;
}
#endif /* LZMA_SUPORT */
/* vim: set ts=8 sts=8 sw=8 noet: */

View File

@ -1,4 +1,4 @@
/* $Id: tif_lzw.c,v 1.29.2.6 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_lzw.c,v 1.45 2011-04-02 20:54:09 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -27,7 +27,7 @@
#include "tiffiop.h" #include "tiffiop.h"
#ifdef LZW_SUPPORT #ifdef LZW_SUPPORT
/* /*
* TIFF Library. * TIFF Library.
* Rev 5.0 Lempel-Ziv & Welch Compression Support * Rev 5.0 Lempel-Ziv & Welch Compression Support
* *
* This code is derived from the compress program whose code is * This code is derived from the compress program whose code is
@ -53,34 +53,34 @@
* *
* Future revisions to the TIFF spec are expected to "clarify this issue". * Future revisions to the TIFF spec are expected to "clarify this issue".
*/ */
#define LZW_COMPAT /* include backwards compatibility code */ #define LZW_COMPAT /* include backwards compatibility code */
/* /*
* Each strip of data is supposed to be terminated by a CODE_EOI. * Each strip of data is supposed to be terminated by a CODE_EOI.
* If the following #define is included, the decoder will also * If the following #define is included, the decoder will also
* check for end-of-strip w/o seeing this code. This makes the * check for end-of-strip w/o seeing this code. This makes the
* library more robust, but also slower. * library more robust, but also slower.
*/ */
#define LZW_CHECKEOS /* include checks for strips w/o EOI code */ #define LZW_CHECKEOS /* include checks for strips w/o EOI code */
#define MAXCODE(n) ((1L<<(n))-1) #define MAXCODE(n) ((1L<<(n))-1)
/* /*
* The TIFF spec specifies that encoded bit * The TIFF spec specifies that encoded bit
* strings range from 9 to 12 bits. * strings range from 9 to 12 bits.
*/ */
#define BITS_MIN 9 /* start with 9 bits */ #define BITS_MIN 9 /* start with 9 bits */
#define BITS_MAX 12 /* max of 12 bit strings */ #define BITS_MAX 12 /* max of 12 bit strings */
/* predefined codes */ /* predefined codes */
#define CODE_CLEAR 256 /* code to clear string table */ #define CODE_CLEAR 256 /* code to clear string table */
#define CODE_EOI 257 /* end-of-information code */ #define CODE_EOI 257 /* end-of-information code */
#define CODE_FIRST 258 /* first free code entry */ #define CODE_FIRST 258 /* first free code entry */
#define CODE_MAX MAXCODE(BITS_MAX) #define CODE_MAX MAXCODE(BITS_MAX)
#define HSIZE 9001L /* 91% occupancy */ #define HSIZE 9001L /* 91% occupancy */
#define HSHIFT (13-8) #define HSHIFT (13-8)
#ifdef LZW_COMPAT #ifdef LZW_COMPAT
/* NB: +1024 is for compatibility with old files */ /* NB: +1024 is for compatibility with old files */
#define CSIZE (MAXCODE(BITS_MAX)+1024L) #define CSIZE (MAXCODE(BITS_MAX)+1024L)
#else #else
#define CSIZE (MAXCODE(BITS_MAX)+1L) #define CSIZE (MAXCODE(BITS_MAX)+1L)
#endif #endif
/* /*
@ -88,23 +88,23 @@
* compression/decompression. Note that the predictor * compression/decompression. Note that the predictor
* state block must be first in this data structure. * state block must be first in this data structure.
*/ */
typedef struct { typedef struct {
TIFFPredictorState predict; /* predictor super class */ TIFFPredictorState predict; /* predictor super class */
unsigned short nbits; /* # of bits/code */ unsigned short nbits; /* # of bits/code */
unsigned short maxcode; /* maximum code for lzw_nbits */ unsigned short maxcode; /* maximum code for lzw_nbits */
unsigned short free_ent; /* next free entry in hash table */ unsigned short free_ent; /* next free entry in hash table */
long nextdata; /* next bits of i/o */ long nextdata; /* next bits of i/o */
long nextbits; /* # of valid bits in lzw_nextdata */ long nextbits; /* # of valid bits in lzw_nextdata */
int rw_mode; /* preserve rw_mode from init */ int rw_mode; /* preserve rw_mode from init */
} LZWBaseState; } LZWBaseState;
#define lzw_nbits base.nbits #define lzw_nbits base.nbits
#define lzw_maxcode base.maxcode #define lzw_maxcode base.maxcode
#define lzw_free_ent base.free_ent #define lzw_free_ent base.free_ent
#define lzw_nextdata base.nextdata #define lzw_nextdata base.nextdata
#define lzw_nextbits base.nextbits #define lzw_nextbits base.nextbits
/* /*
* Encoding-specific state. * Encoding-specific state.
@ -125,44 +125,44 @@ typedef struct code_ent {
unsigned char firstchar; /* first token of string */ unsigned char firstchar; /* first token of string */
} code_t; } code_t;
typedef int (*decodeFunc)(TIFF*, tidata_t, tsize_t, tsample_t); typedef int (*decodeFunc)(TIFF*, uint8*, tmsize_t, uint16);
typedef struct { typedef struct {
LZWBaseState base; LZWBaseState base;
/* Decoding specific data */ /* Decoding specific data */
long dec_nbitsmask; /* lzw_nbits 1 bits, right adjusted */ long dec_nbitsmask; /* lzw_nbits 1 bits, right adjusted */
long dec_restart; /* restart count */ long dec_restart; /* restart count */
#ifdef LZW_CHECKEOS #ifdef LZW_CHECKEOS
long dec_bitsleft; /* available bits in raw data */ uint64 dec_bitsleft; /* available bits in raw data */
#endif #endif
decodeFunc dec_decode; /* regular or backwards compatible */ decodeFunc dec_decode; /* regular or backwards compatible */
code_t* dec_codep; /* current recognized code */ code_t* dec_codep; /* current recognized code */
code_t* dec_oldcodep; /* previously recognized code */ code_t* dec_oldcodep; /* previously recognized code */
code_t* dec_free_entp; /* next free entry */ code_t* dec_free_entp; /* next free entry */
code_t* dec_maxcodep; /* max available entry */ code_t* dec_maxcodep; /* max available entry */
code_t* dec_codetab; /* kept separate for small machines */ code_t* dec_codetab; /* kept separate for small machines */
/* Encoding specific data */ /* Encoding specific data */
int enc_oldcode; /* last code encountered */ int enc_oldcode; /* last code encountered */
long enc_checkpoint; /* point at which to clear table */ long enc_checkpoint; /* point at which to clear table */
#define CHECK_GAP 10000 /* enc_ratio check interval */ #define CHECK_GAP 10000 /* enc_ratio check interval */
long enc_ratio; /* current compression ratio */ long enc_ratio; /* current compression ratio */
long enc_incount; /* (input) data bytes encoded */ long enc_incount; /* (input) data bytes encoded */
long enc_outcount; /* encoded (output) bytes */ long enc_outcount; /* encoded (output) bytes */
tidata_t enc_rawlimit; /* bound on tif_rawdata buffer */ uint8* enc_rawlimit; /* bound on tif_rawdata buffer */
hash_t* enc_hashtab; /* kept separate for small machines */ hash_t* enc_hashtab; /* kept separate for small machines */
} LZWCodecState; } LZWCodecState;
#define LZWState(tif) ((LZWBaseState*) (tif)->tif_data) #define LZWState(tif) ((LZWBaseState*) (tif)->tif_data)
#define DecoderState(tif) ((LZWCodecState*) LZWState(tif)) #define DecoderState(tif) ((LZWCodecState*) LZWState(tif))
#define EncoderState(tif) ((LZWCodecState*) LZWState(tif)) #define EncoderState(tif) ((LZWCodecState*) LZWState(tif))
static int LZWDecode(TIFF*, tidata_t, tsize_t, tsample_t); static int LZWDecode(TIFF* tif, uint8* op0, tmsize_t occ0, uint16 s);
#ifdef LZW_COMPAT #ifdef LZW_COMPAT
static int LZWDecodeCompat(TIFF*, tidata_t, tsize_t, tsample_t); static int LZWDecodeCompat(TIFF* tif, uint8* op0, tmsize_t occ0, uint16 s);
#endif #endif
static void cl_hash(LZWCodecState*); static void cl_hash(LZWCodecState*);
/* /*
* LZW Decoder. * LZW Decoder.
@ -174,8 +174,8 @@ static void cl_hash(LZWCodecState*);
* strip is suppose to be terminated with CODE_EOI. * strip is suppose to be terminated with CODE_EOI.
*/ */
#define NextCode(_tif, _sp, _bp, _code, _get) { \ #define NextCode(_tif, _sp, _bp, _code, _get) { \
if ((_sp)->dec_bitsleft < nbits) { \ if ((_sp)->dec_bitsleft < (uint64)nbits) { \
TIFFWarningExt(_tif->tif_clientdata, _tif->tif_name, \ TIFFWarningExt(_tif->tif_clientdata, module, \
"LZWDecode: Strip %d not terminated with EOI code", \ "LZWDecode: Strip %d not terminated with EOI code", \
_tif->tif_curstrip); \ _tif->tif_curstrip); \
_code = CODE_EOI; \ _code = CODE_EOI; \
@ -188,37 +188,44 @@ static void cl_hash(LZWCodecState*);
#define NextCode(tif, sp, bp, code, get) get(sp, bp, code) #define NextCode(tif, sp, bp, code, get) get(sp, bp, code)
#endif #endif
static int
LZWFixupTags(TIFF* tif)
{
(void) tif;
return (1);
}
static int static int
LZWSetupDecode(TIFF* tif) LZWSetupDecode(TIFF* tif)
{ {
static const char module[] = "LZWSetupDecode";
LZWCodecState* sp = DecoderState(tif); LZWCodecState* sp = DecoderState(tif);
static const char module[] = " LZWSetupDecode";
int code; int code;
if( sp == NULL ) if( sp == NULL )
{ {
/* /*
* Allocate state block so tag methods have storage to record * Allocate state block so tag methods have storage to record
* values. * values.
*/ */
tif->tif_data = (tidata_t) _TIFFmalloc(sizeof(LZWCodecState)); tif->tif_data = (uint8*) _TIFFmalloc(sizeof(LZWCodecState));
if (tif->tif_data == NULL) if (tif->tif_data == NULL)
{ {
TIFFErrorExt(tif->tif_clientdata, "LZWPreDecode", "No space for LZW state block"); TIFFErrorExt(tif->tif_clientdata, module, "No space for LZW state block");
return (0); return (0);
} }
DecoderState(tif)->dec_codetab = NULL; DecoderState(tif)->dec_codetab = NULL;
DecoderState(tif)->dec_decode = NULL; DecoderState(tif)->dec_decode = NULL;
/* /*
* Setup predictor setup. * Setup predictor setup.
*/ */
(void) TIFFPredictorInit(tif); (void) TIFFPredictorInit(tif);
sp = DecoderState(tif);
}
sp = DecoderState(tif);
}
assert(sp != NULL); assert(sp != NULL);
if (sp->dec_codetab == NULL) { if (sp->dec_codetab == NULL) {
@ -231,13 +238,13 @@ LZWSetupDecode(TIFF* tif)
/* /*
* Pre-load the table. * Pre-load the table.
*/ */
code = 255; code = 255;
do { do {
sp->dec_codetab[code].value = code; sp->dec_codetab[code].value = code;
sp->dec_codetab[code].firstchar = code; sp->dec_codetab[code].firstchar = code;
sp->dec_codetab[code].length = 1; sp->dec_codetab[code].length = 1;
sp->dec_codetab[code].next = NULL; sp->dec_codetab[code].next = NULL;
} while (code--); } while (code--);
/* /*
* Zero-out the unused entries * Zero-out the unused entries
*/ */
@ -251,13 +258,14 @@ LZWSetupDecode(TIFF* tif)
* Setup state for decoding a strip. * Setup state for decoding a strip.
*/ */
static int static int
LZWPreDecode(TIFF* tif, tsample_t s) LZWPreDecode(TIFF* tif, uint16 s)
{ {
static const char module[] = "LZWPreDecode";
LZWCodecState *sp = DecoderState(tif); LZWCodecState *sp = DecoderState(tif);
(void) s; (void) s;
assert(sp != NULL); assert(sp != NULL);
if( sp->dec_codetab == NULL ) if( sp->dec_codetab == NULL )
{ {
tif->tif_setupdecode( tif ); tif->tif_setupdecode( tif );
} }
@ -268,7 +276,7 @@ LZWPreDecode(TIFF* tif, tsample_t s)
if (tif->tif_rawdata[0] == 0 && (tif->tif_rawdata[1] & 0x1)) { if (tif->tif_rawdata[0] == 0 && (tif->tif_rawdata[1] & 0x1)) {
#ifdef LZW_COMPAT #ifdef LZW_COMPAT
if (!sp->dec_decode) { if (!sp->dec_decode) {
TIFFWarningExt(tif->tif_clientdata, tif->tif_name, TIFFWarningExt(tif->tif_clientdata, module,
"Old-style LZW codes, convert file"); "Old-style LZW codes, convert file");
/* /*
* Override default decoding methods with * Override default decoding methods with
@ -291,7 +299,7 @@ LZWPreDecode(TIFF* tif, tsample_t s)
sp->lzw_maxcode = MAXCODE(BITS_MIN); sp->lzw_maxcode = MAXCODE(BITS_MIN);
#else /* !LZW_COMPAT */ #else /* !LZW_COMPAT */
if (!sp->dec_decode) { if (!sp->dec_decode) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"Old-style LZW codes not supported"); "Old-style LZW codes not supported");
sp->dec_decode = LZWDecode; sp->dec_decode = LZWDecode;
} }
@ -308,7 +316,7 @@ LZWPreDecode(TIFF* tif, tsample_t s)
sp->dec_restart = 0; sp->dec_restart = 0;
sp->dec_nbitsmask = MAXCODE(BITS_MIN); sp->dec_nbitsmask = MAXCODE(BITS_MIN);
#ifdef LZW_CHECKEOS #ifdef LZW_CHECKEOS
sp->dec_bitsleft = tif->tif_rawcc << 3; sp->dec_bitsleft = ((uint64)tif->tif_rawcc) << 3;
#endif #endif
sp->dec_free_entp = sp->dec_codetab + CODE_FIRST; sp->dec_free_entp = sp->dec_codetab + CODE_FIRST;
/* /*
@ -339,16 +347,17 @@ LZWPreDecode(TIFF* tif, tsample_t s)
} }
static void static void
codeLoop(TIFF* tif) codeLoop(TIFF* tif, const char* module)
{ {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"LZWDecode: Bogus encoding, loop in the code table; scanline %d", "Bogus encoding, loop in the code table; scanline %d",
tif->tif_row); tif->tif_row);
} }
static int static int
LZWDecode(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s) LZWDecode(TIFF* tif, uint8* op0, tmsize_t occ0, uint16 s)
{ {
static const char module[] = "LZWDecode";
LZWCodecState *sp = DecoderState(tif); LZWCodecState *sp = DecoderState(tif);
char *op = (char*) op0; char *op = (char*) op0;
long occ = (long) occ0; long occ = (long) occ0;
@ -362,6 +371,12 @@ LZWDecode(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
(void) s; (void) s;
assert(sp != NULL); assert(sp != NULL);
assert(sp->dec_codetab != NULL); assert(sp->dec_codetab != NULL);
/*
Fail if value does not fit in long.
*/
if ((tmsize_t) occ != occ0)
return (0);
/* /*
* Restart interrupted output operation. * Restart interrupted output operation.
*/ */
@ -428,7 +443,7 @@ LZWDecode(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
NextCode(tif, sp, bp, code, GetNextCode); NextCode(tif, sp, bp, code, GetNextCode);
if (code == CODE_EOI) if (code == CODE_EOI)
break; break;
if (code == CODE_CLEAR) { if (code >= CODE_CLEAR) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, tif->tif_name,
"LZWDecode: Corrupted LZW table at scanline %d", "LZWDecode: Corrupted LZW table at scanline %d",
tif->tif_row); tif->tif_row);
@ -441,22 +456,22 @@ LZWDecode(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
codep = sp->dec_codetab + code; codep = sp->dec_codetab + code;
/* /*
* Add the new entry to the code table. * Add the new entry to the code table.
*/ */
if (free_entp < &sp->dec_codetab[0] || if (free_entp < &sp->dec_codetab[0] ||
free_entp >= &sp->dec_codetab[CSIZE]) { free_entp >= &sp->dec_codetab[CSIZE]) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"LZWDecode: Corrupted LZW table at scanline %d", "Corrupted LZW table at scanline %d",
tif->tif_row); tif->tif_row);
return (0); return (0);
} }
free_entp->next = oldcodep; free_entp->next = oldcodep;
if (free_entp->next < &sp->dec_codetab[0] || if (free_entp->next < &sp->dec_codetab[0] ||
free_entp->next >= &sp->dec_codetab[CSIZE]) { free_entp->next >= &sp->dec_codetab[CSIZE]) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"LZWDecode: Corrupted LZW table at scanline %d", "Corrupted LZW table at scanline %d",
tif->tif_row); tif->tif_row);
return (0); return (0);
} }
free_entp->firstchar = free_entp->next->firstchar; free_entp->firstchar = free_entp->next->firstchar;
@ -472,15 +487,15 @@ LZWDecode(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
oldcodep = codep; oldcodep = codep;
if (code >= 256) { if (code >= 256) {
/* /*
* Code maps to a string, copy string * Code maps to a string, copy string
* value to output (written in reverse). * value to output (written in reverse).
*/ */
if(codep->length == 0) { if(codep->length == 0) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"LZWDecode: Wrong length of decoded string: " "Wrong length of decoded string: "
"data probably corrupted at scanline %d", "data probably corrupted at scanline %d",
tif->tif_row); tif->tif_row);
return (0); return (0);
} }
if (codep->length > occ) { if (codep->length > occ) {
/* /*
@ -494,14 +509,14 @@ LZWDecode(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
codep = codep->next; codep = codep->next;
} while (codep && codep->length > occ); } while (codep && codep->length > occ);
if (codep) { if (codep) {
sp->dec_restart = occ; sp->dec_restart = (long)occ;
tp = op + occ; tp = op + occ;
do { do {
*--tp = codep->value; *--tp = codep->value;
codep = codep->next; codep = codep->next;
} while (--occ && codep); } while (--occ && codep);
if (codep) if (codep)
codeLoop(tif); codeLoop(tif, module);
} }
break; break;
} }
@ -515,15 +530,16 @@ LZWDecode(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
*tp = t; *tp = t;
} while (codep && tp > op); } while (codep && tp > op);
if (codep) { if (codep) {
codeLoop(tif); codeLoop(tif, module);
break; break;
} }
assert(occ >= len);
op += len, occ -= len; op += len, occ -= len;
} else } else
*op++ = (char)code, occ--; *op++ = (char)code, occ--;
} }
tif->tif_rawcp = (tidata_t) bp; tif->tif_rawcp = (uint8*) bp;
sp->lzw_nbits = (unsigned short) nbits; sp->lzw_nbits = (unsigned short) nbits;
sp->lzw_nextdata = nextdata; sp->lzw_nextdata = nextdata;
sp->lzw_nextbits = nextbits; sp->lzw_nextbits = nextbits;
@ -533,9 +549,15 @@ LZWDecode(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
sp->dec_maxcodep = maxcodep; sp->dec_maxcodep = maxcodep;
if (occ > 0) { if (occ > 0) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
"LZWDecode: Not enough data at scanline %d (short %ld bytes)", TIFFErrorExt(tif->tif_clientdata, module,
tif->tif_row, occ); "Not enough data at scanline %d (short %I64d bytes)",
tif->tif_row, (unsigned __int64) occ);
#else
TIFFErrorExt(tif->tif_clientdata, module,
"Not enough data at scanline %d (short %llu bytes)",
tif->tif_row, (unsigned long long) occ);
#endif
return (0); return (0);
} }
return (1); return (1);
@ -558,8 +580,9 @@ LZWDecode(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
} }
static int static int
LZWDecodeCompat(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s) LZWDecodeCompat(TIFF* tif, uint8* op0, tmsize_t occ0, uint16 s)
{ {
static const char module[] = "LZWDecodeCompat";
LZWCodecState *sp = DecoderState(tif); LZWCodecState *sp = DecoderState(tif);
char *op = (char*) op0; char *op = (char*) op0;
long occ = (long) occ0; long occ = (long) occ0;
@ -571,6 +594,13 @@ LZWDecodeCompat(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
(void) s; (void) s;
assert(sp != NULL); assert(sp != NULL);
/*
Fail if value does not fit in long.
*/
if ((tmsize_t) occ != occ0)
return (0);
/* /*
* Restart interrupted output operation. * Restart interrupted output operation.
*/ */
@ -632,7 +662,7 @@ LZWDecodeCompat(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
NextCode(tif, sp, bp, code, GetNextCodeCompat); NextCode(tif, sp, bp, code, GetNextCodeCompat);
if (code == CODE_EOI) if (code == CODE_EOI)
break; break;
if (code == CODE_CLEAR) { if (code >= CODE_CLEAR) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, tif->tif_name,
"LZWDecode: Corrupted LZW table at scanline %d", "LZWDecode: Corrupted LZW table at scanline %d",
tif->tif_row); tif->tif_row);
@ -645,22 +675,20 @@ LZWDecodeCompat(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
codep = sp->dec_codetab + code; codep = sp->dec_codetab + code;
/* /*
* Add the new entry to the code table. * Add the new entry to the code table.
*/ */
if (free_entp < &sp->dec_codetab[0] || if (free_entp < &sp->dec_codetab[0] ||
free_entp >= &sp->dec_codetab[CSIZE]) { free_entp >= &sp->dec_codetab[CSIZE]) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"LZWDecodeCompat: Corrupted LZW table at scanline %d", "Corrupted LZW table at scanline %d", tif->tif_row);
tif->tif_row);
return (0); return (0);
} }
free_entp->next = oldcodep; free_entp->next = oldcodep;
if (free_entp->next < &sp->dec_codetab[0] || if (free_entp->next < &sp->dec_codetab[0] ||
free_entp->next >= &sp->dec_codetab[CSIZE]) { free_entp->next >= &sp->dec_codetab[CSIZE]) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"LZWDecodeCompat: Corrupted LZW table at scanline %d", "Corrupted LZW table at scanline %d", tif->tif_row);
tif->tif_row);
return (0); return (0);
} }
free_entp->firstchar = free_entp->next->firstchar; free_entp->firstchar = free_entp->next->firstchar;
@ -675,17 +703,16 @@ LZWDecodeCompat(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
} }
oldcodep = codep; oldcodep = codep;
if (code >= 256) { if (code >= 256) {
char *op_orig = op;
/* /*
* Code maps to a string, copy string * Code maps to a string, copy string
* value to output (written in reverse). * value to output (written in reverse).
*/ */
if(codep->length == 0) { if(codep->length == 0) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"LZWDecodeCompat: Wrong length of decoded " "Wrong length of decoded "
"string: data probably corrupted at scanline %d", "string: data probably corrupted at scanline %d",
tif->tif_row); tif->tif_row);
return (0); return (0);
} }
if (codep->length > occ) { if (codep->length > occ) {
/* /*
@ -706,16 +733,17 @@ LZWDecodeCompat(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
} while (--occ); } while (--occ);
break; break;
} }
assert(occ >= codep->length);
op += codep->length, occ -= codep->length; op += codep->length, occ -= codep->length;
tp = op; tp = op;
do { do {
*--tp = codep->value; *--tp = codep->value;
} while( (codep = codep->next) != NULL && tp > op_orig); } while( (codep = codep->next) != NULL );
} else } else
*op++ = code, occ--; *op++ = code, occ--;
} }
tif->tif_rawcp = (tidata_t) bp; tif->tif_rawcp = (uint8*) bp;
sp->lzw_nbits = nbits; sp->lzw_nbits = nbits;
sp->lzw_nextdata = nextdata; sp->lzw_nextdata = nextdata;
sp->lzw_nextbits = nextbits; sp->lzw_nextbits = nextbits;
@ -725,9 +753,15 @@ LZWDecodeCompat(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
sp->dec_maxcodep = maxcodep; sp->dec_maxcodep = maxcodep;
if (occ > 0) { if (occ > 0) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
"LZWDecodeCompat: Not enough data at scanline %d (short %ld bytes)", TIFFErrorExt(tif->tif_clientdata, module,
tif->tif_row, occ); "Not enough data at scanline %d (short %I64d bytes)",
tif->tif_row, (unsigned __int64) occ);
#else
TIFFErrorExt(tif->tif_clientdata, module,
"Not enough data at scanline %d (short %llu bytes)",
tif->tif_row, (unsigned long long) occ);
#endif
return (0); return (0);
} }
return (1); return (1);
@ -741,13 +775,14 @@ LZWDecodeCompat(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
static int static int
LZWSetupEncode(TIFF* tif) LZWSetupEncode(TIFF* tif)
{ {
LZWCodecState* sp = EncoderState(tif);
static const char module[] = "LZWSetupEncode"; static const char module[] = "LZWSetupEncode";
LZWCodecState* sp = EncoderState(tif);
assert(sp != NULL); assert(sp != NULL);
sp->enc_hashtab = (hash_t*) _TIFFmalloc(HSIZE*sizeof (hash_t)); sp->enc_hashtab = (hash_t*) _TIFFmalloc(HSIZE*sizeof (hash_t));
if (sp->enc_hashtab == NULL) { if (sp->enc_hashtab == NULL) {
TIFFErrorExt(tif->tif_clientdata, module, "No space for LZW hash table"); TIFFErrorExt(tif->tif_clientdata, module,
"No space for LZW hash table");
return (0); return (0);
} }
return (1); return (1);
@ -757,14 +792,14 @@ LZWSetupEncode(TIFF* tif)
* Reset encoding state at the start of a strip. * Reset encoding state at the start of a strip.
*/ */
static int static int
LZWPreEncode(TIFF* tif, tsample_t s) LZWPreEncode(TIFF* tif, uint16 s)
{ {
LZWCodecState *sp = EncoderState(tif); LZWCodecState *sp = EncoderState(tif);
(void) s; (void) s;
assert(sp != NULL); assert(sp != NULL);
if( sp->enc_hashtab == NULL ) if( sp->enc_hashtab == NULL )
{ {
tif->tif_setupencode( tif ); tif->tif_setupencode( tif );
} }
@ -822,7 +857,7 @@ LZWPreEncode(TIFF* tif, tsample_t s)
* for the decoder. * for the decoder.
*/ */
static int static int
LZWEncode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) LZWEncode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
register LZWCodecState *sp = EncoderState(tif); register LZWCodecState *sp = EncoderState(tif);
register long fcode; register long fcode;
@ -833,7 +868,8 @@ LZWEncode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
long incount, outcount, checkpoint; long incount, outcount, checkpoint;
long nextdata, nextbits; long nextdata, nextbits;
int free_ent, maxcode, nbits; int free_ent, maxcode, nbits;
tidata_t op, limit; uint8* op;
uint8* limit;
(void) s; (void) s;
if (sp == NULL) if (sp == NULL)
@ -912,7 +948,7 @@ LZWEncode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
* are at least 4 bytes free--room for 2 codes. * are at least 4 bytes free--room for 2 codes.
*/ */
if (op > limit) { if (op > limit) {
tif->tif_rawcc = (tsize_t)(op - tif->tif_rawdata); tif->tif_rawcc = (tmsize_t)(op - tif->tif_rawdata);
TIFFFlushData1(tif); TIFFFlushData1(tif);
op = tif->tif_rawdata; op = tif->tif_rawdata;
} }
@ -990,14 +1026,14 @@ static int
LZWPostEncode(TIFF* tif) LZWPostEncode(TIFF* tif)
{ {
register LZWCodecState *sp = EncoderState(tif); register LZWCodecState *sp = EncoderState(tif);
tidata_t op = tif->tif_rawcp; uint8* op = tif->tif_rawcp;
long nextbits = sp->lzw_nextbits; long nextbits = sp->lzw_nextbits;
long nextdata = sp->lzw_nextdata; long nextdata = sp->lzw_nextdata;
long outcount = sp->enc_outcount; long outcount = sp->enc_outcount;
int nbits = sp->lzw_nbits; int nbits = sp->lzw_nbits;
if (op > sp->enc_rawlimit) { if (op > sp->enc_rawlimit) {
tif->tif_rawcc = (tsize_t)(op - tif->tif_rawdata); tif->tif_rawcc = (tmsize_t)(op - tif->tif_rawdata);
TIFFFlushData1(tif); TIFFFlushData1(tif);
op = tif->tif_rawdata; op = tif->tif_rawdata;
} }
@ -1008,7 +1044,7 @@ LZWPostEncode(TIFF* tif)
PutNextCode(op, CODE_EOI); PutNextCode(op, CODE_EOI);
if (nextbits > 0) if (nextbits > 0)
*op++ = (unsigned char)(nextdata << (8-nextbits)); *op++ = (unsigned char)(nextdata << (8-nextbits));
tif->tif_rawcc = (tsize_t)(op - tif->tif_rawdata); tif->tif_rawcc = (tmsize_t)(op - tif->tif_rawdata);
return (1); return (1);
} }
@ -1021,7 +1057,7 @@ cl_hash(LZWCodecState* sp)
register hash_t *hp = &sp->enc_hashtab[HSIZE-1]; register hash_t *hp = &sp->enc_hashtab[HSIZE-1];
register long i = HSIZE-8; register long i = HSIZE-8;
do { do {
i -= 8; i -= 8;
hp[-7].hash = -1; hp[-7].hash = -1;
hp[-6].hash = -1; hp[-6].hash = -1;
@ -1033,7 +1069,7 @@ cl_hash(LZWCodecState* sp)
hp[ 0].hash = -1; hp[ 0].hash = -1;
hp -= 8; hp -= 8;
} while (i >= 0); } while (i >= 0);
for (i += 8; i > 0; i--, hp--) for (i += 8; i > 0; i--, hp--)
hp->hash = -1; hp->hash = -1;
} }
@ -1059,11 +1095,12 @@ LZWCleanup(TIFF* tif)
int int
TIFFInitLZW(TIFF* tif, int scheme) TIFFInitLZW(TIFF* tif, int scheme)
{ {
static const char module[] = "TIFFInitLZW";
assert(scheme == COMPRESSION_LZW); assert(scheme == COMPRESSION_LZW);
/* /*
* Allocate state block so tag methods have storage to record values. * Allocate state block so tag methods have storage to record values.
*/ */
tif->tif_data = (tidata_t) _TIFFmalloc(sizeof (LZWCodecState)); tif->tif_data = (uint8*) _TIFFmalloc(sizeof (LZWCodecState));
if (tif->tif_data == NULL) if (tif->tif_data == NULL)
goto bad; goto bad;
DecoderState(tif)->dec_codetab = NULL; DecoderState(tif)->dec_codetab = NULL;
@ -1074,6 +1111,7 @@ TIFFInitLZW(TIFF* tif, int scheme)
/* /*
* Install codec methods. * Install codec methods.
*/ */
tif->tif_fixuptags = LZWFixupTags;
tif->tif_setupdecode = LZWSetupDecode; tif->tif_setupdecode = LZWSetupDecode;
tif->tif_predecode = LZWPreDecode; tif->tif_predecode = LZWPreDecode;
tif->tif_decoderow = LZWDecode; tif->tif_decoderow = LZWDecode;
@ -1092,7 +1130,7 @@ TIFFInitLZW(TIFF* tif, int scheme)
(void) TIFFPredictorInit(tif); (void) TIFFPredictorInit(tif);
return (1); return (1);
bad: bad:
TIFFErrorExt(tif->tif_clientdata, "TIFFInitLZW", TIFFErrorExt(tif->tif_clientdata, module,
"No space for LZW state block"); "No space for LZW state block");
return (0); return (0);
} }

View File

@ -1,4 +1,4 @@
/* $Id: tif_next.c,v 1.8.2.1 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_next.c,v 1.13 2010-03-10 18:56:48 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -46,12 +46,13 @@
#define WHITE ((1<<2)-1) #define WHITE ((1<<2)-1)
static int static int
NeXTDecode(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s) NeXTDecode(TIFF* tif, uint8* buf, tmsize_t occ, uint16 s)
{ {
static const char module[] = "NeXTDecode";
unsigned char *bp, *op; unsigned char *bp, *op;
tsize_t cc; tmsize_t cc;
tidata_t row; uint8* row;
tsize_t scanline, n; tmsize_t scanline, n;
(void) s; (void) s;
/* /*
@ -59,12 +60,17 @@ NeXTDecode(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s)
* white (we assume a PhotometricInterpretation * white (we assume a PhotometricInterpretation
* of ``min-is-black''). * of ``min-is-black'').
*/ */
for (op = buf, cc = occ; cc-- > 0;) for (op = (unsigned char*) buf, cc = occ; cc-- > 0;)
*op++ = 0xff; *op++ = 0xff;
bp = (unsigned char *)tif->tif_rawcp; bp = (unsigned char *)tif->tif_rawcp;
cc = tif->tif_rawcc; cc = tif->tif_rawcc;
scanline = tif->tif_scanlinesize; scanline = tif->tif_scanlinesize;
if (occ % scanline)
{
TIFFErrorExt(tif->tif_clientdata, module, "Fractional scanlines cannot be read");
return (0);
}
for (row = buf; occ > 0; occ -= scanline, row += scanline) { for (row = buf; occ > 0; occ -= scanline, row += scanline) {
n = *bp++, cc--; n = *bp++, cc--;
switch (n) { switch (n) {
@ -79,7 +85,7 @@ NeXTDecode(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s)
cc -= scanline; cc -= scanline;
break; break;
case LITERALSPAN: { case LITERALSPAN: {
tsize_t off; tmsize_t off;
/* /*
* The scanline has a literal span that begins at some * The scanline has a literal span that begins at some
* offset. * offset.
@ -105,7 +111,7 @@ NeXTDecode(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s)
*/ */
op = row; op = row;
for (;;) { for (;;) {
grey = (n>>6) & 0x3; grey = (uint32)((n>>6) & 0x3);
n &= 0x3f; n &= 0x3f;
/* /*
* Ensure the run does not exceed the scanline * Ensure the run does not exceed the scanline
@ -124,11 +130,11 @@ NeXTDecode(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s)
} }
} }
} }
tif->tif_rawcp = (tidata_t) bp; tif->tif_rawcp = (uint8*) bp;
tif->tif_rawcc = cc; tif->tif_rawcc = cc;
return (1); return (1);
bad: bad:
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, "NeXTDecode: Not enough data for scanline %ld", TIFFErrorExt(tif->tif_clientdata, module, "Not enough data for scanline %ld",
(long) tif->tif_row); (long) tif->tif_row);
return (0); return (0);
} }
@ -137,8 +143,8 @@ int
TIFFInitNeXT(TIFF* tif, int scheme) TIFFInitNeXT(TIFF* tif, int scheme)
{ {
(void) scheme; (void) scheme;
tif->tif_decoderow = NeXTDecode; tif->tif_decoderow = NeXTDecode;
tif->tif_decodestrip = NeXTDecode; tif->tif_decodestrip = NeXTDecode;
tif->tif_decodetile = NeXTDecode; tif->tif_decodetile = NeXTDecode;
return (1); return (1);
} }

View File

@ -1,4 +1,4 @@
/* $Id: tif_ojpeg.c,v 1.24.2.6 2010-06-08 23:29:51 bfriesen Exp $ */ /* $Id: tif_ojpeg.c,v 1.54 2011-05-31 17:05:07 bfriesen Exp $ */
/* WARNING: The type of JPEG encapsulation defined by the TIFF Version 6.0 /* WARNING: The type of JPEG encapsulation defined by the TIFF Version 6.0
specification is now totally obsolete and deprecated for new applications and specification is now totally obsolete and deprecated for new applications and
@ -120,6 +120,8 @@
session. session.
*/ */
#define WIN32_LEAN_AND_MEAN
#define VC_EXTRALEAN
#include "tiffiop.h" #include "tiffiop.h"
#ifdef OJPEG_SUPPORT #ifdef OJPEG_SUPPORT
@ -146,7 +148,7 @@
* absolutely no effect. That is why most people insist the EGYPTIANWALK is a bit silly. * absolutely no effect. That is why most people insist the EGYPTIANWALK is a bit silly.
*/ */
/* #define LIBJPEG_ENCAP_EXTERNAL */ /* define LIBJPEG_ENCAP_EXTERNAL */
#define SETJMP(jbuf) setjmp(jbuf) #define SETJMP(jbuf) setjmp(jbuf)
#define LONGJMP(jbuf,code) longjmp(jbuf,code) #define LONGJMP(jbuf,code) longjmp(jbuf,code)
#define JMP_BUF jmp_buf #define JMP_BUF jmp_buf
@ -173,22 +175,45 @@
#define FIELD_OJPEG_JPEGACTABLES (FIELD_CODEC+4) #define FIELD_OJPEG_JPEGACTABLES (FIELD_CODEC+4)
#define FIELD_OJPEG_JPEGPROC (FIELD_CODEC+5) #define FIELD_OJPEG_JPEGPROC (FIELD_CODEC+5)
#define FIELD_OJPEG_JPEGRESTARTINTERVAL (FIELD_CODEC+6) #define FIELD_OJPEG_JPEGRESTARTINTERVAL (FIELD_CODEC+6)
#define FIELD_OJPEG_COUNT 7
static const TIFFFieldInfo ojpeg_field_info[] = { static const TIFFField ojpegFields[] = {
{TIFFTAG_JPEGIFOFFSET,1,1,TIFF_LONG,FIELD_OJPEG_JPEGINTERCHANGEFORMAT,TRUE,FALSE,"JpegInterchangeFormat"}, {TIFFTAG_JPEGIFOFFSET,1,1,TIFF_LONG8,0,TIFF_SETGET_UINT64,TIFF_SETGET_UNDEFINED,FIELD_OJPEG_JPEGINTERCHANGEFORMAT,TRUE,FALSE,"JpegInterchangeFormat",NULL},
{TIFFTAG_JPEGIFBYTECOUNT,1,1,TIFF_LONG,FIELD_OJPEG_JPEGINTERCHANGEFORMATLENGTH,TRUE,FALSE,"JpegInterchangeFormatLength"}, {TIFFTAG_JPEGIFBYTECOUNT,1,1,TIFF_LONG8,0,TIFF_SETGET_UINT64,TIFF_SETGET_UNDEFINED,FIELD_OJPEG_JPEGINTERCHANGEFORMATLENGTH,TRUE,FALSE,"JpegInterchangeFormatLength",NULL},
{TIFFTAG_JPEGQTABLES,TIFF_VARIABLE,TIFF_VARIABLE,TIFF_LONG,FIELD_OJPEG_JPEGQTABLES,FALSE,TRUE,"JpegQTables"}, {TIFFTAG_JPEGQTABLES,TIFF_VARIABLE2,TIFF_VARIABLE2,TIFF_LONG8,0,TIFF_SETGET_C32_UINT64,TIFF_SETGET_UNDEFINED,FIELD_OJPEG_JPEGQTABLES,FALSE,TRUE,"JpegQTables",NULL},
{TIFFTAG_JPEGDCTABLES,TIFF_VARIABLE,TIFF_VARIABLE,TIFF_LONG,FIELD_OJPEG_JPEGDCTABLES,FALSE,TRUE,"JpegDcTables"}, {TIFFTAG_JPEGDCTABLES,TIFF_VARIABLE2,TIFF_VARIABLE2,TIFF_LONG8,0,TIFF_SETGET_C32_UINT64,TIFF_SETGET_UNDEFINED,FIELD_OJPEG_JPEGDCTABLES,FALSE,TRUE,"JpegDcTables",NULL},
{TIFFTAG_JPEGACTABLES,TIFF_VARIABLE,TIFF_VARIABLE,TIFF_LONG,FIELD_OJPEG_JPEGACTABLES,FALSE,TRUE,"JpegAcTables"}, {TIFFTAG_JPEGACTABLES,TIFF_VARIABLE2,TIFF_VARIABLE2,TIFF_LONG8,0,TIFF_SETGET_C32_UINT64,TIFF_SETGET_UNDEFINED,FIELD_OJPEG_JPEGACTABLES,FALSE,TRUE,"JpegAcTables",NULL},
{TIFFTAG_JPEGPROC,1,1,TIFF_SHORT,FIELD_OJPEG_JPEGPROC,FALSE,FALSE,"JpegProc"}, {TIFFTAG_JPEGPROC,1,1,TIFF_SHORT,0,TIFF_SETGET_UINT16,TIFF_SETGET_UNDEFINED,FIELD_OJPEG_JPEGPROC,FALSE,FALSE,"JpegProc",NULL},
{TIFFTAG_JPEGRESTARTINTERVAL,1,1,TIFF_SHORT,FIELD_OJPEG_JPEGRESTARTINTERVAL,FALSE,FALSE,"JpegRestartInterval"}, {TIFFTAG_JPEGRESTARTINTERVAL,1,1,TIFF_SHORT,0,TIFF_SETGET_UINT16,TIFF_SETGET_UNDEFINED,FIELD_OJPEG_JPEGRESTARTINTERVAL,FALSE,FALSE,"JpegRestartInterval",NULL},
}; };
#ifndef LIBJPEG_ENCAP_EXTERNAL #ifndef LIBJPEG_ENCAP_EXTERNAL
#include <setjmp.h> #include <setjmp.h>
#endif #endif
/* We undefine FAR to avoid conflict with JPEG definition */
#ifdef FAR
#undef FAR
#endif
/*
Libjpeg's jmorecfg.h defines INT16 and INT32, but only if XMD_H is
not defined. Unfortunately, the MinGW and Borland compilers include
a typedef for INT32, which causes a conflict. MSVC does not include
a conficting typedef given the headers which are included.
*/
#if defined(__BORLANDC__) || defined(__MINGW32__)
# define XMD_H 1
#endif
/* Define "boolean" as unsigned char, not int, per Windows custom. */
#if defined(__WIN32__) && !defined(__MINGW32__)
# ifndef __RPCNDR_H__ /* don't conflict if rpcndr.h already read */
typedef unsigned char boolean;
# endif
# define HAVE_BOOLEAN /* prevent jmorecfg.h from redefining it */
#endif
#include "jpeglib.h" #include "jpeglib.h"
#include "jerror.h" #include "jerror.h"
@ -224,7 +249,8 @@ typedef struct {
#endif #endif
TIFFVGetMethod vgetparent; TIFFVGetMethod vgetparent;
TIFFVSetMethod vsetparent; TIFFVSetMethod vsetparent;
toff_t file_size; TIFFPrintMethod printdir;
uint64 file_size;
uint32 image_width; uint32 image_width;
uint32 image_length; uint32 image_length;
uint32 strile_width; uint32 strile_width;
@ -233,8 +259,8 @@ typedef struct {
uint8 samples_per_pixel; uint8 samples_per_pixel;
uint8 plane_sample_offset; uint8 plane_sample_offset;
uint8 samples_per_pixel_per_plane; uint8 samples_per_pixel_per_plane;
toff_t jpeg_interchange_format; uint64 jpeg_interchange_format;
toff_t jpeg_interchange_format_length; uint64 jpeg_interchange_format_length;
uint8 jpeg_proc; uint8 jpeg_proc;
uint8 subsamplingcorrect; uint8 subsamplingcorrect;
uint8 subsamplingcorrect_done; uint8 subsamplingcorrect_done;
@ -245,9 +271,9 @@ typedef struct {
uint8 qtable_offset_count; uint8 qtable_offset_count;
uint8 dctable_offset_count; uint8 dctable_offset_count;
uint8 actable_offset_count; uint8 actable_offset_count;
toff_t qtable_offset[3]; uint64 qtable_offset[3];
toff_t dctable_offset[3]; uint64 dctable_offset[3];
toff_t actable_offset[3]; uint64 actable_offset[3];
uint8* qtable[4]; uint8* qtable[4];
uint8* dctable[4]; uint8* dctable[4];
uint8* actable[4]; uint8* actable[4];
@ -265,14 +291,14 @@ typedef struct {
struct { struct {
uint8 log; uint8 log;
OJPEGStateInBufferSource in_buffer_source; OJPEGStateInBufferSource in_buffer_source;
tstrile_t in_buffer_next_strile; uint32 in_buffer_next_strile;
toff_t in_buffer_file_pos; uint64 in_buffer_file_pos;
toff_t in_buffer_file_togo; uint64 in_buffer_file_togo;
} sos_end[3]; } sos_end[3];
uint8 readheader_done; uint8 readheader_done;
uint8 writeheader_done; uint8 writeheader_done;
tsample_t write_cursample; uint16 write_cursample;
tstrile_t write_curstrile; uint32 write_curstrile;
uint8 libjpeg_session_active; uint8 libjpeg_session_active;
uint8 libjpeg_jpeg_query_style; uint8 libjpeg_jpeg_query_style;
jpeg_error_mgr libjpeg_jpeg_error_mgr; jpeg_error_mgr libjpeg_jpeg_error_mgr;
@ -297,11 +323,11 @@ typedef struct {
uint32 bytes_per_line; /* if the codec outputs subsampled data, a 'line' in bytes_per_line */ uint32 bytes_per_line; /* if the codec outputs subsampled data, a 'line' in bytes_per_line */
uint32 lines_per_strile; /* and lines_per_strile means subsampling_ver desubsampled rows */ uint32 lines_per_strile; /* and lines_per_strile means subsampling_ver desubsampled rows */
OJPEGStateInBufferSource in_buffer_source; OJPEGStateInBufferSource in_buffer_source;
tstrile_t in_buffer_next_strile; uint32 in_buffer_next_strile;
tstrile_t in_buffer_strile_count; uint32 in_buffer_strile_count;
toff_t in_buffer_file_pos; uint64 in_buffer_file_pos;
uint8 in_buffer_file_pos_log; uint8 in_buffer_file_pos_log;
toff_t in_buffer_file_togo; uint64 in_buffer_file_togo;
uint16 in_buffer_togo; uint16 in_buffer_togo;
uint8* in_buffer_cur; uint8* in_buffer_cur;
uint8 in_buffer[OJPEG_BUFFER]; uint8 in_buffer[OJPEG_BUFFER];
@ -310,27 +336,28 @@ typedef struct {
uint8* skip_buffer; uint8* skip_buffer;
} OJPEGState; } OJPEGState;
static int OJPEGVGetField(TIFF* tif, ttag_t tag, va_list ap); static int OJPEGVGetField(TIFF* tif, uint32 tag, va_list ap);
static int OJPEGVSetField(TIFF* tif, ttag_t tag, va_list ap); static int OJPEGVSetField(TIFF* tif, uint32 tag, va_list ap);
static void OJPEGPrintDir(TIFF* tif, FILE* fd, long flags); static void OJPEGPrintDir(TIFF* tif, FILE* fd, long flags);
static int OJPEGFixupTags(TIFF* tif);
static int OJPEGSetupDecode(TIFF* tif); static int OJPEGSetupDecode(TIFF* tif);
static int OJPEGPreDecode(TIFF* tif, tsample_t s); static int OJPEGPreDecode(TIFF* tif, uint16 s);
static int OJPEGPreDecodeSkipRaw(TIFF* tif); static int OJPEGPreDecodeSkipRaw(TIFF* tif);
static int OJPEGPreDecodeSkipScanlines(TIFF* tif); static int OJPEGPreDecodeSkipScanlines(TIFF* tif);
static int OJPEGDecode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s); static int OJPEGDecode(TIFF* tif, uint8* buf, tmsize_t cc, uint16 s);
static int OJPEGDecodeRaw(TIFF* tif, tidata_t buf, tsize_t cc); static int OJPEGDecodeRaw(TIFF* tif, uint8* buf, tmsize_t cc);
static int OJPEGDecodeScanlines(TIFF* tif, tidata_t buf, tsize_t cc); static int OJPEGDecodeScanlines(TIFF* tif, uint8* buf, tmsize_t cc);
static void OJPEGPostDecode(TIFF* tif, tidata_t buf, tsize_t cc); static void OJPEGPostDecode(TIFF* tif, uint8* buf, tmsize_t cc);
static int OJPEGSetupEncode(TIFF* tif); static int OJPEGSetupEncode(TIFF* tif);
static int OJPEGPreEncode(TIFF* tif, tsample_t s); static int OJPEGPreEncode(TIFF* tif, uint16 s);
static int OJPEGEncode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s); static int OJPEGEncode(TIFF* tif, uint8* buf, tmsize_t cc, uint16 s);
static int OJPEGPostEncode(TIFF* tif); static int OJPEGPostEncode(TIFF* tif);
static void OJPEGCleanup(TIFF* tif); static void OJPEGCleanup(TIFF* tif);
static void OJPEGSubsamplingCorrect(TIFF* tif); static void OJPEGSubsamplingCorrect(TIFF* tif);
static int OJPEGReadHeaderInfo(TIFF* tif); static int OJPEGReadHeaderInfo(TIFF* tif);
static int OJPEGReadSecondarySos(TIFF* tif, tsample_t s); static int OJPEGReadSecondarySos(TIFF* tif, uint16 s);
static int OJPEGWriteHeaderInfo(TIFF* tif); static int OJPEGWriteHeaderInfo(TIFF* tif);
static void OJPEGLibjpegSessionAbort(TIFF* tif); static void OJPEGLibjpegSessionAbort(TIFF* tif);
@ -399,9 +426,9 @@ TIFFInitOJPEG(TIFF* tif, int scheme)
/* /*
* Merge codec-specific tag information. * Merge codec-specific tag information.
*/ */
if (!_TIFFMergeFieldInfo(tif,ojpeg_field_info,FIELD_OJPEG_COUNT)) { if (!_TIFFMergeFields(tif, ojpegFields, TIFFArrayCount(ojpegFields))) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"Merging Old JPEG codec-specific tags failed"); "Merging Old JPEG codec-specific tags failed");
return 0; return 0;
} }
@ -419,25 +446,27 @@ TIFFInitOJPEG(TIFF* tif, int scheme)
sp->subsampling_ver=2; sp->subsampling_ver=2;
TIFFSetField(tif,TIFFTAG_YCBCRSUBSAMPLING,2,2); TIFFSetField(tif,TIFFTAG_YCBCRSUBSAMPLING,2,2);
/* tif codec methods */ /* tif codec methods */
tif->tif_fixuptags=OJPEGFixupTags;
tif->tif_setupdecode=OJPEGSetupDecode; tif->tif_setupdecode=OJPEGSetupDecode;
tif->tif_predecode=OJPEGPreDecode; tif->tif_predecode=OJPEGPreDecode;
tif->tif_postdecode=OJPEGPostDecode; tif->tif_postdecode=OJPEGPostDecode;
tif->tif_decoderow=OJPEGDecode; tif->tif_decoderow=OJPEGDecode;
tif->tif_decodestrip=OJPEGDecode; tif->tif_decodestrip=OJPEGDecode;
tif->tif_decodetile=OJPEGDecode; tif->tif_decodetile=OJPEGDecode;
tif->tif_setupencode=OJPEGSetupEncode; tif->tif_setupencode=OJPEGSetupEncode;
tif->tif_preencode=OJPEGPreEncode; tif->tif_preencode=OJPEGPreEncode;
tif->tif_postencode=OJPEGPostEncode; tif->tif_postencode=OJPEGPostEncode;
tif->tif_encoderow=OJPEGEncode; tif->tif_encoderow=OJPEGEncode;
tif->tif_encodestrip=OJPEGEncode; tif->tif_encodestrip=OJPEGEncode;
tif->tif_encodetile=OJPEGEncode; tif->tif_encodetile=OJPEGEncode;
tif->tif_cleanup=OJPEGCleanup; tif->tif_cleanup=OJPEGCleanup;
tif->tif_data=(tidata_t)sp; tif->tif_data=(uint8*)sp;
/* tif tag methods */ /* tif tag methods */
sp->vgetparent=tif->tif_tagmethods.vgetfield; sp->vgetparent=tif->tif_tagmethods.vgetfield;
tif->tif_tagmethods.vgetfield=OJPEGVGetField; tif->tif_tagmethods.vgetfield=OJPEGVGetField;
sp->vsetparent=tif->tif_tagmethods.vsetfield; sp->vsetparent=tif->tif_tagmethods.vsetfield;
tif->tif_tagmethods.vsetfield=OJPEGVSetField; tif->tif_tagmethods.vsetfield=OJPEGVSetField;
sp->printdir=tif->tif_tagmethods.printdir;
tif->tif_tagmethods.printdir=OJPEGPrintDir; tif->tif_tagmethods.printdir=OJPEGPrintDir;
/* Some OJPEG files don't have strip or tile offsets or bytecounts tags. /* Some OJPEG files don't have strip or tile offsets or bytecounts tags.
Some others do, but have totally meaningless or corrupt values Some others do, but have totally meaningless or corrupt values
@ -450,16 +479,16 @@ TIFFInitOJPEG(TIFF* tif, int scheme)
} }
static int static int
OJPEGVGetField(TIFF* tif, ttag_t tag, va_list ap) OJPEGVGetField(TIFF* tif, uint32 tag, va_list ap)
{ {
OJPEGState* sp=(OJPEGState*)tif->tif_data; OJPEGState* sp=(OJPEGState*)tif->tif_data;
switch(tag) switch(tag)
{ {
case TIFFTAG_JPEGIFOFFSET: case TIFFTAG_JPEGIFOFFSET:
*va_arg(ap,uint32*)=(uint32)sp->jpeg_interchange_format; *va_arg(ap,uint64*)=(uint64)sp->jpeg_interchange_format;
break; break;
case TIFFTAG_JPEGIFBYTECOUNT: case TIFFTAG_JPEGIFBYTECOUNT:
*va_arg(ap,uint32*)=(uint32)sp->jpeg_interchange_format_length; *va_arg(ap,uint64*)=(uint64)sp->jpeg_interchange_format_length;
break; break;
case TIFFTAG_YCBCRSUBSAMPLING: case TIFFTAG_YCBCRSUBSAMPLING:
if (sp->subsamplingcorrect_done==0) if (sp->subsamplingcorrect_done==0)
@ -469,11 +498,11 @@ OJPEGVGetField(TIFF* tif, ttag_t tag, va_list ap)
break; break;
case TIFFTAG_JPEGQTABLES: case TIFFTAG_JPEGQTABLES:
*va_arg(ap,uint32*)=(uint32)sp->qtable_offset_count; *va_arg(ap,uint32*)=(uint32)sp->qtable_offset_count;
*va_arg(ap,void**)=(void*)sp->qtable_offset; *va_arg(ap,void**)=(void*)sp->qtable_offset;
break; break;
case TIFFTAG_JPEGDCTABLES: case TIFFTAG_JPEGDCTABLES:
*va_arg(ap,uint32*)=(uint32)sp->dctable_offset_count; *va_arg(ap,uint32*)=(uint32)sp->dctable_offset_count;
*va_arg(ap,void**)=(void*)sp->dctable_offset; *va_arg(ap,void**)=(void*)sp->dctable_offset;
break; break;
case TIFFTAG_JPEGACTABLES: case TIFFTAG_JPEGACTABLES:
*va_arg(ap,uint32*)=(uint32)sp->actable_offset_count; *va_arg(ap,uint32*)=(uint32)sp->actable_offset_count;
@ -492,30 +521,30 @@ OJPEGVGetField(TIFF* tif, ttag_t tag, va_list ap)
} }
static int static int
OJPEGVSetField(TIFF* tif, ttag_t tag, va_list ap) OJPEGVSetField(TIFF* tif, uint32 tag, va_list ap)
{ {
static const char module[]="OJPEGVSetField"; static const char module[]="OJPEGVSetField";
OJPEGState* sp=(OJPEGState*)tif->tif_data; OJPEGState* sp=(OJPEGState*)tif->tif_data;
uint32 ma; uint32 ma;
uint32* mb; uint64* mb;
uint32 n; uint32 n;
switch(tag) switch(tag)
{ {
case TIFFTAG_JPEGIFOFFSET: case TIFFTAG_JPEGIFOFFSET:
sp->jpeg_interchange_format=(toff_t)va_arg(ap,uint32); sp->jpeg_interchange_format=(uint64)va_arg(ap,uint64);
break; break;
case TIFFTAG_JPEGIFBYTECOUNT: case TIFFTAG_JPEGIFBYTECOUNT:
sp->jpeg_interchange_format_length=(toff_t)va_arg(ap,uint32); sp->jpeg_interchange_format_length=(uint64)va_arg(ap,uint64);
break; break;
case TIFFTAG_YCBCRSUBSAMPLING: case TIFFTAG_YCBCRSUBSAMPLING:
sp->subsampling_tag=1; sp->subsampling_tag=1;
sp->subsampling_hor=(uint8)va_arg(ap,int); sp->subsampling_hor=(uint8)va_arg(ap,uint16_vap);
sp->subsampling_ver=(uint8)va_arg(ap,int); sp->subsampling_ver=(uint8)va_arg(ap,uint16_vap);
tif->tif_dir.td_ycbcrsubsampling[0]=sp->subsampling_hor; tif->tif_dir.td_ycbcrsubsampling[0]=sp->subsampling_hor;
tif->tif_dir.td_ycbcrsubsampling[1]=sp->subsampling_ver; tif->tif_dir.td_ycbcrsubsampling[1]=sp->subsampling_ver;
break; break;
case TIFFTAG_JPEGQTABLES: case TIFFTAG_JPEGQTABLES:
ma=va_arg(ap,uint32); ma=(uint32)va_arg(ap,uint32);
if (ma!=0) if (ma!=0)
{ {
if (ma>3) if (ma>3)
@ -524,13 +553,13 @@ OJPEGVSetField(TIFF* tif, ttag_t tag, va_list ap)
return(0); return(0);
} }
sp->qtable_offset_count=(uint8)ma; sp->qtable_offset_count=(uint8)ma;
mb=va_arg(ap,uint32*); mb=(uint64*)va_arg(ap,uint64*);
for (n=0; n<ma; n++) for (n=0; n<ma; n++)
sp->qtable_offset[n]=(toff_t)mb[n]; sp->qtable_offset[n]=mb[n];
} }
break; break;
case TIFFTAG_JPEGDCTABLES: case TIFFTAG_JPEGDCTABLES:
ma=va_arg(ap,uint32); ma=(uint32)va_arg(ap,uint32);
if (ma!=0) if (ma!=0)
{ {
if (ma>3) if (ma>3)
@ -539,13 +568,13 @@ OJPEGVSetField(TIFF* tif, ttag_t tag, va_list ap)
return(0); return(0);
} }
sp->dctable_offset_count=(uint8)ma; sp->dctable_offset_count=(uint8)ma;
mb=va_arg(ap,uint32*); mb=(uint64*)va_arg(ap,uint64*);
for (n=0; n<ma; n++) for (n=0; n<ma; n++)
sp->dctable_offset[n]=(toff_t)mb[n]; sp->dctable_offset[n]=mb[n];
} }
break; break;
case TIFFTAG_JPEGACTABLES: case TIFFTAG_JPEGACTABLES:
ma=va_arg(ap,uint32); ma=(uint32)va_arg(ap,uint32);
if (ma!=0) if (ma!=0)
{ {
if (ma>3) if (ma>3)
@ -554,21 +583,21 @@ OJPEGVSetField(TIFF* tif, ttag_t tag, va_list ap)
return(0); return(0);
} }
sp->actable_offset_count=(uint8)ma; sp->actable_offset_count=(uint8)ma;
mb=va_arg(ap,uint32*); mb=(uint64*)va_arg(ap,uint64*);
for (n=0; n<ma; n++) for (n=0; n<ma; n++)
sp->actable_offset[n]=(toff_t)mb[n]; sp->actable_offset[n]=mb[n];
} }
break; break;
case TIFFTAG_JPEGPROC: case TIFFTAG_JPEGPROC:
sp->jpeg_proc=(uint8)va_arg(ap,uint32); sp->jpeg_proc=(uint8)va_arg(ap,uint16_vap);
break; break;
case TIFFTAG_JPEGRESTARTINTERVAL: case TIFFTAG_JPEGRESTARTINTERVAL:
sp->restart_interval=(uint16)va_arg(ap,uint32); sp->restart_interval=(uint16)va_arg(ap,uint16_vap);
break; break;
default: default:
return (*sp->vsetparent)(tif,tag,ap); return (*sp->vsetparent)(tif,tag,ap);
} }
TIFFSetFieldBit(tif,_TIFFFieldWithTag(tif,tag)->field_bit); TIFFSetFieldBit(tif,TIFFFieldWithTag(tif,tag)->field_bit);
tif->tif_flags|=TIFF_DIRTYDIRECT; tif->tif_flags|=TIFF_DIRTYDIRECT;
return(1); return(1);
} }
@ -581,34 +610,43 @@ OJPEGPrintDir(TIFF* tif, FILE* fd, long flags)
(void)flags; (void)flags;
assert(sp!=NULL); assert(sp!=NULL);
if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGINTERCHANGEFORMAT)) if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGINTERCHANGEFORMAT))
fprintf(fd," JpegInterchangeFormat: %lu\n",(unsigned long)sp->jpeg_interchange_format); fprintf(fd," JpegInterchangeFormat: " TIFF_UINT64_FORMAT "\n",(TIFF_UINT64_T)sp->jpeg_interchange_format);
if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGINTERCHANGEFORMATLENGTH)) if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGINTERCHANGEFORMATLENGTH))
fprintf(fd," JpegInterchangeFormatLength: %lu\n",(unsigned long)sp->jpeg_interchange_format_length); fprintf(fd," JpegInterchangeFormatLength: " TIFF_UINT64_FORMAT "\n",(TIFF_UINT64_T)sp->jpeg_interchange_format_length);
if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGQTABLES)) if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGQTABLES))
{ {
fprintf(fd," JpegQTables:"); fprintf(fd," JpegQTables:");
for (m=0; m<sp->qtable_offset_count; m++) for (m=0; m<sp->qtable_offset_count; m++)
fprintf(fd," %lu",(unsigned long)sp->qtable_offset[m]); fprintf(fd," " TIFF_UINT64_FORMAT,(TIFF_UINT64_T)sp->qtable_offset[m]);
fprintf(fd,"\n"); fprintf(fd,"\n");
} }
if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGDCTABLES)) if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGDCTABLES))
{ {
fprintf(fd," JpegDcTables:"); fprintf(fd," JpegDcTables:");
for (m=0; m<sp->dctable_offset_count; m++) for (m=0; m<sp->dctable_offset_count; m++)
fprintf(fd," %lu",(unsigned long)sp->dctable_offset[m]); fprintf(fd," " TIFF_UINT64_FORMAT,(TIFF_UINT64_T)sp->dctable_offset[m]);
fprintf(fd,"\n"); fprintf(fd,"\n");
} }
if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGACTABLES)) if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGACTABLES))
{ {
fprintf(fd," JpegAcTables:"); fprintf(fd," JpegAcTables:");
for (m=0; m<sp->actable_offset_count; m++) for (m=0; m<sp->actable_offset_count; m++)
fprintf(fd," %lu",(unsigned long)sp->actable_offset[m]); fprintf(fd," " TIFF_UINT64_FORMAT,(TIFF_UINT64_T)sp->actable_offset[m]);
fprintf(fd,"\n"); fprintf(fd,"\n");
} }
if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGPROC)) if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGPROC))
fprintf(fd," JpegProc: %u\n",(unsigned int)sp->jpeg_proc); fprintf(fd," JpegProc: %u\n",(unsigned int)sp->jpeg_proc);
if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGRESTARTINTERVAL)) if (TIFFFieldSet(tif,FIELD_OJPEG_JPEGRESTARTINTERVAL))
fprintf(fd," JpegRestartInterval: %u\n",(unsigned int)sp->restart_interval); fprintf(fd," JpegRestartInterval: %u\n",(unsigned int)sp->restart_interval);
if (sp->printdir)
(*sp->printdir)(tif, fd, flags);
}
static int
OJPEGFixupTags(TIFF* tif)
{
(void) tif;
return(1);
} }
static int static int
@ -620,10 +658,10 @@ OJPEGSetupDecode(TIFF* tif)
} }
static int static int
OJPEGPreDecode(TIFF* tif, tsample_t s) OJPEGPreDecode(TIFF* tif, uint16 s)
{ {
OJPEGState* sp=(OJPEGState*)tif->tif_data; OJPEGState* sp=(OJPEGState*)tif->tif_data;
tstrile_t m; uint32 m;
if (sp->subsamplingcorrect_done==0) if (sp->subsamplingcorrect_done==0)
OJPEGSubsamplingCorrect(tif); OJPEGSubsamplingCorrect(tif);
if (sp->readheader_done==0) if (sp->readheader_done==0)
@ -637,9 +675,9 @@ OJPEGPreDecode(TIFF* tif, tsample_t s)
return(0); return(0);
} }
if isTiled(tif) if isTiled(tif)
m=(tstrile_t)tif->tif_curtile; m=tif->tif_curtile;
else else
m=(tstrile_t)tif->tif_curstrip; m=tif->tif_curstrip;
if ((sp->writeheader_done!=0) && ((sp->write_cursample!=s) || (sp->write_curstrile>m))) if ((sp->writeheader_done!=0) && ((sp->write_cursample!=s) || (sp->write_curstrile>m)))
{ {
if (sp->libjpeg_session_active!=0) if (sp->libjpeg_session_active!=0)
@ -648,7 +686,7 @@ OJPEGPreDecode(TIFF* tif, tsample_t s)
} }
if (sp->writeheader_done==0) if (sp->writeheader_done==0)
{ {
sp->plane_sample_offset=s; sp->plane_sample_offset=(uint8)s;
sp->write_cursample=s; sp->write_cursample=s;
sp->write_curstrile=s*tif->tif_dir.td_stripsperimage; sp->write_curstrile=s*tif->tif_dir.td_stripsperimage;
if ((sp->in_buffer_file_pos_log==0) || if ((sp->in_buffer_file_pos_log==0) ||
@ -739,7 +777,7 @@ OJPEGPreDecodeSkipScanlines(TIFF* tif)
} }
static int static int
OJPEGDecode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s) OJPEGDecode(TIFF* tif, uint8* buf, tmsize_t cc, uint16 s)
{ {
OJPEGState* sp=(OJPEGState*)tif->tif_data; OJPEGState* sp=(OJPEGState*)tif->tif_data;
(void)s; (void)s;
@ -757,12 +795,12 @@ OJPEGDecode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s)
} }
static int static int
OJPEGDecodeRaw(TIFF* tif, tidata_t buf, tsize_t cc) OJPEGDecodeRaw(TIFF* tif, uint8* buf, tmsize_t cc)
{ {
static const char module[]="OJPEGDecodeRaw"; static const char module[]="OJPEGDecodeRaw";
OJPEGState* sp=(OJPEGState*)tif->tif_data; OJPEGState* sp=(OJPEGState*)tif->tif_data;
uint8* m; uint8* m;
uint32 n; tmsize_t n;
uint8* oy; uint8* oy;
uint8* ocb; uint8* ocb;
uint8* ocr; uint8* ocr;
@ -812,12 +850,12 @@ OJPEGDecodeRaw(TIFF* tif, tidata_t buf, tsize_t cc)
} }
static int static int
OJPEGDecodeScanlines(TIFF* tif, tidata_t buf, tsize_t cc) OJPEGDecodeScanlines(TIFF* tif, uint8* buf, tmsize_t cc)
{ {
static const char module[]="OJPEGDecodeScanlines"; static const char module[]="OJPEGDecodeScanlines";
OJPEGState* sp=(OJPEGState*)tif->tif_data; OJPEGState* sp=(OJPEGState*)tif->tif_data;
uint8* m; uint8* m;
uint32 n; tmsize_t n;
if (cc%sp->bytes_per_line!=0) if (cc%sp->bytes_per_line!=0)
{ {
TIFFErrorExt(tif->tif_clientdata,module,"Fractional scanline not read"); TIFFErrorExt(tif->tif_clientdata,module,"Fractional scanline not read");
@ -837,13 +875,13 @@ OJPEGDecodeScanlines(TIFF* tif, tidata_t buf, tsize_t cc)
} }
static void static void
OJPEGPostDecode(TIFF* tif, tidata_t buf, tsize_t cc) OJPEGPostDecode(TIFF* tif, uint8* buf, tmsize_t cc)
{ {
OJPEGState* sp=(OJPEGState*)tif->tif_data; OJPEGState* sp=(OJPEGState*)tif->tif_data;
(void)buf; (void)buf;
(void)cc; (void)cc;
sp->write_curstrile++; sp->write_curstrile++;
if (sp->write_curstrile%tif->tif_dir.td_stripsperimage==0) if (sp->write_curstrile%tif->tif_dir.td_stripsperimage==0)
{ {
assert(sp->libjpeg_session_active!=0); assert(sp->libjpeg_session_active!=0);
OJPEGLibjpegSessionAbort(tif); OJPEGLibjpegSessionAbort(tif);
@ -860,7 +898,7 @@ OJPEGSetupEncode(TIFF* tif)
} }
static int static int
OJPEGPreEncode(TIFF* tif, tsample_t s) OJPEGPreEncode(TIFF* tif, uint16 s)
{ {
static const char module[]="OJPEGPreEncode"; static const char module[]="OJPEGPreEncode";
(void)s; (void)s;
@ -869,7 +907,7 @@ OJPEGPreEncode(TIFF* tif, tsample_t s)
} }
static int static int
OJPEGEncode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s) OJPEGEncode(TIFF* tif, uint8* buf, tmsize_t cc, uint16 s)
{ {
static const char module[]="OJPEGEncode"; static const char module[]="OJPEGEncode";
(void)buf; (void)buf;
@ -895,6 +933,7 @@ OJPEGCleanup(TIFF* tif)
{ {
tif->tif_tagmethods.vgetfield=sp->vgetparent; tif->tif_tagmethods.vgetfield=sp->vgetparent;
tif->tif_tagmethods.vsetfield=sp->vsetparent; tif->tif_tagmethods.vsetfield=sp->vsetparent;
tif->tif_tagmethods.printdir=sp->printdir;
if (sp->qtable[0]!=0) if (sp->qtable[0]!=0)
_TIFFfree(sp->qtable[0]); _TIFFfree(sp->qtable[0]);
if (sp->qtable[1]!=0) if (sp->qtable[1]!=0)
@ -940,6 +979,8 @@ OJPEGSubsamplingCorrect(TIFF* tif)
OJPEGState* sp=(OJPEGState*)tif->tif_data; OJPEGState* sp=(OJPEGState*)tif->tif_data;
uint8 mh; uint8 mh;
uint8 mv; uint8 mv;
_TIFFFillStriles( tif );
assert(sp->subsamplingcorrect_done==0); assert(sp->subsamplingcorrect_done==0);
if ((tif->tif_dir.td_samplesperpixel!=3) || ((tif->tif_dir.td_photometric!=PHOTOMETRIC_YCBCR) && if ((tif->tif_dir.td_samplesperpixel!=3) || ((tif->tif_dir.td_photometric!=PHOTOMETRIC_YCBCR) &&
(tif->tif_dir.td_photometric!=PHOTOMETRIC_ITULAB))) (tif->tif_dir.td_photometric!=PHOTOMETRIC_ITULAB)))
@ -1006,9 +1047,9 @@ OJPEGReadHeaderInfo(TIFF* tif)
sp->strile_length=tif->tif_dir.td_rowsperstrip; sp->strile_length=tif->tif_dir.td_rowsperstrip;
sp->strile_length_total=sp->image_length; sp->strile_length_total=sp->image_length;
} }
sp->samples_per_pixel=tif->tif_dir.td_samplesperpixel; if (tif->tif_dir.td_samplesperpixel==1)
if (sp->samples_per_pixel==1)
{ {
sp->samples_per_pixel=1;
sp->plane_sample_offset=0; sp->plane_sample_offset=0;
sp->samples_per_pixel_per_plane=sp->samples_per_pixel; sp->samples_per_pixel_per_plane=sp->samples_per_pixel;
sp->subsampling_hor=1; sp->subsampling_hor=1;
@ -1016,11 +1057,12 @@ OJPEGReadHeaderInfo(TIFF* tif)
} }
else else
{ {
if (sp->samples_per_pixel!=3) if (tif->tif_dir.td_samplesperpixel!=3)
{ {
TIFFErrorExt(tif->tif_clientdata,module,"SamplesPerPixel %d not supported for this compression scheme",sp->samples_per_pixel); TIFFErrorExt(tif->tif_clientdata,module,"SamplesPerPixel %d not supported for this compression scheme",sp->samples_per_pixel);
return(0); return(0);
} }
sp->samples_per_pixel=3;
sp->plane_sample_offset=0; sp->plane_sample_offset=0;
if (tif->tif_dir.td_planarconfig==PLANARCONFIG_CONTIG) if (tif->tif_dir.td_planarconfig==PLANARCONFIG_CONTIG)
sp->samples_per_pixel_per_plane=3; sp->samples_per_pixel_per_plane=3;
@ -1042,13 +1084,13 @@ OJPEGReadHeaderInfo(TIFF* tif)
sp->sos_end[0].in_buffer_source=sp->in_buffer_source; sp->sos_end[0].in_buffer_source=sp->in_buffer_source;
sp->sos_end[0].in_buffer_next_strile=sp->in_buffer_next_strile; sp->sos_end[0].in_buffer_next_strile=sp->in_buffer_next_strile;
sp->sos_end[0].in_buffer_file_pos=sp->in_buffer_file_pos-sp->in_buffer_togo; sp->sos_end[0].in_buffer_file_pos=sp->in_buffer_file_pos-sp->in_buffer_togo;
sp->sos_end[0].in_buffer_file_togo=sp->in_buffer_file_togo+sp->in_buffer_togo; sp->sos_end[0].in_buffer_file_togo=sp->in_buffer_file_togo+sp->in_buffer_togo;
sp->readheader_done=1; sp->readheader_done=1;
return(1); return(1);
} }
static int static int
OJPEGReadSecondarySos(TIFF* tif, tsample_t s) OJPEGReadSecondarySos(TIFF* tif, uint16 s)
{ {
OJPEGState* sp=(OJPEGState*)tif->tif_data; OJPEGState* sp=(OJPEGState*)tif->tif_data;
uint8 m; uint8 m;
@ -1061,7 +1103,7 @@ OJPEGReadSecondarySos(TIFF* tif, tsample_t s)
sp->plane_sample_offset--; sp->plane_sample_offset--;
sp->in_buffer_source=sp->sos_end[sp->plane_sample_offset].in_buffer_source; sp->in_buffer_source=sp->sos_end[sp->plane_sample_offset].in_buffer_source;
sp->in_buffer_next_strile=sp->sos_end[sp->plane_sample_offset].in_buffer_next_strile; sp->in_buffer_next_strile=sp->sos_end[sp->plane_sample_offset].in_buffer_next_strile;
sp->in_buffer_file_pos=sp->sos_end[sp->plane_sample_offset].in_buffer_file_pos; sp->in_buffer_file_pos=sp->sos_end[sp->plane_sample_offset].in_buffer_file_pos;
sp->in_buffer_file_pos_log=0; sp->in_buffer_file_pos_log=0;
sp->in_buffer_file_togo=sp->sos_end[sp->plane_sample_offset].in_buffer_file_togo; sp->in_buffer_file_togo=sp->sos_end[sp->plane_sample_offset].in_buffer_file_togo;
sp->in_buffer_togo=0; sp->in_buffer_togo=0;
@ -1223,7 +1265,7 @@ OJPEGReadHeaderInfoSec(TIFF* tif)
} }
sp->in_buffer_source=osibsNotSetYet; sp->in_buffer_source=osibsNotSetYet;
sp->in_buffer_next_strile=0; sp->in_buffer_next_strile=0;
sp->in_buffer_strile_count=tif->tif_dir.td_nstrips; sp->in_buffer_strile_count=tif->tif_dir.td_nstrips;
sp->in_buffer_file_togo=0; sp->in_buffer_file_togo=0;
sp->in_buffer_togo=0; sp->in_buffer_togo=0;
do do
@ -1391,12 +1433,15 @@ OJPEGReadHeaderInfoSecStreamDqt(TIFF* tif)
nb[sizeof(uint32)+1]=JPEG_MARKER_DQT; nb[sizeof(uint32)+1]=JPEG_MARKER_DQT;
nb[sizeof(uint32)+2]=0; nb[sizeof(uint32)+2]=0;
nb[sizeof(uint32)+3]=67; nb[sizeof(uint32)+3]=67;
if (OJPEGReadBlock(sp,65,&nb[sizeof(uint32)+4])==0) if (OJPEGReadBlock(sp,65,&nb[sizeof(uint32)+4])==0) {
_TIFFfree(nb);
return(0); return(0);
}
o=nb[sizeof(uint32)+4]&15; o=nb[sizeof(uint32)+4]&15;
if (3<o) if (3<o)
{ {
TIFFErrorExt(tif->tif_clientdata,module,"Corrupt DQT marker in JPEG data"); TIFFErrorExt(tif->tif_clientdata,module,"Corrupt DQT marker in JPEG data");
_TIFFfree(nb);
return(0); return(0);
} }
if (sp->qtable[o]!=0) if (sp->qtable[o]!=0)
@ -1537,11 +1582,10 @@ OJPEGReadHeaderInfoSecStreamSof(TIFF* tif, uint8 marker_id)
OJPEGReadSkip(sp,4); OJPEGReadSkip(sp,4);
else else
{ {
/* TODO: probably best to also add check on allowed upper bound, especially x, may cause buffer overflow otherwise i think */
/* Y: Number of lines */ /* Y: Number of lines */
if (OJPEGReadWord(sp,&p)==0) if (OJPEGReadWord(sp,&p)==0)
return(0); return(0);
if ((p<sp->image_length) && (p<sp->strile_length_total)) if (((uint32)p<sp->image_length) && ((uint32)p<sp->strile_length_total))
{ {
TIFFErrorExt(tif->tif_clientdata,module,"JPEG compressed data indicates unexpected height"); TIFFErrorExt(tif->tif_clientdata,module,"JPEG compressed data indicates unexpected height");
return(0); return(0);
@ -1550,11 +1594,16 @@ OJPEGReadHeaderInfoSecStreamSof(TIFF* tif, uint8 marker_id)
/* X: Number of samples per line */ /* X: Number of samples per line */
if (OJPEGReadWord(sp,&p)==0) if (OJPEGReadWord(sp,&p)==0)
return(0); return(0);
if ((p<sp->image_width) && (p<sp->strile_width)) if (((uint32)p<sp->image_width) && ((uint32)p<sp->strile_width))
{ {
TIFFErrorExt(tif->tif_clientdata,module,"JPEG compressed data indicates unexpected width"); TIFFErrorExt(tif->tif_clientdata,module,"JPEG compressed data indicates unexpected width");
return(0); return(0);
} }
if ((uint32)p>sp->strile_width)
{
TIFFErrorExt(tif->tif_clientdata,module,"JPEG compressed data image width exceeds expected image width");
return(0);
}
sp->sof_x=p; sp->sof_x=p;
} }
/* Nf: Number of image components in frame */ /* Nf: Number of image components in frame */
@ -1717,7 +1766,7 @@ OJPEGReadHeaderInfoSecTablesQTable(TIFF* tif)
ob[sizeof(uint32)+2]=0; ob[sizeof(uint32)+2]=0;
ob[sizeof(uint32)+3]=67; ob[sizeof(uint32)+3]=67;
ob[sizeof(uint32)+4]=m; ob[sizeof(uint32)+4]=m;
TIFFSeekFile(tif,sp->qtable_offset[m],SEEK_SET); TIFFSeekFile(tif,sp->qtable_offset[m],SEEK_SET);
p=TIFFReadFile(tif,&ob[sizeof(uint32)+5],64); p=TIFFReadFile(tif,&ob[sizeof(uint32)+5],64);
if (p!=64) if (p!=64)
return(0); return(0);
@ -1824,7 +1873,7 @@ OJPEGReadHeaderInfoSecTablesAcTable(TIFF* tif)
return(0); return(0);
} }
} }
TIFFSeekFile(tif,sp->actable_offset[m],SEEK_SET); TIFFSeekFile(tif,sp->actable_offset[m],SEEK_SET);
p=TIFFReadFile(tif,o,16); p=TIFFReadFile(tif,o,16);
if (p!=16) if (p!=16)
return(0); return(0);
@ -1862,7 +1911,7 @@ static int
OJPEGReadBufferFill(OJPEGState* sp) OJPEGReadBufferFill(OJPEGState* sp)
{ {
uint16 m; uint16 m;
tsize_t n; tmsize_t n;
/* TODO: double-check: when subsamplingcorrect is set, no call to TIFFErrorExt or TIFFWarningExt should be made /* TODO: double-check: when subsamplingcorrect is set, no call to TIFFErrorExt or TIFFWarningExt should be made
* in any other case, seek or read errors should be passed through */ * in any other case, seek or read errors should be passed through */
do do
@ -1875,15 +1924,15 @@ OJPEGReadBufferFill(OJPEGState* sp)
sp->in_buffer_file_pos_log=1; sp->in_buffer_file_pos_log=1;
} }
m=OJPEG_BUFFER; m=OJPEG_BUFFER;
if (m>sp->in_buffer_file_togo) if ((uint64)m>sp->in_buffer_file_togo)
m=(uint16)sp->in_buffer_file_togo; m=(uint16)sp->in_buffer_file_togo;
n=TIFFReadFile(sp->tif,sp->in_buffer,(tsize_t)m); n=TIFFReadFile(sp->tif,sp->in_buffer,(tmsize_t)m);
if (n==0) if (n==0)
return(0); return(0);
assert(n>0); assert(n>0);
assert(n<=OJPEG_BUFFER); assert(n<=OJPEG_BUFFER);
assert(n<65536); assert(n<65536);
assert((uint16)n<=sp->in_buffer_file_togo); assert((uint64)n<=sp->in_buffer_file_togo);
m=(uint16)n; m=(uint16)n;
sp->in_buffer_togo=m; sp->in_buffer_togo=m;
sp->in_buffer_cur=sp->in_buffer; sp->in_buffer_cur=sp->in_buffer;
@ -1905,22 +1954,24 @@ OJPEGReadBufferFill(OJPEGState* sp)
case osibsJpegInterchangeFormat: case osibsJpegInterchangeFormat:
sp->in_buffer_source=osibsStrile; sp->in_buffer_source=osibsStrile;
case osibsStrile: case osibsStrile:
if (sp->in_buffer_next_strile==sp->in_buffer_strile_count) if (sp->in_buffer_next_strile==sp->in_buffer_strile_count)
sp->in_buffer_source=osibsEof; sp->in_buffer_source=osibsEof;
else else
{ {
if (sp->tif->tif_dir.td_stripoffset == 0) { sp->in_buffer_file_pos=sp->tif->tif_dir.td_stripoffset[sp->in_buffer_next_strile];
TIFFErrorExt(sp->tif->tif_clientdata,sp->tif->tif_name,"Strip offsets are missing");
return(0);
}
sp->in_buffer_file_pos=sp->tif->tif_dir.td_stripoffset[sp->in_buffer_next_strile];
if (sp->in_buffer_file_pos!=0) if (sp->in_buffer_file_pos!=0)
{ {
if (sp->in_buffer_file_pos>=sp->file_size) if (sp->in_buffer_file_pos>=sp->file_size)
sp->in_buffer_file_pos=0; sp->in_buffer_file_pos=0;
else if (sp->tif->tif_dir.td_stripbytecount==NULL)
sp->in_buffer_file_togo=sp->file_size-sp->in_buffer_file_pos;
else else
{ {
sp->in_buffer_file_togo=sp->tif->tif_dir.td_stripbytecount[sp->in_buffer_next_strile]; if (sp->tif->tif_dir.td_stripbytecount == 0) {
TIFFErrorExt(sp->tif->tif_clientdata,sp->tif->tif_name,"Strip byte counts are missing");
return(0);
}
sp->in_buffer_file_togo=sp->tif->tif_dir.td_stripbytecount[sp->in_buffer_next_strile];
if (sp->in_buffer_file_togo==0) if (sp->in_buffer_file_togo==0)
sp->in_buffer_file_pos=0; sp->in_buffer_file_pos=0;
else if (sp->in_buffer_file_pos+sp->in_buffer_file_togo>sp->file_size) else if (sp->in_buffer_file_pos+sp->in_buffer_file_togo>sp->file_size)
@ -2031,8 +2082,8 @@ OJPEGReadSkip(OJPEGState* sp, uint16 len)
{ {
assert(sp->in_buffer_togo==0); assert(sp->in_buffer_togo==0);
n=m; n=m;
if (n>sp->in_buffer_file_togo) if ((uint64)n>sp->in_buffer_file_togo)
n=sp->in_buffer_file_togo; n=(uint16)sp->in_buffer_file_togo;
sp->in_buffer_file_pos+=n; sp->in_buffer_file_pos+=n;
sp->in_buffer_file_togo-=n; sp->in_buffer_file_togo-=n;
sp->in_buffer_file_pos_log=0; sp->in_buffer_file_pos_log=0;
@ -2271,7 +2322,7 @@ OJPEGWriteStreamCompressed(TIFF* tif, void** mem, uint32* len)
switch(sp->in_buffer_source) switch(sp->in_buffer_source)
{ {
case osibsStrile: case osibsStrile:
if (sp->in_buffer_next_strile<sp->in_buffer_strile_count) if (sp->in_buffer_next_strile<sp->in_buffer_strile_count)
sp->out_state=ososRst; sp->out_state=ososRst;
else else
sp->out_state=ososEoi; sp->out_state=ososEoi;
@ -2366,7 +2417,7 @@ OJPEGLibjpegJpegErrorMgrOutputMessage(jpeg_common_struct* cinfo)
{ {
char buffer[JMSG_LENGTH_MAX]; char buffer[JMSG_LENGTH_MAX];
(*cinfo->err->format_message)(cinfo,buffer); (*cinfo->err->format_message)(cinfo,buffer);
TIFFWarningExt(((TIFF*)(cinfo->client_data))->tif_clientdata,"LibJpeg", "%s", buffer); TIFFWarningExt(((TIFF*)(cinfo->client_data))->tif_clientdata,"LibJpeg","%s",buffer);
} }
static void static void
@ -2374,7 +2425,7 @@ OJPEGLibjpegJpegErrorMgrErrorExit(jpeg_common_struct* cinfo)
{ {
char buffer[JMSG_LENGTH_MAX]; char buffer[JMSG_LENGTH_MAX];
(*cinfo->err->format_message)(cinfo,buffer); (*cinfo->err->format_message)(cinfo,buffer);
TIFFErrorExt(((TIFF*)(cinfo->client_data))->tif_clientdata,"LibJpeg", "%s", buffer); TIFFErrorExt(((TIFF*)(cinfo->client_data))->tif_clientdata,"LibJpeg","%s",buffer);
jpeg_encap_unwind((TIFF*)(cinfo->client_data)); jpeg_encap_unwind((TIFF*)(cinfo->client_data));
} }
@ -2390,7 +2441,7 @@ OJPEGLibjpegJpegSourceMgrFillInputBuffer(jpeg_decompress_struct* cinfo)
TIFF* tif=(TIFF*)cinfo->client_data; TIFF* tif=(TIFF*)cinfo->client_data;
OJPEGState* sp=(OJPEGState*)tif->tif_data; OJPEGState* sp=(OJPEGState*)tif->tif_data;
void* mem=0; void* mem=0;
uint32 len=0; uint32 len=0U;
if (OJPEGWriteStream(tif,&mem,&len)==0) if (OJPEGWriteStream(tif,&mem,&len)==0)
{ {
TIFFErrorExt(tif->tif_clientdata,"LibJpeg","Premature end of JPEG data"); TIFFErrorExt(tif->tif_clientdata,"LibJpeg","Premature end of JPEG data");

View File

@ -1,4 +1,4 @@
/* $Id: tif_open.c,v 1.33.2.1 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_open.c,v 1.46 2010-12-06 16:54:54 faxguy Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -29,90 +29,22 @@
*/ */
#include "tiffiop.h" #include "tiffiop.h"
static const long typemask[13] = {
(long)0L, /* TIFF_NOTYPE */
(long)0x000000ffL, /* TIFF_BYTE */
(long)0xffffffffL, /* TIFF_ASCII */
(long)0x0000ffffL, /* TIFF_SHORT */
(long)0xffffffffL, /* TIFF_LONG */
(long)0xffffffffL, /* TIFF_RATIONAL */
(long)0x000000ffL, /* TIFF_SBYTE */
(long)0x000000ffL, /* TIFF_UNDEFINED */
(long)0x0000ffffL, /* TIFF_SSHORT */
(long)0xffffffffL, /* TIFF_SLONG */
(long)0xffffffffL, /* TIFF_SRATIONAL */
(long)0xffffffffL, /* TIFF_FLOAT */
(long)0xffffffffL, /* TIFF_DOUBLE */
};
static const int bigTypeshift[13] = {
0, /* TIFF_NOTYPE */
24, /* TIFF_BYTE */
0, /* TIFF_ASCII */
16, /* TIFF_SHORT */
0, /* TIFF_LONG */
0, /* TIFF_RATIONAL */
24, /* TIFF_SBYTE */
24, /* TIFF_UNDEFINED */
16, /* TIFF_SSHORT */
0, /* TIFF_SLONG */
0, /* TIFF_SRATIONAL */
0, /* TIFF_FLOAT */
0, /* TIFF_DOUBLE */
};
static const int litTypeshift[13] = {
0, /* TIFF_NOTYPE */
0, /* TIFF_BYTE */
0, /* TIFF_ASCII */
0, /* TIFF_SHORT */
0, /* TIFF_LONG */
0, /* TIFF_RATIONAL */
0, /* TIFF_SBYTE */
0, /* TIFF_UNDEFINED */
0, /* TIFF_SSHORT */
0, /* TIFF_SLONG */
0, /* TIFF_SRATIONAL */
0, /* TIFF_FLOAT */
0, /* TIFF_DOUBLE */
};
/* /*
* Dummy functions to fill the omitted client procedures. * Dummy functions to fill the omitted client procedures.
*/ */
static int static int
_tiffDummyMapProc(thandle_t fd, tdata_t* pbase, toff_t* psize) _tiffDummyMapProc(thandle_t fd, void** pbase, toff_t* psize)
{ {
(void) fd; (void) pbase; (void) psize; (void) fd; (void) pbase; (void) psize;
return (0); return (0);
} }
static void static void
_tiffDummyUnmapProc(thandle_t fd, tdata_t base, toff_t size) _tiffDummyUnmapProc(thandle_t fd, void* base, toff_t size)
{ {
(void) fd; (void) base; (void) size; (void) fd; (void) base; (void) size;
} }
/*
* Initialize the shift & mask tables, and the
* byte swapping state according to the file
* contents and the machine architecture.
*/
static void
TIFFInitOrder(TIFF* tif, int magic)
{
tif->tif_typemask = typemask;
if (magic == TIFF_BIGENDIAN) {
tif->tif_typeshift = bigTypeshift;
#ifndef WORDS_BIGENDIAN
tif->tif_flags |= TIFF_SWAB;
#endif
} else {
tif->tif_typeshift = litTypeshift;
#ifdef WORDS_BIGENDIAN
tif->tif_flags |= TIFF_SWAB;
#endif
}
}
int int
_TIFFgetMode(const char* mode, const char* module) _TIFFgetMode(const char* mode, const char* module)
{ {
@ -155,10 +87,36 @@ TIFFClientOpen(
int m; int m;
const char* cp; const char* cp;
/* The following are configuration checks. They should be redundant, but should not
* compile to any actual code in an optimised release build anyway. If any of them
* fail, (makefile-based or other) configuration is not correct */
assert(sizeof(uint8)==1);
assert(sizeof(int8)==1);
assert(sizeof(uint16)==2);
assert(sizeof(int16)==2);
assert(sizeof(uint32)==4);
assert(sizeof(int32)==4);
assert(sizeof(uint64)==8);
assert(sizeof(int64)==8);
assert(sizeof(tmsize_t)==sizeof(void*));
{
union{
uint8 a8[2];
uint16 a16;
} n;
n.a8[0]=1;
n.a8[1]=0;
#ifdef WORDS_BIGENDIAN
assert(n.a16==256);
#else
assert(n.a16==1);
#endif
}
m = _TIFFgetMode(mode, module); m = _TIFFgetMode(mode, module);
if (m == -1) if (m == -1)
goto bad2; goto bad2;
tif = (TIFF *)_TIFFmalloc(sizeof (TIFF) + strlen(name) + 1); tif = (TIFF *)_TIFFmalloc((tmsize_t)(sizeof (TIFF) + strlen(name) + 1));
if (tif == NULL) { if (tif == NULL) {
TIFFErrorExt(clientdata, module, "%s: Out of memory (TIFF structure)", name); TIFFErrorExt(clientdata, module, "%s: Out of memory (TIFF structure)", name);
goto bad2; goto bad2;
@ -167,14 +125,14 @@ TIFFClientOpen(
tif->tif_name = (char *)tif + sizeof (TIFF); tif->tif_name = (char *)tif + sizeof (TIFF);
strcpy(tif->tif_name, name); strcpy(tif->tif_name, name);
tif->tif_mode = m &~ (O_CREAT|O_TRUNC); tif->tif_mode = m &~ (O_CREAT|O_TRUNC);
tif->tif_curdir = (tdir_t) -1; /* non-existent directory */ tif->tif_curdir = (uint16) -1; /* non-existent directory */
tif->tif_curoff = 0; tif->tif_curoff = 0;
tif->tif_curstrip = (tstrip_t) -1; /* invalid strip */ tif->tif_curstrip = (uint32) -1; /* invalid strip */
tif->tif_row = (uint32) -1; /* read/write pre-increment */ tif->tif_row = (uint32) -1; /* read/write pre-increment */
tif->tif_clientdata = clientdata; tif->tif_clientdata = clientdata;
if (!readproc || !writeproc || !seekproc || !closeproc || !sizeproc) { if (!readproc || !writeproc || !seekproc || !closeproc || !sizeproc) {
TIFFErrorExt(clientdata, module, TIFFErrorExt(clientdata, module,
"One of the client procedures is NULL pointer."); "One of the client procedures is NULL pointer.");
goto bad2; goto bad2;
} }
tif->tif_readproc = readproc; tif->tif_readproc = readproc;
@ -182,7 +140,7 @@ TIFFClientOpen(
tif->tif_seekproc = seekproc; tif->tif_seekproc = seekproc;
tif->tif_closeproc = closeproc; tif->tif_closeproc = closeproc;
tif->tif_sizeproc = sizeproc; tif->tif_sizeproc = sizeproc;
if (mapproc) if (mapproc)
tif->tif_mapproc = mapproc; tif->tif_mapproc = mapproc;
else else
tif->tif_mapproc = _tiffDummyMapProc; tif->tif_mapproc = _tiffDummyMapProc;
@ -190,7 +148,7 @@ TIFFClientOpen(
tif->tif_unmapproc = unmapproc; tif->tif_unmapproc = unmapproc;
else else
tif->tif_unmapproc = _tiffDummyUnmapProc; tif->tif_unmapproc = _tiffDummyUnmapProc;
_TIFFSetDefaultCompressionState(tif); /* setup default state */ _TIFFSetDefaultCompressionState(tif); /* setup default state */
/* /*
* Default is to return data MSB2LSB and enable the * Default is to return data MSB2LSB and enable the
* use of memory-mapped files and strip chopping when * use of memory-mapped files and strip chopping when
@ -200,10 +158,10 @@ TIFFClientOpen(
if (m == O_RDONLY ) if (m == O_RDONLY )
tif->tif_flags |= TIFF_MAPPED; tif->tif_flags |= TIFF_MAPPED;
#ifdef STRIPCHOP_DEFAULT #ifdef STRIPCHOP_DEFAULT
if (m == O_RDONLY || m == O_RDWR) if (m == O_RDONLY || m == O_RDWR)
tif->tif_flags |= STRIPCHOP_DEFAULT; tif->tif_flags |= STRIPCHOP_DEFAULT;
#endif #endif
/* /*
* Process library-specific flags in the open mode string. * Process library-specific flags in the open mode string.
@ -213,16 +171,18 @@ TIFFClientOpen(
* TIFF but only supports some braindead idea of what the * TIFF but only supports some braindead idea of what the
* vendor thinks TIFF is): * vendor thinks TIFF is):
* *
* 'l' use little-endian byte order for creating a file * 'l' use little-endian byte order for creating a file
* 'b' use big-endian byte order for creating a file * 'b' use big-endian byte order for creating a file
* 'L' read/write information using LSB2MSB bit order * 'L' read/write information using LSB2MSB bit order
* 'B' read/write information using MSB2LSB bit order * 'B' read/write information using MSB2LSB bit order
* 'H' read/write information using host bit order * 'H' read/write information using host bit order
* 'M' enable use of memory-mapped files when supported * 'M' enable use of memory-mapped files when supported
* 'm' disable use of memory-mapped files * 'm' disable use of memory-mapped files
* 'C' enable strip chopping support when reading * 'C' enable strip chopping support when reading
* 'c' disable strip chopping support * 'c' disable strip chopping support
* 'h' read TIFF header only, do not load the first IFD * 'h' read TIFF header only, do not load the first IFD
* '4' ClassicTIFF for creating a file (default)
* '8' BigTIFF for creating a file
* *
* The use of the 'l' and 'b' flags is strongly discouraged. * The use of the 'l' and 'b' flags is strongly discouraged.
* These flags are provided solely because numerous vendors, * These flags are provided solely because numerous vendors,
@ -257,94 +217,120 @@ TIFFClientOpen(
*/ */
for (cp = mode; *cp; cp++) for (cp = mode; *cp; cp++)
switch (*cp) { switch (*cp) {
case 'b': case 'b':
#ifndef WORDS_BIGENDIAN #ifndef WORDS_BIGENDIAN
if (m&O_CREAT) if (m&O_CREAT)
tif->tif_flags |= TIFF_SWAB; tif->tif_flags |= TIFF_SWAB;
#endif #endif
break; break;
case 'l': case 'l':
#ifdef WORDS_BIGENDIAN #ifdef WORDS_BIGENDIAN
if ((m&O_CREAT)) if ((m&O_CREAT))
tif->tif_flags |= TIFF_SWAB; tif->tif_flags |= TIFF_SWAB;
#endif #endif
break; break;
case 'B': case 'B':
tif->tif_flags = (tif->tif_flags &~ TIFF_FILLORDER) | tif->tif_flags = (tif->tif_flags &~ TIFF_FILLORDER) |
FILLORDER_MSB2LSB; FILLORDER_MSB2LSB;
break; break;
case 'L': case 'L':
tif->tif_flags = (tif->tif_flags &~ TIFF_FILLORDER) | tif->tif_flags = (tif->tif_flags &~ TIFF_FILLORDER) |
FILLORDER_LSB2MSB; FILLORDER_LSB2MSB;
break; break;
case 'H': case 'H':
tif->tif_flags = (tif->tif_flags &~ TIFF_FILLORDER) | tif->tif_flags = (tif->tif_flags &~ TIFF_FILLORDER) |
HOST_FILLORDER; HOST_FILLORDER;
break; break;
case 'M': case 'M':
if (m == O_RDONLY) if (m == O_RDONLY)
tif->tif_flags |= TIFF_MAPPED; tif->tif_flags |= TIFF_MAPPED;
break; break;
case 'm': case 'm':
if (m == O_RDONLY) if (m == O_RDONLY)
tif->tif_flags &= ~TIFF_MAPPED; tif->tif_flags &= ~TIFF_MAPPED;
break; break;
case 'C': case 'C':
if (m == O_RDONLY) if (m == O_RDONLY)
tif->tif_flags |= TIFF_STRIPCHOP; tif->tif_flags |= TIFF_STRIPCHOP;
break; break;
case 'c': case 'c':
if (m == O_RDONLY) if (m == O_RDONLY)
tif->tif_flags &= ~TIFF_STRIPCHOP; tif->tif_flags &= ~TIFF_STRIPCHOP;
break; break;
case 'h': case 'h':
tif->tif_flags |= TIFF_HEADERONLY; tif->tif_flags |= TIFF_HEADERONLY;
break; break;
case '8':
if (m&O_CREAT)
tif->tif_flags |= TIFF_BIGTIFF;
break;
} }
/* /*
* Read in TIFF header. * Read in TIFF header.
*/ */
if (tif->tif_mode & O_TRUNC || if ((m & O_TRUNC) ||
!ReadOK(tif, &tif->tif_header, sizeof (TIFFHeader))) { !ReadOK(tif, &tif->tif_header, sizeof (TIFFHeaderClassic))) {
if (tif->tif_mode == O_RDONLY) { if (tif->tif_mode == O_RDONLY) {
TIFFErrorExt(tif->tif_clientdata, name, TIFFErrorExt(tif->tif_clientdata, name,
"Cannot read TIFF header"); "Cannot read TIFF header");
goto bad; goto bad;
} }
/* /*
* Setup header and write. * Setup header and write.
*/ */
#ifdef WORDS_BIGENDIAN #ifdef WORDS_BIGENDIAN
tif->tif_header.tiff_magic = tif->tif_flags & TIFF_SWAB tif->tif_header.common.tiff_magic = tif->tif_flags & TIFF_SWAB
? TIFF_LITTLEENDIAN : TIFF_BIGENDIAN; ? TIFF_LITTLEENDIAN : TIFF_BIGENDIAN;
#else #else
tif->tif_header.tiff_magic = tif->tif_flags & TIFF_SWAB tif->tif_header.common.tiff_magic = tif->tif_flags & TIFF_SWAB
? TIFF_BIGENDIAN : TIFF_LITTLEENDIAN; ? TIFF_BIGENDIAN : TIFF_LITTLEENDIAN;
#endif #endif
tif->tif_header.tiff_version = TIFF_VERSION; if (!(tif->tif_flags&TIFF_BIGTIFF))
if (tif->tif_flags & TIFF_SWAB) {
TIFFSwabShort(&tif->tif_header.tiff_version); tif->tif_header.common.tiff_version = TIFF_VERSION_CLASSIC;
tif->tif_header.tiff_diroff = 0; /* filled in later */ tif->tif_header.classic.tiff_diroff = 0;
if (tif->tif_flags & TIFF_SWAB)
TIFFSwabShort(&tif->tif_header.common.tiff_version);
/* tif->tif_header_size = sizeof(TIFFHeaderClassic);
* The doc for "fopen" for some STD_C_LIBs says that if you }
* open a file for modify ("+"), then you must fseek (or else
* fflush?) between any freads and fwrites. This is not {
* necessary on most systems, but has been shown to be needed tif->tif_header.common.tiff_version = TIFF_VERSION_BIG;
* on Solaris. tif->tif_header.big.tiff_offsetsize = 8;
*/ tif->tif_header.big.tiff_unused = 0;
TIFFSeekFile( tif, 0, SEEK_SET ); tif->tif_header.big.tiff_diroff = 0;
if (tif->tif_flags & TIFF_SWAB)
if (!WriteOK(tif, &tif->tif_header, sizeof (TIFFHeader))) { {
TIFFSwabShort(&tif->tif_header.common.tiff_version);
TIFFSwabShort(&tif->tif_header.big.tiff_offsetsize);
}
tif->tif_header_size = sizeof (TIFFHeaderBig);
}
/*
* The doc for "fopen" for some STD_C_LIBs says that if you
* open a file for modify ("+"), then you must fseek (or
* fflush?) between any freads and fwrites. This is not
* necessary on most systems, but has been shown to be needed
* on Solaris.
*/
TIFFSeekFile( tif, 0, SEEK_SET );
if (!WriteOK(tif, &tif->tif_header, (tmsize_t)(tif->tif_header_size))) {
TIFFErrorExt(tif->tif_clientdata, name, TIFFErrorExt(tif->tif_clientdata, name,
"Error writing TIFF header"); "Error writing TIFF header");
goto bad; goto bad;
} }
/* /*
* Setup the byte order handling. * Setup the byte order handling.
*/ */
TIFFInitOrder(tif, tif->tif_header.tiff_magic); if (tif->tif_header.common.tiff_magic == TIFF_BIGENDIAN) {
#ifndef WORDS_BIGENDIAN
tif->tif_flags |= TIFF_SWAB;
#endif
} else {
#ifdef WORDS_BIGENDIAN
tif->tif_flags |= TIFF_SWAB;
#endif
}
/* /*
* Setup default directory. * Setup default directory.
*/ */
@ -359,95 +345,139 @@ TIFFClientOpen(
/* /*
* Setup the byte order handling. * Setup the byte order handling.
*/ */
if (tif->tif_header.tiff_magic != TIFF_BIGENDIAN && if (tif->tif_header.common.tiff_magic != TIFF_BIGENDIAN &&
tif->tif_header.tiff_magic != TIFF_LITTLEENDIAN tif->tif_header.common.tiff_magic != TIFF_LITTLEENDIAN
#if MDI_SUPPORT #if MDI_SUPPORT
&& &&
#if HOST_BIGENDIAN #if HOST_BIGENDIAN
tif->tif_header.tiff_magic != MDI_BIGENDIAN tif->tif_header.common.tiff_magic != MDI_BIGENDIAN
#else #else
tif->tif_header.tiff_magic != MDI_LITTLEENDIAN tif->tif_header.common.tiff_magic != MDI_LITTLEENDIAN
#endif #endif
) { ) {
TIFFErrorExt(tif->tif_clientdata, name, TIFFErrorExt(tif->tif_clientdata, name,
"Not a TIFF or MDI file, bad magic number %d (0x%x)", "Not a TIFF or MDI file, bad magic number %d (0x%x)",
#else #else
) { ) {
TIFFErrorExt(tif->tif_clientdata, name, TIFFErrorExt(tif->tif_clientdata, name,
"Not a TIFF file, bad magic number %d (0x%x)", "Not a TIFF file, bad magic number %d (0x%x)",
#endif #endif
tif->tif_header.tiff_magic, tif->tif_header.common.tiff_magic,
tif->tif_header.tiff_magic); tif->tif_header.common.tiff_magic);
goto bad; goto bad;
} }
TIFFInitOrder(tif, tif->tif_header.tiff_magic); if (tif->tif_header.common.tiff_magic == TIFF_BIGENDIAN) {
/* #ifndef WORDS_BIGENDIAN
* Swap header if required. tif->tif_flags |= TIFF_SWAB;
*/ #endif
if (tif->tif_flags & TIFF_SWAB) { } else {
TIFFSwabShort(&tif->tif_header.tiff_version); #ifdef WORDS_BIGENDIAN
TIFFSwabLong(&tif->tif_header.tiff_diroff); tif->tif_flags |= TIFF_SWAB;
#endif
} }
/* if (tif->tif_flags & TIFF_SWAB)
* Now check version (if needed, it's been byte-swapped). TIFFSwabShort(&tif->tif_header.common.tiff_version);
* Note that this isn't actually a version number, it's a if ((tif->tif_header.common.tiff_version != TIFF_VERSION_CLASSIC)&&
* magic number that doesn't change (stupid). (tif->tif_header.common.tiff_version != TIFF_VERSION_BIG)) {
*/
if (tif->tif_header.tiff_version == TIFF_BIGTIFF_VERSION) {
TIFFErrorExt(tif->tif_clientdata, name,
"This is a BigTIFF file. This format not supported\n"
"by this version of libtiff." );
goto bad;
}
if (tif->tif_header.tiff_version != TIFF_VERSION) {
TIFFErrorExt(tif->tif_clientdata, name, TIFFErrorExt(tif->tif_clientdata, name,
"Not a TIFF file, bad version number %d (0x%x)", "Not a TIFF file, bad version number %d (0x%x)",
tif->tif_header.tiff_version, tif->tif_header.common.tiff_version,
tif->tif_header.tiff_version); tif->tif_header.common.tiff_version);
goto bad; goto bad;
} }
if (tif->tif_header.common.tiff_version == TIFF_VERSION_CLASSIC)
{
if (tif->tif_flags & TIFF_SWAB)
TIFFSwabLong(&tif->tif_header.classic.tiff_diroff);
tif->tif_header_size = sizeof(TIFFHeaderClassic);
}
else
{
if (!ReadOK(tif, ((uint8*)(&tif->tif_header) + sizeof(TIFFHeaderClassic)), (sizeof(TIFFHeaderBig)-sizeof(TIFFHeaderClassic))))
{
TIFFErrorExt(tif->tif_clientdata, name,
"Cannot read TIFF header");
goto bad;
}
if (tif->tif_flags & TIFF_SWAB)
{
TIFFSwabShort(&tif->tif_header.big.tiff_offsetsize);
TIFFSwabLong8(&tif->tif_header.big.tiff_diroff);
}
if (tif->tif_header.big.tiff_offsetsize != 8)
{
TIFFErrorExt(tif->tif_clientdata, name,
"Not a TIFF file, bad BigTIFF offsetsize %d (0x%x)",
tif->tif_header.big.tiff_offsetsize,
tif->tif_header.big.tiff_offsetsize);
goto bad;
}
if (tif->tif_header.big.tiff_unused != 0)
{
TIFFErrorExt(tif->tif_clientdata, name,
"Not a TIFF file, bad BigTIFF unused %d (0x%x)",
tif->tif_header.big.tiff_unused,
tif->tif_header.big.tiff_unused);
goto bad;
}
tif->tif_header_size = sizeof(TIFFHeaderBig);
tif->tif_flags |= TIFF_BIGTIFF;
}
tif->tif_flags |= TIFF_MYBUFFER; tif->tif_flags |= TIFF_MYBUFFER;
tif->tif_rawcp = tif->tif_rawdata = 0; tif->tif_rawcp = tif->tif_rawdata = 0;
tif->tif_rawdatasize = 0; tif->tif_rawdatasize = 0;
tif->tif_rawdataoff = 0;
tif->tif_rawdataloaded = 0;
/*
* Sometimes we do not want to read the first directory (for example,
* it may be broken) and want to proceed to other directories. I this
* case we use the TIFF_HEADERONLY flag to open file and return
* immediately after reading TIFF header.
*/
if (tif->tif_flags & TIFF_HEADERONLY)
return (tif);
/*
* Setup initial directory.
*/
switch (mode[0]) { switch (mode[0]) {
case 'r': case 'r':
tif->tif_nextdiroff = tif->tif_header.tiff_diroff; if (!(tif->tif_flags&TIFF_BIGTIFF))
/* tif->tif_nextdiroff = tif->tif_header.classic.tiff_diroff;
* Try to use a memory-mapped file if the client else
* has not explicitly suppressed usage with the tif->tif_nextdiroff = tif->tif_header.big.tiff_diroff;
* 'm' flag in the open mode (see above). /*
*/ * Try to use a memory-mapped file if the client
if ((tif->tif_flags & TIFF_MAPPED) && * has not explicitly suppressed usage with the
!TIFFMapFileContents(tif, (tdata_t*) &tif->tif_base, &tif->tif_size)) * 'm' flag in the open mode (see above).
tif->tif_flags &= ~TIFF_MAPPED; */
if (TIFFReadDirectory(tif)) { if (tif->tif_flags & TIFF_MAPPED)
tif->tif_rawcc = -1; {
tif->tif_flags |= TIFF_BUFFERSETUP; toff_t n;
if (TIFFMapFileContents(tif,(void**)(&tif->tif_base),&n))
{
tif->tif_size=(tmsize_t)n;
assert((toff_t)tif->tif_size==n);
}
else
tif->tif_flags &= ~TIFF_MAPPED;
}
/*
* Sometimes we do not want to read the first directory (for example,
* it may be broken) and want to proceed to other directories. I this
* case we use the TIFF_HEADERONLY flag to open file and return
* immediately after reading TIFF header.
*/
if (tif->tif_flags & TIFF_HEADERONLY)
return (tif);
/*
* Setup initial directory.
*/
if (TIFFReadDirectory(tif)) {
tif->tif_rawcc = (tmsize_t)-1;
tif->tif_flags |= TIFF_BUFFERSETUP;
return (tif);
}
break;
case 'a':
/*
* New directories are automatically append
* to the end of the directory chain when they
* are written out (see TIFFWriteDirectory).
*/
if (!TIFFDefaultDirectory(tif))
goto bad;
return (tif); return (tif);
}
break;
case 'a':
/*
* New directories are automatically append
* to the end of the directory chain when they
* are written out (see TIFFWriteDirectory).
*/
if (!TIFFDefaultDirectory(tif))
goto bad;
return (tif);
} }
bad: bad:
tif->tif_mode = O_RDONLY; /* XXX avoid flush */ tif->tif_mode = O_RDONLY; /* XXX avoid flush */
@ -562,7 +592,7 @@ TIFFCurrentRow(TIFF* tif)
/* /*
* Return index of the current directory. * Return index of the current directory.
*/ */
tdir_t uint16
TIFFCurrentDirectory(TIFF* tif) TIFFCurrentDirectory(TIFF* tif)
{ {
return (tif->tif_curdir); return (tif->tif_curdir);
@ -571,7 +601,7 @@ TIFFCurrentDirectory(TIFF* tif)
/* /*
* Return current strip. * Return current strip.
*/ */
tstrip_t uint32
TIFFCurrentStrip(TIFF* tif) TIFFCurrentStrip(TIFF* tif)
{ {
return (tif->tif_curstrip); return (tif->tif_curstrip);
@ -580,7 +610,7 @@ TIFFCurrentStrip(TIFF* tif)
/* /*
* Return current tile. * Return current tile.
*/ */
ttile_t uint32
TIFFCurrentTile(TIFF* tif) TIFFCurrentTile(TIFF* tif)
{ {
return (tif->tif_curtile); return (tif->tif_curtile);
@ -619,7 +649,7 @@ TIFFIsMSB2LSB(TIFF* tif)
int int
TIFFIsBigEndian(TIFF* tif) TIFFIsBigEndian(TIFF* tif)
{ {
return (tif->tif_header.tiff_magic == TIFF_BIGENDIAN); return (tif->tif_header.common.tiff_magic == TIFF_BIGENDIAN);
} }
/* /*

View File

@ -1,4 +1,4 @@
/* $Id: tif_packbits.c,v 1.13.2.2 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_packbits.c,v 1.20 2010-03-10 18:56:49 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -34,19 +34,19 @@
#include <stdio.h> #include <stdio.h>
static int static int
PackBitsPreEncode(TIFF* tif, tsample_t s) PackBitsPreEncode(TIFF* tif, uint16 s)
{ {
(void) s; (void) s;
if (!(tif->tif_data = (tidata_t)_TIFFmalloc(sizeof(tsize_t)))) if (!(tif->tif_data = (uint8*)_TIFFmalloc(sizeof(tmsize_t))))
return (0); return (0);
/* /*
* Calculate the scanline/tile-width size in bytes. * Calculate the scanline/tile-width size in bytes.
*/ */
if (isTiled(tif)) if (isTiled(tif))
*(tsize_t*)tif->tif_data = TIFFTileRowSize(tif); *(tmsize_t*)tif->tif_data = TIFFTileRowSize(tif);
else else
*(tsize_t*)tif->tif_data = TIFFScanlineSize(tif); *(tmsize_t*)tif->tif_data = TIFFScanlineSize(tif);
return (1); return (1);
} }
@ -58,21 +58,16 @@ PackBitsPostEncode(TIFF* tif)
return (1); return (1);
} }
/*
* NB: tidata is the type representing *(tidata_t);
* if tidata_t is made signed then this type must
* be adjusted accordingly.
*/
typedef unsigned char tidata;
/* /*
* Encode a run of pixels. * Encode a run of pixels.
*/ */
static int static int
PackBitsEncode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s) PackBitsEncode(TIFF* tif, uint8* buf, tmsize_t cc, uint16 s)
{ {
unsigned char* bp = (unsigned char*) buf; unsigned char* bp = (unsigned char*) buf;
tidata_t op, ep, lastliteral; uint8* op;
uint8* ep;
uint8* lastliteral;
long n, slop; long n, slop;
int b; int b;
enum { BASE, LITERAL, RUN, LITERAL_RUN } state; enum { BASE, LITERAL, RUN, LITERAL_RUN } state;
@ -98,8 +93,8 @@ PackBitsEncode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s)
* front of the buffer. * front of the buffer.
*/ */
if (state == LITERAL || state == LITERAL_RUN) { if (state == LITERAL || state == LITERAL_RUN) {
slop = op - lastliteral; slop = (long)(op - lastliteral);
tif->tif_rawcc += lastliteral - tif->tif_rawcp; tif->tif_rawcc += (tmsize_t)(lastliteral - tif->tif_rawcp);
if (!TIFFFlushData1(tif)) if (!TIFFFlushData1(tif))
return (-1); return (-1);
op = tif->tif_rawcp; op = tif->tif_rawcp;
@ -107,7 +102,7 @@ PackBitsEncode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s)
*op++ = *lastliteral++; *op++ = *lastliteral++;
lastliteral = tif->tif_rawcp; lastliteral = tif->tif_rawcp;
} else { } else {
tif->tif_rawcc += op - tif->tif_rawcp; tif->tif_rawcc += (tmsize_t)(op - tif->tif_rawcp);
if (!TIFFFlushData1(tif)) if (!TIFFFlushData1(tif))
return (-1); return (-1);
op = tif->tif_rawcp; op = tif->tif_rawcp;
@ -118,17 +113,17 @@ PackBitsEncode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s)
if (n > 1) { if (n > 1) {
state = RUN; state = RUN;
if (n > 128) { if (n > 128) {
*op++ = (tidata) -127; *op++ = (uint8) -127;
*op++ = (tidataval_t) b; *op++ = (uint8) b;
n -= 128; n -= 128;
goto again; goto again;
} }
*op++ = (tidataval_t)(-(n-1)); *op++ = (uint8)(-(n-1));
*op++ = (tidataval_t) b; *op++ = (uint8) b;
} else { } else {
lastliteral = op; lastliteral = op;
*op++ = 0; *op++ = 0;
*op++ = (tidataval_t) b; *op++ = (uint8) b;
state = LITERAL; state = LITERAL;
} }
break; break;
@ -136,33 +131,33 @@ PackBitsEncode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s)
if (n > 1) { if (n > 1) {
state = LITERAL_RUN; state = LITERAL_RUN;
if (n > 128) { if (n > 128) {
*op++ = (tidata) -127; *op++ = (uint8) -127;
*op++ = (tidataval_t) b; *op++ = (uint8) b;
n -= 128; n -= 128;
goto again; goto again;
} }
*op++ = (tidataval_t)(-(n-1)); /* encode run */ *op++ = (uint8)(-(n-1)); /* encode run */
*op++ = (tidataval_t) b; *op++ = (uint8) b;
} else { /* extend literal */ } else { /* extend literal */
if (++(*lastliteral) == 127) if (++(*lastliteral) == 127)
state = BASE; state = BASE;
*op++ = (tidataval_t) b; *op++ = (uint8) b;
} }
break; break;
case RUN: /* last object was run */ case RUN: /* last object was run */
if (n > 1) { if (n > 1) {
if (n > 128) { if (n > 128) {
*op++ = (tidata) -127; *op++ = (uint8) -127;
*op++ = (tidataval_t) b; *op++ = (uint8) b;
n -= 128; n -= 128;
goto again; goto again;
} }
*op++ = (tidataval_t)(-(n-1)); *op++ = (uint8)(-(n-1));
*op++ = (tidataval_t) b; *op++ = (uint8) b;
} else { } else {
lastliteral = op; lastliteral = op;
*op++ = 0; *op++ = 0;
*op++ = (tidataval_t) b; *op++ = (uint8) b;
state = LITERAL; state = LITERAL;
} }
break; break;
@ -173,7 +168,7 @@ PackBitsEncode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s)
* case we convert literal-run-literal * case we convert literal-run-literal
* to a single literal. * to a single literal.
*/ */
if (n == 1 && op[-2] == (tidata) -1 && if (n == 1 && op[-2] == (uint8) -1 &&
*lastliteral < 126) { *lastliteral < 126) {
state = (((*lastliteral) += 2) == 127 ? state = (((*lastliteral) += 2) == 127 ?
BASE : LITERAL); BASE : LITERAL);
@ -183,7 +178,7 @@ PackBitsEncode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s)
goto again; goto again;
} }
} }
tif->tif_rawcc += op - tif->tif_rawcp; tif->tif_rawcc += (tmsize_t)(op - tif->tif_rawcp);
tif->tif_rawcp = op; tif->tif_rawcp = op;
return (1); return (1);
} }
@ -196,12 +191,12 @@ PackBitsEncode(TIFF* tif, tidata_t buf, tsize_t cc, tsample_t s)
* when it was encoded by strips. * when it was encoded by strips.
*/ */
static int static int
PackBitsEncodeChunk(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) PackBitsEncodeChunk(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
tsize_t rowsize = *(tsize_t*)tif->tif_data; tmsize_t rowsize = *(tmsize_t*)tif->tif_data;
while ((long)cc > 0) { while (cc > 0) {
int chunk = rowsize; tmsize_t chunk = rowsize;
if( cc < chunk ) if( cc < chunk )
chunk = cc; chunk = cc;
@ -215,17 +210,18 @@ PackBitsEncodeChunk(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
} }
static int static int
PackBitsDecode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s) PackBitsDecode(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
{ {
static const char module[] = "PackBitsDecode";
char *bp; char *bp;
tsize_t cc; tmsize_t cc;
long n; long n;
int b; int b;
(void) s; (void) s;
bp = (char*) tif->tif_rawcp; bp = (char*) tif->tif_rawcp;
cc = tif->tif_rawcc; cc = tif->tif_rawcc;
while (cc > 0 && (long)occ > 0) { while (cc > 0 && occ > 0) {
n = (long) *bp++, cc--; n = (long) *bp++, cc--;
/* /*
* Watch out for compilers that * Watch out for compilers that
@ -236,39 +232,37 @@ PackBitsDecode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
if (n < 0) { /* replicate next byte -n+1 times */ if (n < 0) { /* replicate next byte -n+1 times */
if (n == -128) /* nop */ if (n == -128) /* nop */
continue; continue;
n = -n + 1; n = -n + 1;
if( occ < n ) if( occ < (tmsize_t)n )
{ {
TIFFWarningExt(tif->tif_clientdata, tif->tif_name, TIFFWarningExt(tif->tif_clientdata, module,
"PackBitsDecode: discarding %ld bytes " "Discarding %lu bytes to avoid buffer overrun",
"to avoid buffer overrun", (unsigned long) ((tmsize_t)n - occ));
n - occ); n = (long)occ;
n = occ; }
}
occ -= n; occ -= n;
b = *bp++, cc--; b = *bp++, cc--; /* TODO: may be reading past input buffer here when input data is corrupt or ends prematurely */
while (n-- > 0) while (n-- > 0)
*op++ = (tidataval_t) b; *op++ = (uint8) b;
} else { /* copy next n+1 bytes literally */ } else { /* copy next n+1 bytes literally */
if (occ < n + 1) if (occ < (tmsize_t)(n + 1))
{ {
TIFFWarningExt(tif->tif_clientdata, tif->tif_name, TIFFWarningExt(tif->tif_clientdata, module,
"PackBitsDecode: discarding %ld bytes " "Discarding %lu bytes to avoid buffer overrun",
"to avoid buffer overrun", (unsigned long) ((tmsize_t)n - occ + 1));
n - occ + 1); n = (long)occ - 1;
n = occ - 1; }
} _TIFFmemcpy(op, bp, ++n); /* TODO: may be reading past input buffer here when input data is corrupt or ends prematurely */
_TIFFmemcpy(op, bp, ++n);
op += n; occ -= n; op += n; occ -= n;
bp += n; cc -= n; bp += n; cc -= n;
} }
} }
tif->tif_rawcp = (tidata_t) bp; tif->tif_rawcp = (uint8*) bp;
tif->tif_rawcc = cc; tif->tif_rawcc = cc;
if (occ > 0) { if (occ > 0) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"PackBitsDecode: Not enough data for scanline %ld", "Not enough data for scanline %lu",
(long) tif->tif_row); (unsigned long) tif->tif_row);
return (0); return (0);
} }
return (1); return (1);
@ -282,7 +276,7 @@ TIFFInitPackBits(TIFF* tif, int scheme)
tif->tif_decodestrip = PackBitsDecode; tif->tif_decodestrip = PackBitsDecode;
tif->tif_decodetile = PackBitsDecode; tif->tif_decodetile = PackBitsDecode;
tif->tif_preencode = PackBitsPreEncode; tif->tif_preencode = PackBitsPreEncode;
tif->tif_postencode = PackBitsPostEncode; tif->tif_postencode = PackBitsPostEncode;
tif->tif_encoderow = PackBitsEncode; tif->tif_encoderow = PackBitsEncode;
tif->tif_encodestrip = PackBitsEncodeChunk; tif->tif_encodestrip = PackBitsEncodeChunk;
tif->tif_encodetile = PackBitsEncodeChunk; tif->tif_encodetile = PackBitsEncodeChunk;

View File

@ -1,4 +1,4 @@
/* $Id: tif_pixarlog.c,v 1.15.2.4 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_pixarlog.c,v 1.35 2011-01-06 16:00:23 fwarmerdam Exp $ */
/* /*
* Copyright (c) 1996-1997 Sam Leffler * Copyright (c) 1996-1997 Sam Leffler
@ -83,7 +83,10 @@
* The codec also handle byte swapping the encoded values as necessary * The codec also handle byte swapping the encoded values as necessary
* since the library does not have the information necessary * since the library does not have the information necessary
* to know the bit depth of the raw unencoded buffer. * to know the bit depth of the raw unencoded buffer.
* *
* NOTE: This decoder does not appear to update tif_rawcp, and tif_rawcc.
* This can cause problems with the implementation of CHUNKY_STRIP_READ_SUPPORT
* as noted in http://trac.osgeo.org/gdal/ticket/3894. FrankW - Jan'11
*/ */
#include "tif_predict.h" #include "tif_predict.h"
@ -108,7 +111,7 @@ static float LogK1, LogK2;
#define REPEAT(n, op) { int i; i=n; do { i--; op; } while (i>0); } #define REPEAT(n, op) { int i; i=n; do { i--; op; } while (i>0); }
static void static void
horizontalAccumulateF(uint16 *wp, int n, int stride, float *op, horizontalAccumulateF(uint16 *wp, int n, int stride, float *op,
float *ToLinearF) float *ToLinearF)
{ {
register unsigned int cr, cg, cb, ca, mask; register unsigned int cr, cg, cb, ca, mask;
@ -587,11 +590,11 @@ PixarLogMakeTables(PixarLogState *sp)
return 1; return 1;
} }
#define DecoderState(tif) ((PixarLogState*) (tif)->tif_data) #define DecoderState(tif) ((PixarLogState*) (tif)->tif_data)
#define EncoderState(tif) ((PixarLogState*) (tif)->tif_data) #define EncoderState(tif) ((PixarLogState*) (tif)->tif_data)
static int PixarLogEncode(TIFF*, tidata_t, tsize_t, tsample_t); static int PixarLogEncode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s);
static int PixarLogDecode(TIFF*, tidata_t, tsize_t, tsample_t); static int PixarLogDecode(TIFF* tif, uint8* op, tmsize_t occ, uint16 s);
#define PIXARLOGDATAFMT_UNKNOWN -1 #define PIXARLOGDATAFMT_UNKNOWN -1
@ -630,10 +633,10 @@ PixarLogGuessDataFmt(TIFFDirectory *td)
return guess; return guess;
} }
static uint32 static tmsize_t
multiply(size_t m1, size_t m2) multiply_ms(tmsize_t m1, tmsize_t m2)
{ {
uint32 bytes = m1 * m2; tmsize_t bytes = m1 * m2;
if (m1 && bytes / m1 != m2) if (m1 && bytes / m1 != m2)
bytes = 0; bytes = 0;
@ -641,28 +644,35 @@ multiply(size_t m1, size_t m2)
return bytes; return bytes;
} }
static int
PixarLogFixupTags(TIFF* tif)
{
(void) tif;
return (1);
}
static int static int
PixarLogSetupDecode(TIFF* tif) PixarLogSetupDecode(TIFF* tif)
{ {
static const char module[] = "PixarLogSetupDecode";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
PixarLogState* sp = DecoderState(tif); PixarLogState* sp = DecoderState(tif);
tsize_t tbuf_size; tmsize_t tbuf_size;
static const char module[] = "PixarLogSetupDecode";
assert(sp != NULL); assert(sp != NULL);
/* Make sure no byte swapping happens on the data /* Make sure no byte swapping happens on the data
* after decompression. */ * after decompression. */
tif->tif_postdecode = _TIFFNoPostDecode; tif->tif_postdecode = _TIFFNoPostDecode;
/* for some reason, we can't do this in TIFFInitPixarLog */ /* for some reason, we can't do this in TIFFInitPixarLog */
sp->stride = (td->td_planarconfig == PLANARCONFIG_CONTIG ? sp->stride = (td->td_planarconfig == PLANARCONFIG_CONTIG ?
td->td_samplesperpixel : 1); td->td_samplesperpixel : 1);
tbuf_size = multiply(multiply(multiply(sp->stride, td->td_imagewidth), tbuf_size = multiply_ms(multiply_ms(multiply_ms(sp->stride, td->td_imagewidth),
td->td_rowsperstrip), sizeof(uint16)); td->td_rowsperstrip), sizeof(uint16));
if (tbuf_size == 0) if (tbuf_size == 0)
return (0); return (0); /* TODO: this is an error return without error report through TIFFErrorExt */
sp->tbuf = (uint16 *) _TIFFmalloc(tbuf_size); sp->tbuf = (uint16 *) _TIFFmalloc(tbuf_size);
if (sp->tbuf == NULL) if (sp->tbuf == NULL)
return (0); return (0);
@ -676,7 +686,7 @@ PixarLogSetupDecode(TIFF* tif)
} }
if (inflateInit(&sp->stream) != Z_OK) { if (inflateInit(&sp->stream) != Z_OK) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: %s", tif->tif_name, sp->stream.msg); TIFFErrorExt(tif->tif_clientdata, module, "%s", sp->stream.msg);
return (0); return (0);
} else { } else {
sp->state |= PLSTATE_INIT; sp->state |= PLSTATE_INIT;
@ -688,24 +698,36 @@ PixarLogSetupDecode(TIFF* tif)
* Setup state for decoding a strip. * Setup state for decoding a strip.
*/ */
static int static int
PixarLogPreDecode(TIFF* tif, tsample_t s) PixarLogPreDecode(TIFF* tif, uint16 s)
{ {
static const char module[] = "PixarLogPreDecode";
PixarLogState* sp = DecoderState(tif); PixarLogState* sp = DecoderState(tif);
(void) s; (void) s;
assert(sp != NULL); assert(sp != NULL);
sp->stream.next_in = tif->tif_rawdata; sp->stream.next_in = tif->tif_rawdata;
sp->stream.avail_in = tif->tif_rawcc; assert(sizeof(sp->stream.avail_in)==4); /* if this assert gets raised,
we need to simplify this code to reflect a ZLib that is likely updated
to deal with 8byte memory sizes, though this code will respond
apropriately even before we simplify it */
sp->stream.avail_in = (uInt) tif->tif_rawcc;
if ((tmsize_t)sp->stream.avail_in != tif->tif_rawcc)
{
TIFFErrorExt(tif->tif_clientdata, module, "ZLib cannot deal with buffers this size");
return (0);
}
return (inflateReset(&sp->stream) == Z_OK); return (inflateReset(&sp->stream) == Z_OK);
} }
static int static int
PixarLogDecode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s) PixarLogDecode(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
{ {
static const char module[] = "PixarLogDecode";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
PixarLogState* sp = DecoderState(tif); PixarLogState* sp = DecoderState(tif);
static const char module[] = "PixarLogDecode"; tmsize_t i;
int i, nsamples, llen; tmsize_t nsamples;
int llen;
uint16 *up; uint16 *up;
switch (sp->user_datafmt) { switch (sp->user_datafmt) {
@ -722,7 +744,7 @@ PixarLogDecode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
nsamples = occ; nsamples = occ;
break; break;
default: default:
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"%d bit input not supported in PixarLog", "%d bit input not supported in PixarLog",
td->td_bitspersample); td->td_bitspersample);
return 0; return 0;
@ -733,7 +755,16 @@ PixarLogDecode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
(void) s; (void) s;
assert(sp != NULL); assert(sp != NULL);
sp->stream.next_out = (unsigned char *) sp->tbuf; sp->stream.next_out = (unsigned char *) sp->tbuf;
sp->stream.avail_out = nsamples * sizeof(uint16); assert(sizeof(sp->stream.avail_out)==4); /* if this assert gets raised,
we need to simplify this code to reflect a ZLib that is likely updated
to deal with 8byte memory sizes, though this code will respond
apropriately even before we simplify it */
sp->stream.avail_out = (uInt) (nsamples * sizeof(uint16));
if (sp->stream.avail_out != nsamples * sizeof(uint16))
{
TIFFErrorExt(tif->tif_clientdata, module, "ZLib cannot deal with buffers this size");
return (0);
}
do { do {
int state = inflate(&sp->stream, Z_PARTIAL_FLUSH); int state = inflate(&sp->stream, Z_PARTIAL_FLUSH);
if (state == Z_STREAM_END) { if (state == Z_STREAM_END) {
@ -741,15 +772,15 @@ PixarLogDecode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
} }
if (state == Z_DATA_ERROR) { if (state == Z_DATA_ERROR) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"%s: Decoding error at scanline %d, %s", "Decoding error at scanline %lu, %s",
tif->tif_name, tif->tif_row, sp->stream.msg); (unsigned long) tif->tif_row, sp->stream.msg);
if (inflateSync(&sp->stream) != Z_OK) if (inflateSync(&sp->stream) != Z_OK)
return (0); return (0);
continue; continue;
} }
if (state != Z_OK) { if (state != Z_OK) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: zlib error: %s", TIFFErrorExt(tif->tif_clientdata, module, "ZLib error: %s",
tif->tif_name, sp->stream.msg); sp->stream.msg);
return (0); return (0);
} }
} while (sp->stream.avail_out > 0); } while (sp->stream.avail_out > 0);
@ -757,8 +788,8 @@ PixarLogDecode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
/* hopefully, we got all the bytes we needed */ /* hopefully, we got all the bytes we needed */
if (sp->stream.avail_out != 0) { if (sp->stream.avail_out != 0) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"%s: Not enough data at scanline %d (short %d bytes)", "Not enough data at scanline %lu (short " TIFF_UINT64_FORMAT " bytes)",
tif->tif_name, tif->tif_row, sp->stream.avail_out); (unsigned long) tif->tif_row, (TIFF_UINT64_T) sp->stream.avail_out);
return (0); return (0);
} }
@ -767,15 +798,15 @@ PixarLogDecode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
if (tif->tif_flags & TIFF_SWAB) if (tif->tif_flags & TIFF_SWAB)
TIFFSwabArrayOfShort(up, nsamples); TIFFSwabArrayOfShort(up, nsamples);
/* /*
* if llen is not an exact multiple of nsamples, the decode operation * if llen is not an exact multiple of nsamples, the decode operation
* may overflow the output buffer, so truncate it enough to prevent * may overflow the output buffer, so truncate it enough to prevent
* that but still salvage as much data as possible. * that but still salvage as much data as possible.
*/ */
if (nsamples % llen) { if (nsamples % llen) {
TIFFWarningExt(tif->tif_clientdata, module, TIFFWarningExt(tif->tif_clientdata, module,
"%s: stride %d is not a multiple of sample count, " "stride %lu is not a multiple of sample count, "
"%d, data truncated.", tif->tif_name, llen, nsamples); "%lu, data truncated.", (unsigned long) llen, (unsigned long) nsamples);
nsamples -= nsamples % llen; nsamples -= nsamples % llen;
} }
@ -812,8 +843,8 @@ PixarLogDecode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
op += llen * sizeof(unsigned char); op += llen * sizeof(unsigned char);
break; break;
default: default:
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"PixarLogDecode: unsupported bits/sample: %d", "Unsupported bits/sample: %d",
td->td_bitspersample); td->td_bitspersample);
return (0); return (0);
} }
@ -825,10 +856,10 @@ PixarLogDecode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s)
static int static int
PixarLogSetupEncode(TIFF* tif) PixarLogSetupEncode(TIFF* tif)
{ {
static const char module[] = "PixarLogSetupEncode";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
PixarLogState* sp = EncoderState(tif); PixarLogState* sp = EncoderState(tif);
tsize_t tbuf_size; tmsize_t tbuf_size;
static const char module[] = "PixarLogSetupEncode";
assert(sp != NULL); assert(sp != NULL);
@ -836,10 +867,10 @@ PixarLogSetupEncode(TIFF* tif)
sp->stride = (td->td_planarconfig == PLANARCONFIG_CONTIG ? sp->stride = (td->td_planarconfig == PLANARCONFIG_CONTIG ?
td->td_samplesperpixel : 1); td->td_samplesperpixel : 1);
tbuf_size = multiply(multiply(multiply(sp->stride, td->td_imagewidth), tbuf_size = multiply_ms(multiply_ms(multiply_ms(sp->stride, td->td_imagewidth),
td->td_rowsperstrip), sizeof(uint16)); td->td_rowsperstrip), sizeof(uint16));
if (tbuf_size == 0) if (tbuf_size == 0)
return (0); return (0); /* TODO: this is an error return without error report through TIFFErrorExt */
sp->tbuf = (uint16 *) _TIFFmalloc(tbuf_size); sp->tbuf = (uint16 *) _TIFFmalloc(tbuf_size);
if (sp->tbuf == NULL) if (sp->tbuf == NULL)
return (0); return (0);
@ -851,7 +882,7 @@ PixarLogSetupEncode(TIFF* tif)
} }
if (deflateInit(&sp->stream, sp->quality) != Z_OK) { if (deflateInit(&sp->stream, sp->quality) != Z_OK) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: %s", tif->tif_name, sp->stream.msg); TIFFErrorExt(tif->tif_clientdata, module, "%s", sp->stream.msg);
return (0); return (0);
} else { } else {
sp->state |= PLSTATE_INIT; sp->state |= PLSTATE_INIT;
@ -863,21 +894,30 @@ PixarLogSetupEncode(TIFF* tif)
* Reset encoding state at the start of a strip. * Reset encoding state at the start of a strip.
*/ */
static int static int
PixarLogPreEncode(TIFF* tif, tsample_t s) PixarLogPreEncode(TIFF* tif, uint16 s)
{ {
static const char module[] = "PixarLogPreEncode";
PixarLogState *sp = EncoderState(tif); PixarLogState *sp = EncoderState(tif);
(void) s; (void) s;
assert(sp != NULL); assert(sp != NULL);
sp->stream.next_out = tif->tif_rawdata; sp->stream.next_out = tif->tif_rawdata;
assert(sizeof(sp->stream.avail_out)==4); /* if this assert gets raised,
we need to simplify this code to reflect a ZLib that is likely updated
to deal with 8byte memory sizes, though this code will respond
apropriately even before we simplify it */
sp->stream.avail_out = tif->tif_rawdatasize; sp->stream.avail_out = tif->tif_rawdatasize;
if ((tmsize_t)sp->stream.avail_out != tif->tif_rawdatasize)
{
TIFFErrorExt(tif->tif_clientdata, module, "ZLib cannot deal with buffers this size");
return (0);
}
return (deflateReset(&sp->stream) == Z_OK); return (deflateReset(&sp->stream) == Z_OK);
} }
static void static void
horizontalDifferenceF(float *ip, int n, int stride, uint16 *wp, uint16 *FromLT2) horizontalDifferenceF(float *ip, int n, int stride, uint16 *wp, uint16 *FromLT2)
{ {
int32 r1, g1, b1, a1, r2, g2, b2, a2, mask; int32 r1, g1, b1, a1, r2, g2, b2, a2, mask;
float fltsize = Fltsize; float fltsize = Fltsize;
@ -1042,12 +1082,14 @@ horizontalDifference8(unsigned char *ip, int n, int stride,
* Encode a chunk of pixels. * Encode a chunk of pixels.
*/ */
static int static int
PixarLogEncode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) PixarLogEncode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
static const char module[] = "PixarLogEncode";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
PixarLogState *sp = EncoderState(tif); PixarLogState *sp = EncoderState(tif);
static const char module[] = "PixarLogEncode"; tmsize_t i;
int i, n, llen; tmsize_t n;
int llen;
unsigned short * up; unsigned short * up;
(void) s; (void) s;
@ -1066,7 +1108,7 @@ PixarLogEncode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
n = cc; n = cc;
break; break;
default: default:
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"%d bit input not supported in PixarLog", "%d bit input not supported in PixarLog",
td->td_bitspersample); td->td_bitspersample);
return 0; return 0;
@ -1092,7 +1134,7 @@ PixarLogEncode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
bp += llen * sizeof(unsigned char); bp += llen * sizeof(unsigned char);
break; break;
default: default:
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"%d bit input not supported in PixarLog", "%d bit input not supported in PixarLog",
td->td_bitspersample); td->td_bitspersample);
return 0; return 0;
@ -1100,19 +1142,29 @@ PixarLogEncode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
} }
sp->stream.next_in = (unsigned char *) sp->tbuf; sp->stream.next_in = (unsigned char *) sp->tbuf;
sp->stream.avail_in = n * sizeof(uint16); assert(sizeof(sp->stream.avail_in)==4); /* if this assert gets raised,
we need to simplify this code to reflect a ZLib that is likely updated
to deal with 8byte memory sizes, though this code will respond
apropriately even before we simplify it */
sp->stream.avail_in = (uInt) (n * sizeof(uint16));
if ((sp->stream.avail_in / sizeof(uint16)) != (uInt) n)
{
TIFFErrorExt(tif->tif_clientdata, module,
"ZLib cannot deal with buffers this size");
return (0);
}
do { do {
if (deflate(&sp->stream, Z_NO_FLUSH) != Z_OK) { if (deflate(&sp->stream, Z_NO_FLUSH) != Z_OK) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: Encoder error: %s", TIFFErrorExt(tif->tif_clientdata, module, "Encoder error: %s",
tif->tif_name, sp->stream.msg); sp->stream.msg);
return (0); return (0);
} }
if (sp->stream.avail_out == 0) { if (sp->stream.avail_out == 0) {
tif->tif_rawcc = tif->tif_rawdatasize; tif->tif_rawcc = tif->tif_rawdatasize;
TIFFFlushData1(tif); TIFFFlushData1(tif);
sp->stream.next_out = tif->tif_rawdata; sp->stream.next_out = tif->tif_rawdata;
sp->stream.avail_out = tif->tif_rawdatasize; sp->stream.avail_out = (uInt) tif->tif_rawdatasize; /* this is a safe typecast, as check is made already in PixarLogPreEncode */
} }
} while (sp->stream.avail_in > 0); } while (sp->stream.avail_in > 0);
return (1); return (1);
@ -1126,8 +1178,8 @@ PixarLogEncode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
static int static int
PixarLogPostEncode(TIFF* tif) PixarLogPostEncode(TIFF* tif)
{ {
PixarLogState *sp = EncoderState(tif);
static const char module[] = "PixarLogPostEncode"; static const char module[] = "PixarLogPostEncode";
PixarLogState *sp = EncoderState(tif);
int state; int state;
sp->stream.avail_in = 0; sp->stream.avail_in = 0;
@ -1137,17 +1189,17 @@ PixarLogPostEncode(TIFF* tif)
switch (state) { switch (state) {
case Z_STREAM_END: case Z_STREAM_END:
case Z_OK: case Z_OK:
if (sp->stream.avail_out != (uint32)tif->tif_rawdatasize) { if ((tmsize_t)sp->stream.avail_out != tif->tif_rawdatasize) {
tif->tif_rawcc = tif->tif_rawcc =
tif->tif_rawdatasize - sp->stream.avail_out; tif->tif_rawdatasize - sp->stream.avail_out;
TIFFFlushData1(tif); TIFFFlushData1(tif);
sp->stream.next_out = tif->tif_rawdata; sp->stream.next_out = tif->tif_rawdata;
sp->stream.avail_out = tif->tif_rawdatasize; sp->stream.avail_out = (uInt) tif->tif_rawdatasize; /* this is a safe typecast, as check is made already in PixarLogPreEncode */
} }
break; break;
default: default:
TIFFErrorExt(tif->tif_clientdata, module, "%s: zlib error: %s", TIFFErrorExt(tif->tif_clientdata, module, "ZLib error: %s",
tif->tif_name, sp->stream.msg); sp->stream.msg);
return (0); return (0);
} }
} while (state != Z_STREAM_END); } while (state != Z_STREAM_END);
@ -1159,9 +1211,11 @@ PixarLogClose(TIFF* tif)
{ {
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
/* In a really sneaky maneuver, on close, we covertly modify both /* In a really sneaky (and really incorrect, and untruthfull, and
* bitspersample and sampleformat in the directory to indicate * troublesome, and error-prone) maneuver that completely goes against
* 8-bit linear. This way, the decode "just works" even for * the spirit of TIFF, and breaks TIFF, on close, we covertly
* modify both bitspersample and sampleformat in the directory to
* indicate 8-bit linear. This way, the decode "just works" even for
* readers that don't know about PixarLog, or how to set * readers that don't know about PixarLog, or how to set
* the PIXARLOGDATFMT pseudo-tag. * the PIXARLOGDATFMT pseudo-tag.
*/ */
@ -1202,26 +1256,26 @@ PixarLogCleanup(TIFF* tif)
} }
static int static int
PixarLogVSetField(TIFF* tif, ttag_t tag, va_list ap) PixarLogVSetField(TIFF* tif, uint32 tag, va_list ap)
{ {
static const char module[] = "PixarLogVSetField";
PixarLogState *sp = (PixarLogState *)tif->tif_data; PixarLogState *sp = (PixarLogState *)tif->tif_data;
int result; int result;
static const char module[] = "PixarLogVSetField";
switch (tag) { switch (tag) {
case TIFFTAG_PIXARLOGQUALITY: case TIFFTAG_PIXARLOGQUALITY:
sp->quality = va_arg(ap, int); sp->quality = (int) va_arg(ap, int);
if (tif->tif_mode != O_RDONLY && (sp->state&PLSTATE_INIT)) { if (tif->tif_mode != O_RDONLY && (sp->state&PLSTATE_INIT)) {
if (deflateParams(&sp->stream, if (deflateParams(&sp->stream,
sp->quality, Z_DEFAULT_STRATEGY) != Z_OK) { sp->quality, Z_DEFAULT_STRATEGY) != Z_OK) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: zlib error: %s", TIFFErrorExt(tif->tif_clientdata, module, "ZLib error: %s",
tif->tif_name, sp->stream.msg); sp->stream.msg);
return (0); return (0);
} }
} }
return (1); return (1);
case TIFFTAG_PIXARLOGDATAFMT: case TIFFTAG_PIXARLOGDATAFMT:
sp->user_datafmt = va_arg(ap, int); sp->user_datafmt = (int) va_arg(ap, int);
/* Tweak the TIFF header so that the rest of libtiff knows what /* Tweak the TIFF header so that the rest of libtiff knows what
* size of data will be passed between app and library, and * size of data will be passed between app and library, and
* assume that the app knows what it is doing and is not * assume that the app knows what it is doing and is not
@ -1253,7 +1307,7 @@ PixarLogVSetField(TIFF* tif, ttag_t tag, va_list ap)
/* /*
* Must recalculate sizes should bits/sample change. * Must recalculate sizes should bits/sample change.
*/ */
tif->tif_tilesize = isTiled(tif) ? TIFFTileSize(tif) : (tsize_t) -1; tif->tif_tilesize = isTiled(tif) ? TIFFTileSize(tif) : (tmsize_t)(-1);
tif->tif_scanlinesize = TIFFScanlineSize(tif); tif->tif_scanlinesize = TIFFScanlineSize(tif);
result = 1; /* NB: pseudo tag */ result = 1; /* NB: pseudo tag */
break; break;
@ -1264,7 +1318,7 @@ PixarLogVSetField(TIFF* tif, ttag_t tag, va_list ap)
} }
static int static int
PixarLogVGetField(TIFF* tif, ttag_t tag, va_list ap) PixarLogVGetField(TIFF* tif, uint32 tag, va_list ap)
{ {
PixarLogState *sp = (PixarLogState *)tif->tif_data; PixarLogState *sp = (PixarLogState *)tif->tif_data;
@ -1281,9 +1335,9 @@ PixarLogVGetField(TIFF* tif, ttag_t tag, va_list ap)
return (1); return (1);
} }
static const TIFFFieldInfo pixarlogFieldInfo[] = { static const TIFFField pixarlogFields[] = {
{TIFFTAG_PIXARLOGDATAFMT,0,0,TIFF_ANY, FIELD_PSEUDO,FALSE,FALSE,""}, {TIFFTAG_PIXARLOGDATAFMT, 0, 0, TIFF_ANY, 0, TIFF_SETGET_INT, TIFF_SETGET_UNDEFINED, FIELD_PSEUDO, FALSE, FALSE, "", NULL},
{TIFFTAG_PIXARLOGQUALITY,0,0,TIFF_ANY, FIELD_PSEUDO,FALSE,FALSE,""} {TIFFTAG_PIXARLOGQUALITY, 0, 0, TIFF_ANY, 0, TIFF_SETGET_INT, TIFF_SETGET_UNDEFINED, FIELD_PSEUDO, FALSE, FALSE, "", NULL}
}; };
int int
@ -1298,8 +1352,8 @@ TIFFInitPixarLog(TIFF* tif, int scheme)
/* /*
* Merge codec-specific tag information. * Merge codec-specific tag information.
*/ */
if (!_TIFFMergeFieldInfo(tif, pixarlogFieldInfo, if (!_TIFFMergeFields(tif, pixarlogFields,
TIFFArrayCount(pixarlogFieldInfo))) { TIFFArrayCount(pixarlogFields))) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"Merging PixarLog codec-specific tags failed"); "Merging PixarLog codec-specific tags failed");
return 0; return 0;
@ -1308,7 +1362,7 @@ TIFFInitPixarLog(TIFF* tif, int scheme)
/* /*
* Allocate state block so tag methods have storage to record values. * Allocate state block so tag methods have storage to record values.
*/ */
tif->tif_data = (tidata_t) _TIFFmalloc(sizeof (PixarLogState)); tif->tif_data = (uint8*) _TIFFmalloc(sizeof (PixarLogState));
if (tif->tif_data == NULL) if (tif->tif_data == NULL)
goto bad; goto bad;
sp = (PixarLogState*) tif->tif_data; sp = (PixarLogState*) tif->tif_data;
@ -1319,17 +1373,18 @@ TIFFInitPixarLog(TIFF* tif, int scheme)
/* /*
* Install codec methods. * Install codec methods.
*/ */
tif->tif_fixuptags = PixarLogFixupTags;
tif->tif_setupdecode = PixarLogSetupDecode; tif->tif_setupdecode = PixarLogSetupDecode;
tif->tif_predecode = PixarLogPreDecode; tif->tif_predecode = PixarLogPreDecode;
tif->tif_decoderow = PixarLogDecode; tif->tif_decoderow = PixarLogDecode;
tif->tif_decodestrip = PixarLogDecode; tif->tif_decodestrip = PixarLogDecode;
tif->tif_decodetile = PixarLogDecode; tif->tif_decodetile = PixarLogDecode;
tif->tif_setupencode = PixarLogSetupEncode; tif->tif_setupencode = PixarLogSetupEncode;
tif->tif_preencode = PixarLogPreEncode; tif->tif_preencode = PixarLogPreEncode;
tif->tif_postencode = PixarLogPostEncode; tif->tif_postencode = PixarLogPostEncode;
tif->tif_encoderow = PixarLogEncode; tif->tif_encoderow = PixarLogEncode;
tif->tif_encodestrip = PixarLogEncode; tif->tif_encodestrip = PixarLogEncode;
tif->tif_encodetile = PixarLogEncode; tif->tif_encodetile = PixarLogEncode;
tif->tif_close = PixarLogClose; tif->tif_close = PixarLogClose;
tif->tif_cleanup = PixarLogCleanup; tif->tif_cleanup = PixarLogCleanup;

View File

@ -1,4 +1,4 @@
/* $Id: tif_predict.c,v 1.11.2.4 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_predict.c,v 1.32 2010-03-10 18:56:49 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -34,20 +34,20 @@
#define PredictorState(tif) ((TIFFPredictorState*) (tif)->tif_data) #define PredictorState(tif) ((TIFFPredictorState*) (tif)->tif_data)
static void horAcc8(TIFF*, tidata_t, tsize_t); static void horAcc8(TIFF* tif, uint8* cp0, tmsize_t cc);
static void horAcc16(TIFF*, tidata_t, tsize_t); static void horAcc16(TIFF* tif, uint8* cp0, tmsize_t cc);
static void horAcc32(TIFF*, tidata_t, tsize_t); static void horAcc32(TIFF* tif, uint8* cp0, tmsize_t cc);
static void swabHorAcc16(TIFF*, tidata_t, tsize_t); static void swabHorAcc16(TIFF* tif, uint8* cp0, tmsize_t cc);
static void swabHorAcc32(TIFF*, tidata_t, tsize_t); static void swabHorAcc32(TIFF* tif, uint8* cp0, tmsize_t cc);
static void horDiff8(TIFF*, tidata_t, tsize_t); static void horDiff8(TIFF* tif, uint8* cp0, tmsize_t cc);
static void horDiff16(TIFF*, tidata_t, tsize_t); static void horDiff16(TIFF* tif, uint8* cp0, tmsize_t cc);
static void horDiff32(TIFF*, tidata_t, tsize_t); static void horDiff32(TIFF* tif, uint8* cp0, tmsize_t cc);
static void fpAcc(TIFF*, tidata_t, tsize_t); static void fpAcc(TIFF* tif, uint8* cp0, tmsize_t cc);
static void fpDiff(TIFF*, tidata_t, tsize_t); static void fpDiff(TIFF* tif, uint8* cp0, tmsize_t cc);
static int PredictorDecodeRow(TIFF*, tidata_t, tsize_t, tsample_t); static int PredictorDecodeRow(TIFF* tif, uint8* op0, tmsize_t occ0, uint16 s);
static int PredictorDecodeTile(TIFF*, tidata_t, tsize_t, tsample_t); static int PredictorDecodeTile(TIFF* tif, uint8* op0, tmsize_t occ0, uint16 s);
static int PredictorEncodeRow(TIFF*, tidata_t, tsize_t, tsample_t); static int PredictorEncodeRow(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s);
static int PredictorEncodeTile(TIFF*, tidata_t, tsize_t, tsample_t); static int PredictorEncodeTile(TIFF* tif, uint8* bp0, tmsize_t cc0, uint16 s);
static int static int
PredictorSetup(TIFF* tif) PredictorSetup(TIFF* tif)
@ -66,23 +66,23 @@ PredictorSetup(TIFF* tif)
&& td->td_bitspersample != 16 && td->td_bitspersample != 16
&& td->td_bitspersample != 32) { && td->td_bitspersample != 32) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"Horizontal differencing \"Predictor\" not supported with %d-bit samples", "Horizontal differencing \"Predictor\" not supported with %d-bit samples",
td->td_bitspersample); td->td_bitspersample);
return 0; return 0;
} }
break; break;
case PREDICTOR_FLOATINGPOINT: case PREDICTOR_FLOATINGPOINT:
if (td->td_sampleformat != SAMPLEFORMAT_IEEEFP) { if (td->td_sampleformat != SAMPLEFORMAT_IEEEFP) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"Floating point \"Predictor\" not supported with %d data format", "Floating point \"Predictor\" not supported with %d data format",
td->td_sampleformat); td->td_sampleformat);
return 0; return 0;
} }
break; break;
default: default:
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"\"Predictor\" value %d not supported", "\"Predictor\" value %d not supported",
sp->predictor); sp->predictor);
return 0; return 0;
} }
sp->stride = (td->td_planarconfig == PLANARCONFIG_CONTIG ? sp->stride = (td->td_planarconfig == PLANARCONFIG_CONTIG ?
@ -94,6 +94,8 @@ PredictorSetup(TIFF* tif)
sp->rowsize = TIFFTileRowSize(tif); sp->rowsize = TIFFTileRowSize(tif);
else else
sp->rowsize = TIFFScanlineSize(tif); sp->rowsize = TIFFScanlineSize(tif);
if (sp->rowsize == 0)
return 0;
return 1; return 1;
} }
@ -126,6 +128,7 @@ PredictorSetupDecode(TIFF* tif)
sp->decodetile = tif->tif_decodetile; sp->decodetile = tif->tif_decodetile;
tif->tif_decodetile = PredictorDecodeTile; tif->tif_decodetile = PredictorDecodeTile;
} }
/* /*
* If the data is horizontally differenced 16-bit data that * If the data is horizontally differenced 16-bit data that
* requires byte-swapping, then it must be byte swapped before * requires byte-swapping, then it must be byte swapped before
@ -137,10 +140,10 @@ PredictorSetupDecode(TIFF* tif)
if (sp->decodepfunc == horAcc16) { if (sp->decodepfunc == horAcc16) {
sp->decodepfunc = swabHorAcc16; sp->decodepfunc = swabHorAcc16;
tif->tif_postdecode = _TIFFNoPostDecode; tif->tif_postdecode = _TIFFNoPostDecode;
} else if (sp->decodepfunc == horAcc32) { } else if (sp->decodepfunc == horAcc32) {
sp->decodepfunc = swabHorAcc32; sp->decodepfunc = swabHorAcc32;
tif->tif_postdecode = _TIFFNoPostDecode; tif->tif_postdecode = _TIFFNoPostDecode;
} }
} }
} }
@ -205,7 +208,7 @@ PredictorSetupEncode(TIFF* tif)
tif->tif_encodetile = PredictorEncodeTile; tif->tif_encodetile = PredictorEncodeTile;
} }
} }
else if (sp->predictor == 3) { else if (sp->predictor == 3) {
sp->encodepfunc = fpDiff; sp->encodepfunc = fpDiff;
/* /*
@ -228,7 +231,7 @@ PredictorSetupEncode(TIFF* tif)
#define REPEAT4(n, op) \ #define REPEAT4(n, op) \
switch (n) { \ switch (n) { \
default: { int i; for (i = n-4; i > 0; i--) { op; } } \ default: { tmsize_t i; for (i = n-4; i > 0; i--) { op; } } \
case 4: op; \ case 4: op; \
case 3: op; \ case 3: op; \
case 2: op; \ case 2: op; \
@ -237,13 +240,13 @@ PredictorSetupEncode(TIFF* tif)
} }
static void static void
horAcc8(TIFF* tif, tidata_t cp0, tsize_t cc) horAcc8(TIFF* tif, uint8* cp0, tmsize_t cc)
{ {
tsize_t stride = PredictorState(tif)->stride; tmsize_t stride = PredictorState(tif)->stride;
char* cp = (char*) cp0; char* cp = (char*) cp0;
assert((cc%stride)==0);
if (cc > stride) { if (cc > stride) {
cc -= stride;
/* /*
* Pipeline the most common cases. * Pipeline the most common cases.
*/ */
@ -251,40 +254,49 @@ horAcc8(TIFF* tif, tidata_t cp0, tsize_t cc)
unsigned int cr = cp[0]; unsigned int cr = cp[0];
unsigned int cg = cp[1]; unsigned int cg = cp[1];
unsigned int cb = cp[2]; unsigned int cb = cp[2];
do { cc -= 3;
cc -= 3, cp += 3; cp += 3;
while (cc>0) {
cp[0] = (char) (cr += cp[0]); cp[0] = (char) (cr += cp[0]);
cp[1] = (char) (cg += cp[1]); cp[1] = (char) (cg += cp[1]);
cp[2] = (char) (cb += cp[2]); cp[2] = (char) (cb += cp[2]);
} while ((int32) cc > 0); cc -= 3;
cp += 3;
}
} else if (stride == 4) { } else if (stride == 4) {
unsigned int cr = cp[0]; unsigned int cr = cp[0];
unsigned int cg = cp[1]; unsigned int cg = cp[1];
unsigned int cb = cp[2]; unsigned int cb = cp[2];
unsigned int ca = cp[3]; unsigned int ca = cp[3];
do { cc -= 4;
cc -= 4, cp += 4; cp += 4;
while (cc>0) {
cp[0] = (char) (cr += cp[0]); cp[0] = (char) (cr += cp[0]);
cp[1] = (char) (cg += cp[1]); cp[1] = (char) (cg += cp[1]);
cp[2] = (char) (cb += cp[2]); cp[2] = (char) (cb += cp[2]);
cp[3] = (char) (ca += cp[3]); cp[3] = (char) (ca += cp[3]);
} while ((int32) cc > 0); cc -= 4;
cp += 4;
}
} else { } else {
cc -= stride;
do { do {
REPEAT4(stride, cp[stride] = REPEAT4(stride, cp[stride] =
(char) (cp[stride] + *cp); cp++) (char) (cp[stride] + *cp); cp++)
cc -= stride; cc -= stride;
} while ((int32) cc > 0); } while (cc>0);
} }
} }
} }
static void static void
swabHorAcc16(TIFF* tif, tidata_t cp0, tsize_t cc) swabHorAcc16(TIFF* tif, uint8* cp0, tmsize_t cc)
{ {
tsize_t stride = PredictorState(tif)->stride; tmsize_t stride = PredictorState(tif)->stride;
uint16* wp = (uint16*) cp0; uint16* wp = (uint16*) cp0;
tsize_t wc = cc / 2; tmsize_t wc = cc / 2;
assert((cc%(2*stride))==0);
if (wc > stride) { if (wc > stride) {
TIFFSwabArrayOfShort(wp, wc); TIFFSwabArrayOfShort(wp, wc);
@ -292,32 +304,36 @@ swabHorAcc16(TIFF* tif, tidata_t cp0, tsize_t cc)
do { do {
REPEAT4(stride, wp[stride] += wp[0]; wp++) REPEAT4(stride, wp[stride] += wp[0]; wp++)
wc -= stride; wc -= stride;
} while ((int32) wc > 0); } while (wc > 0);
} }
} }
static void static void
horAcc16(TIFF* tif, tidata_t cp0, tsize_t cc) horAcc16(TIFF* tif, uint8* cp0, tmsize_t cc)
{ {
tsize_t stride = PredictorState(tif)->stride; tmsize_t stride = PredictorState(tif)->stride;
uint16* wp = (uint16*) cp0; uint16* wp = (uint16*) cp0;
tsize_t wc = cc / 2; tmsize_t wc = cc / 2;
assert((cc%(2*stride))==0);
if (wc > stride) { if (wc > stride) {
wc -= stride; wc -= stride;
do { do {
REPEAT4(stride, wp[stride] += wp[0]; wp++) REPEAT4(stride, wp[stride] += wp[0]; wp++)
wc -= stride; wc -= stride;
} while ((int32) wc > 0); } while (wc > 0);
} }
} }
static void static void
swabHorAcc32(TIFF* tif, tidata_t cp0, tsize_t cc) swabHorAcc32(TIFF* tif, uint8* cp0, tmsize_t cc)
{ {
tsize_t stride = PredictorState(tif)->stride; tmsize_t stride = PredictorState(tif)->stride;
uint32* wp = (uint32*) cp0; uint32* wp = (uint32*) cp0;
tsize_t wc = cc / 4; tmsize_t wc = cc / 4;
assert((cc%(4*stride))==0);
if (wc > stride) { if (wc > stride) {
TIFFSwabArrayOfLong(wp, wc); TIFFSwabArrayOfLong(wp, wc);
@ -325,23 +341,25 @@ swabHorAcc32(TIFF* tif, tidata_t cp0, tsize_t cc)
do { do {
REPEAT4(stride, wp[stride] += wp[0]; wp++) REPEAT4(stride, wp[stride] += wp[0]; wp++)
wc -= stride; wc -= stride;
} while ((int32) wc > 0); } while (wc > 0);
} }
} }
static void static void
horAcc32(TIFF* tif, tidata_t cp0, tsize_t cc) horAcc32(TIFF* tif, uint8* cp0, tmsize_t cc)
{ {
tsize_t stride = PredictorState(tif)->stride; tmsize_t stride = PredictorState(tif)->stride;
uint32* wp = (uint32*) cp0; uint32* wp = (uint32*) cp0;
tsize_t wc = cc / 4; tmsize_t wc = cc / 4;
assert((cc%(4*stride))==0);
if (wc > stride) { if (wc > stride) {
wc -= stride; wc -= stride;
do { do {
REPEAT4(stride, wp[stride] += wp[0]; wp++) REPEAT4(stride, wp[stride] += wp[0]; wp++)
wc -= stride; wc -= stride;
} while ((int32) wc > 0); } while (wc > 0);
} }
} }
@ -349,15 +367,17 @@ horAcc32(TIFF* tif, tidata_t cp0, tsize_t cc)
* Floating point predictor accumulation routine. * Floating point predictor accumulation routine.
*/ */
static void static void
fpAcc(TIFF* tif, tidata_t cp0, tsize_t cc) fpAcc(TIFF* tif, uint8* cp0, tmsize_t cc)
{ {
tsize_t stride = PredictorState(tif)->stride; tmsize_t stride = PredictorState(tif)->stride;
uint32 bps = tif->tif_dir.td_bitspersample / 8; uint32 bps = tif->tif_dir.td_bitspersample / 8;
tsize_t wc = cc / bps; tmsize_t wc = cc / bps;
tsize_t count = cc; tmsize_t count = cc;
uint8 *cp = (uint8 *) cp0; uint8 *cp = (uint8 *) cp0;
uint8 *tmp = (uint8 *)_TIFFmalloc(cc); uint8 *tmp = (uint8 *)_TIFFmalloc(cc);
assert((cc%(bps*stride))==0);
if (!tmp) if (!tmp)
return; return;
@ -371,12 +391,12 @@ fpAcc(TIFF* tif, tidata_t cp0, tsize_t cc)
for (count = 0; count < wc; count++) { for (count = 0; count < wc; count++) {
uint32 byte; uint32 byte;
for (byte = 0; byte < bps; byte++) { for (byte = 0; byte < bps; byte++) {
#if WORDS_BIGENDIAN #if WORDS_BIGENDIAN
cp[bps * count + byte] = tmp[byte * wc + count]; cp[bps * count + byte] = tmp[byte * wc + count];
#else #else
cp[bps * count + byte] = cp[bps * count + byte] =
tmp[(bps - byte - 1) * wc + count]; tmp[(bps - byte - 1) * wc + count];
#endif #endif
} }
} }
_TIFFfree(tmp); _TIFFfree(tmp);
@ -386,13 +406,13 @@ fpAcc(TIFF* tif, tidata_t cp0, tsize_t cc)
* Decode a scanline and apply the predictor routine. * Decode a scanline and apply the predictor routine.
*/ */
static int static int
PredictorDecodeRow(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s) PredictorDecodeRow(TIFF* tif, uint8* op0, tmsize_t occ0, uint16 s)
{ {
TIFFPredictorState *sp = PredictorState(tif); TIFFPredictorState *sp = PredictorState(tif);
assert(sp != NULL); assert(sp != NULL);
assert(sp->decoderow != NULL); assert(sp->decoderow != NULL);
assert(sp->decodepfunc != NULL); assert(sp->decodepfunc != NULL);
if ((*sp->decoderow)(tif, op0, occ0, s)) { if ((*sp->decoderow)(tif, op0, occ0, s)) {
(*sp->decodepfunc)(tif, op0, occ0); (*sp->decodepfunc)(tif, op0, occ0);
@ -409,7 +429,7 @@ PredictorDecodeRow(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
* strip/tile dimensions. * strip/tile dimensions.
*/ */
static int static int
PredictorDecodeTile(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s) PredictorDecodeTile(TIFF* tif, uint8* op0, tmsize_t occ0, uint16 s)
{ {
TIFFPredictorState *sp = PredictorState(tif); TIFFPredictorState *sp = PredictorState(tif);
@ -417,11 +437,12 @@ PredictorDecodeTile(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
assert(sp->decodetile != NULL); assert(sp->decodetile != NULL);
if ((*sp->decodetile)(tif, op0, occ0, s)) { if ((*sp->decodetile)(tif, op0, occ0, s)) {
tsize_t rowsize = sp->rowsize; tmsize_t rowsize = sp->rowsize;
assert(rowsize > 0); assert(rowsize > 0);
assert((occ0%rowsize)==0);
assert(sp->decodepfunc != NULL); assert(sp->decodepfunc != NULL);
while ((long)occ0 > 0) { while (occ0 > 0) {
(*sp->decodepfunc)(tif, op0, (tsize_t) rowsize); (*sp->decodepfunc)(tif, op0, rowsize);
occ0 -= rowsize; occ0 -= rowsize;
op0 += rowsize; op0 += rowsize;
} }
@ -431,12 +452,14 @@ PredictorDecodeTile(TIFF* tif, tidata_t op0, tsize_t occ0, tsample_t s)
} }
static void static void
horDiff8(TIFF* tif, tidata_t cp0, tsize_t cc) horDiff8(TIFF* tif, uint8* cp0, tmsize_t cc)
{ {
TIFFPredictorState* sp = PredictorState(tif); TIFFPredictorState* sp = PredictorState(tif);
tsize_t stride = sp->stride; tmsize_t stride = sp->stride;
char* cp = (char*) cp0; char* cp = (char*) cp0;
assert((cc%stride)==0);
if (cc > stride) { if (cc > stride) {
cc -= stride; cc -= stride;
/* /*
@ -452,7 +475,7 @@ horDiff8(TIFF* tif, tidata_t cp0, tsize_t cc)
g1 = cp[4]; cp[4] = g1-g2; g2 = g1; g1 = cp[4]; cp[4] = g1-g2; g2 = g1;
b1 = cp[5]; cp[5] = b1-b2; b2 = b1; b1 = cp[5]; cp[5] = b1-b2; b2 = b1;
cp += 3; cp += 3;
} while ((int32)(cc -= 3) > 0); } while ((cc -= 3) > 0);
} else if (stride == 4) { } else if (stride == 4) {
int r1, g1, b1, a1; int r1, g1, b1, a1;
int r2 = cp[0]; int r2 = cp[0];
@ -465,23 +488,25 @@ horDiff8(TIFF* tif, tidata_t cp0, tsize_t cc)
b1 = cp[6]; cp[6] = b1-b2; b2 = b1; b1 = cp[6]; cp[6] = b1-b2; b2 = b1;
a1 = cp[7]; cp[7] = a1-a2; a2 = a1; a1 = cp[7]; cp[7] = a1-a2; a2 = a1;
cp += 4; cp += 4;
} while ((int32)(cc -= 4) > 0); } while ((cc -= 4) > 0);
} else { } else {
cp += cc - 1; cp += cc - 1;
do { do {
REPEAT4(stride, cp[stride] -= cp[0]; cp--) REPEAT4(stride, cp[stride] -= cp[0]; cp--)
} while ((int32)(cc -= stride) > 0); } while ((cc -= stride) > 0);
} }
} }
} }
static void static void
horDiff16(TIFF* tif, tidata_t cp0, tsize_t cc) horDiff16(TIFF* tif, uint8* cp0, tmsize_t cc)
{ {
TIFFPredictorState* sp = PredictorState(tif); TIFFPredictorState* sp = PredictorState(tif);
tsize_t stride = sp->stride; tmsize_t stride = sp->stride;
int16 *wp = (int16*) cp0; int16 *wp = (int16*) cp0;
tsize_t wc = cc/2; tmsize_t wc = cc/2;
assert((cc%(2*stride))==0);
if (wc > stride) { if (wc > stride) {
wc -= stride; wc -= stride;
@ -489,17 +514,19 @@ horDiff16(TIFF* tif, tidata_t cp0, tsize_t cc)
do { do {
REPEAT4(stride, wp[stride] -= wp[0]; wp--) REPEAT4(stride, wp[stride] -= wp[0]; wp--)
wc -= stride; wc -= stride;
} while ((int32) wc > 0); } while (wc > 0);
} }
} }
static void static void
horDiff32(TIFF* tif, tidata_t cp0, tsize_t cc) horDiff32(TIFF* tif, uint8* cp0, tmsize_t cc)
{ {
TIFFPredictorState* sp = PredictorState(tif); TIFFPredictorState* sp = PredictorState(tif);
tsize_t stride = sp->stride; tmsize_t stride = sp->stride;
int32 *wp = (int32*) cp0; int32 *wp = (int32*) cp0;
tsize_t wc = cc/4; tmsize_t wc = cc/4;
assert((cc%(4*stride))==0);
if (wc > stride) { if (wc > stride) {
wc -= stride; wc -= stride;
@ -507,7 +534,7 @@ horDiff32(TIFF* tif, tidata_t cp0, tsize_t cc)
do { do {
REPEAT4(stride, wp[stride] -= wp[0]; wp--) REPEAT4(stride, wp[stride] -= wp[0]; wp--)
wc -= stride; wc -= stride;
} while ((int32) wc > 0); } while (wc > 0);
} }
} }
@ -515,15 +542,17 @@ horDiff32(TIFF* tif, tidata_t cp0, tsize_t cc)
* Floating point predictor differencing routine. * Floating point predictor differencing routine.
*/ */
static void static void
fpDiff(TIFF* tif, tidata_t cp0, tsize_t cc) fpDiff(TIFF* tif, uint8* cp0, tmsize_t cc)
{ {
tsize_t stride = PredictorState(tif)->stride; tmsize_t stride = PredictorState(tif)->stride;
uint32 bps = tif->tif_dir.td_bitspersample / 8; uint32 bps = tif->tif_dir.td_bitspersample / 8;
tsize_t wc = cc / bps; tmsize_t wc = cc / bps;
tsize_t count; tmsize_t count;
uint8 *cp = (uint8 *) cp0; uint8 *cp = (uint8 *) cp0;
uint8 *tmp = (uint8 *)_TIFFmalloc(cc); uint8 *tmp = (uint8 *)_TIFFmalloc(cc);
assert((cc%(bps*stride))==0);
if (!tmp) if (!tmp)
return; return;
@ -531,12 +560,12 @@ fpDiff(TIFF* tif, tidata_t cp0, tsize_t cc)
for (count = 0; count < wc; count++) { for (count = 0; count < wc; count++) {
uint32 byte; uint32 byte;
for (byte = 0; byte < bps; byte++) { for (byte = 0; byte < bps; byte++) {
#if WORDS_BIGENDIAN #if WORDS_BIGENDIAN
cp[byte * wc + count] = tmp[bps * count + byte]; cp[byte * wc + count] = tmp[bps * count + byte];
#else #else
cp[(bps - byte - 1) * wc + count] = cp[(bps - byte - 1) * wc + count] =
tmp[bps * count + byte]; tmp[bps * count + byte];
#endif #endif
} }
} }
_TIFFfree(tmp); _TIFFfree(tmp);
@ -548,7 +577,7 @@ fpDiff(TIFF* tif, tidata_t cp0, tsize_t cc)
} }
static int static int
PredictorEncodeRow(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) PredictorEncodeRow(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
TIFFPredictorState *sp = PredictorState(tif); TIFFPredictorState *sp = PredictorState(tif);
@ -562,12 +591,12 @@ PredictorEncodeRow(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
} }
static int static int
PredictorEncodeTile(TIFF* tif, tidata_t bp0, tsize_t cc0, tsample_t s) PredictorEncodeTile(TIFF* tif, uint8* bp0, tmsize_t cc0, uint16 s)
{ {
static const char module[] = "PredictorEncodeTile"; static const char module[] = "PredictorEncodeTile";
TIFFPredictorState *sp = PredictorState(tif); TIFFPredictorState *sp = PredictorState(tif);
uint8 *working_copy; uint8 *working_copy;
tsize_t cc = cc0, rowsize; tmsize_t cc = cc0, rowsize;
unsigned char* bp; unsigned char* bp;
int result_code; int result_code;
@ -583,7 +612,7 @@ PredictorEncodeTile(TIFF* tif, tidata_t bp0, tsize_t cc0, tsample_t s)
if( working_copy == NULL ) if( working_copy == NULL )
{ {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"Out of memory allocating %d byte temp buffer.", "Out of memory allocating " TIFF_SSIZE_FORMAT " byte temp buffer.",
cc0 ); cc0 );
return 0; return 0;
} }
@ -607,13 +636,12 @@ PredictorEncodeTile(TIFF* tif, tidata_t bp0, tsize_t cc0, tsample_t s)
#define FIELD_PREDICTOR (FIELD_CODEC+0) /* XXX */ #define FIELD_PREDICTOR (FIELD_CODEC+0) /* XXX */
static const TIFFFieldInfo predictFieldInfo[] = { static const TIFFField predictFields[] = {
{ TIFFTAG_PREDICTOR, 1, 1, TIFF_SHORT, FIELD_PREDICTOR, { TIFFTAG_PREDICTOR, 1, 1, TIFF_SHORT, 0, TIFF_SETGET_UINT16, TIFF_SETGET_UINT16, FIELD_PREDICTOR, FALSE, FALSE, "Predictor", NULL },
FALSE, FALSE, "Predictor" },
}; };
static int static int
PredictorVSetField(TIFF* tif, ttag_t tag, va_list ap) PredictorVSetField(TIFF* tif, uint32 tag, va_list ap)
{ {
TIFFPredictorState *sp = PredictorState(tif); TIFFPredictorState *sp = PredictorState(tif);
@ -622,7 +650,7 @@ PredictorVSetField(TIFF* tif, ttag_t tag, va_list ap)
switch (tag) { switch (tag) {
case TIFFTAG_PREDICTOR: case TIFFTAG_PREDICTOR:
sp->predictor = (uint16) va_arg(ap, int); sp->predictor = (uint16) va_arg(ap, uint16_vap);
TIFFSetFieldBit(tif, FIELD_PREDICTOR); TIFFSetFieldBit(tif, FIELD_PREDICTOR);
break; break;
default: default:
@ -633,7 +661,7 @@ PredictorVSetField(TIFF* tif, ttag_t tag, va_list ap)
} }
static int static int
PredictorVGetField(TIFF* tif, ttag_t tag, va_list ap) PredictorVGetField(TIFF* tif, uint32 tag, va_list ap)
{ {
TIFFPredictorState *sp = PredictorState(tif); TIFFPredictorState *sp = PredictorState(tif);
@ -659,9 +687,9 @@ PredictorPrintDir(TIFF* tif, FILE* fd, long flags)
if (TIFFFieldSet(tif,FIELD_PREDICTOR)) { if (TIFFFieldSet(tif,FIELD_PREDICTOR)) {
fprintf(fd, " Predictor: "); fprintf(fd, " Predictor: ");
switch (sp->predictor) { switch (sp->predictor) {
case 1: fprintf(fd, "none "); break; case 1: fprintf(fd, "none "); break;
case 2: fprintf(fd, "horizontal differencing "); break; case 2: fprintf(fd, "horizontal differencing "); break;
case 3: fprintf(fd, "floating point predictor "); break; case 3: fprintf(fd, "floating point predictor "); break;
} }
fprintf(fd, "%u (0x%x)\n", sp->predictor, sp->predictor); fprintf(fd, "%u (0x%x)\n", sp->predictor, sp->predictor);
} }
@ -679,10 +707,10 @@ TIFFPredictorInit(TIFF* tif)
/* /*
* Merge codec-specific tag information. * Merge codec-specific tag information.
*/ */
if (!_TIFFMergeFieldInfo(tif, predictFieldInfo, if (!_TIFFMergeFields(tif, predictFields,
TIFFArrayCount(predictFieldInfo))) { TIFFArrayCount(predictFields))) {
TIFFErrorExt(tif->tif_clientdata, "TIFFPredictorInit", TIFFErrorExt(tif->tif_clientdata, "TIFFPredictorInit",
"Merging Predictor codec-specific tags failed"); "Merging Predictor codec-specific tags failed");
return 0; return 0;
} }
@ -694,7 +722,7 @@ TIFFPredictorInit(TIFF* tif)
PredictorVGetField;/* hook for predictor tag */ PredictorVGetField;/* hook for predictor tag */
sp->vsetparent = tif->tif_tagmethods.vsetfield; sp->vsetparent = tif->tif_tagmethods.vsetfield;
tif->tif_tagmethods.vsetfield = tif->tif_tagmethods.vsetfield =
PredictorVSetField;/* hook for predictor tag */ PredictorVSetField;/* hook for predictor tag */
sp->printdir = tif->tif_tagmethods.printdir; sp->printdir = tif->tif_tagmethods.printdir;
tif->tif_tagmethods.printdir = tif->tif_tagmethods.printdir =
PredictorPrintDir; /* hook for predictor tag */ PredictorPrintDir; /* hook for predictor tag */

View File

@ -1,26 +1,26 @@
/* $Id: tif_predict.h,v 1.3.2.2 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_predict.h,v 1.8 2010-03-10 18:56:49 bfriesen Exp $ */
/* /*
* Copyright (c) 1995-1997 Sam Leffler * Copyright (c) 1995-1997 Sam Leffler
* Copyright (c) 1995-1997 Silicon Graphics, Inc. * Copyright (c) 1995-1997 Silicon Graphics, Inc.
* *
* Permission to use, copy, modify, distribute, and sell this software and * Permission to use, copy, modify, distribute, and sell this software and
* its documentation for any purpose is hereby granted without fee, provided * its documentation for any purpose is hereby granted without fee, provided
* that (i) the above copyright notices and this permission notice appear in * that (i) the above copyright notices and this permission notice appear in
* all copies of the software and related documentation, and (ii) the names of * all copies of the software and related documentation, and (ii) the names of
* Sam Leffler and Silicon Graphics may not be used in any advertising or * Sam Leffler and Silicon Graphics may not be used in any advertising or
* publicity relating to the software without the specific, prior written * publicity relating to the software without the specific, prior written
* permission of Sam Leffler and Silicon Graphics. * permission of Sam Leffler and Silicon Graphics.
* *
* THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND, * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
* EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
* WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
* *
* IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
* ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
* OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
* WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
* LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
* OF THIS SOFTWARE. * OF THIS SOFTWARE.
*/ */
@ -36,32 +36,32 @@
* the predictor code can cast tif_data to find its state. * the predictor code can cast tif_data to find its state.
*/ */
typedef struct { typedef struct {
int predictor; /* predictor tag value */ int predictor; /* predictor tag value */
int stride; /* sample stride over data */ tmsize_t stride; /* sample stride over data */
tsize_t rowsize; /* tile/strip row size */ tmsize_t rowsize; /* tile/strip row size */
TIFFCodeMethod encoderow; /* parent codec encode/decode row */ TIFFCodeMethod encoderow; /* parent codec encode/decode row */
TIFFCodeMethod encodestrip; /* parent codec encode/decode strip */ TIFFCodeMethod encodestrip; /* parent codec encode/decode strip */
TIFFCodeMethod encodetile; /* parent codec encode/decode tile */ TIFFCodeMethod encodetile; /* parent codec encode/decode tile */
TIFFPostMethod encodepfunc; /* horizontal differencer */ TIFFPostMethod encodepfunc; /* horizontal differencer */
TIFFCodeMethod decoderow; /* parent codec encode/decode row */
TIFFCodeMethod decodestrip; /* parent codec encode/decode strip */
TIFFCodeMethod decodetile; /* parent codec encode/decode tile */
TIFFPostMethod decodepfunc; /* horizontal accumulator */
TIFFVGetMethod vgetparent; /* super-class method */ TIFFCodeMethod decoderow; /* parent codec encode/decode row */
TIFFVSetMethod vsetparent; /* super-class method */ TIFFCodeMethod decodestrip; /* parent codec encode/decode strip */
TIFFPrintMethod printdir; /* super-class method */ TIFFCodeMethod decodetile; /* parent codec encode/decode tile */
TIFFBoolMethod setupdecode; /* super-class method */ TIFFPostMethod decodepfunc; /* horizontal accumulator */
TIFFBoolMethod setupencode; /* super-class method */
TIFFVGetMethod vgetparent; /* super-class method */
TIFFVSetMethod vsetparent; /* super-class method */
TIFFPrintMethod printdir; /* super-class method */
TIFFBoolMethod setupdecode; /* super-class method */
TIFFBoolMethod setupencode; /* super-class method */
} TIFFPredictorState; } TIFFPredictorState;
#if defined(__cplusplus) #if defined(__cplusplus)
extern "C" { extern "C" {
#endif #endif
extern int TIFFPredictorInit(TIFF*); extern int TIFFPredictorInit(TIFF*);
extern int TIFFPredictorCleanup(TIFF*); extern int TIFFPredictorCleanup(TIFF*);
#if defined(__cplusplus) #if defined(__cplusplus)
} }
#endif #endif

View File

@ -1,4 +1,4 @@
/* $Id: tif_print.c,v 1.36.2.4 2010-06-08 18:50:42 bfriesen Exp $ */ /* $Id: tif_print.c,v 1.54 2011-04-02 20:54:09 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -31,7 +31,7 @@
*/ */
#include "tiffiop.h" #include "tiffiop.h"
#include <stdio.h> #include <stdio.h>
#include <string.h>
#include <ctype.h> #include <ctype.h>
static const char *photoNames[] = { static const char *photoNames[] = {
@ -61,7 +61,7 @@ static const char *orientNames[] = {
#define NORIENTNAMES (sizeof (orientNames) / sizeof (orientNames[0])) #define NORIENTNAMES (sizeof (orientNames) / sizeof (orientNames[0]))
static void static void
_TIFFPrintField(FILE* fd, const TIFFFieldInfo *fip, _TIFFPrintField(FILE* fd, const TIFFField *fip,
uint32 value_count, void *raw_data) uint32 value_count, void *raw_data)
{ {
uint32 j; uint32 j;
@ -73,7 +73,7 @@ _TIFFPrintField(FILE* fd, const TIFFFieldInfo *fip,
fprintf(fd, "%u", ((uint8 *) raw_data)[j]); fprintf(fd, "%u", ((uint8 *) raw_data)[j]);
else if(fip->field_type == TIFF_UNDEFINED) else if(fip->field_type == TIFF_UNDEFINED)
fprintf(fd, "0x%x", fprintf(fd, "0x%x",
(unsigned int) ((unsigned char *) raw_data)[j]); (unsigned int) ((unsigned char *) raw_data)[j]);
else if(fip->field_type == TIFF_SBYTE) else if(fip->field_type == TIFF_SBYTE)
fprintf(fd, "%d", ((int8 *) raw_data)[j]); fprintf(fd, "%d", ((int8 *) raw_data)[j]);
else if(fip->field_type == TIFF_SHORT) else if(fip->field_type == TIFF_SHORT)
@ -82,23 +82,46 @@ _TIFFPrintField(FILE* fd, const TIFFFieldInfo *fip,
fprintf(fd, "%d", ((int16 *) raw_data)[j]); fprintf(fd, "%d", ((int16 *) raw_data)[j]);
else if(fip->field_type == TIFF_LONG) else if(fip->field_type == TIFF_LONG)
fprintf(fd, "%lu", fprintf(fd, "%lu",
(unsigned long)((uint32 *) raw_data)[j]); (unsigned long)((uint32 *) raw_data)[j]);
else if(fip->field_type == TIFF_SLONG) else if(fip->field_type == TIFF_SLONG)
fprintf(fd, "%ld", (long)((int32 *) raw_data)[j]); fprintf(fd, "%ld", (long)((int32 *) raw_data)[j]);
else if(fip->field_type == TIFF_IFD)
fprintf(fd, "0x%lx",
(unsigned long)((uint32 *) raw_data)[j]);
else if(fip->field_type == TIFF_RATIONAL else if(fip->field_type == TIFF_RATIONAL
|| fip->field_type == TIFF_SRATIONAL || fip->field_type == TIFF_SRATIONAL
|| fip->field_type == TIFF_FLOAT) || fip->field_type == TIFF_FLOAT)
fprintf(fd, "%f", ((float *) raw_data)[j]); fprintf(fd, "%f", ((float *) raw_data)[j]);
else if(fip->field_type == TIFF_IFD) else if(fip->field_type == TIFF_LONG8)
fprintf(fd, "0x%ulx", ((uint32 *) raw_data)[j]); #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
fprintf(fd, "%I64u",
(unsigned __int64)((uint64 *) raw_data)[j]);
#else
fprintf(fd, "%llu",
(unsigned long long)((uint64 *) raw_data)[j]);
#endif
else if(fip->field_type == TIFF_SLONG8)
#if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
fprintf(fd, "%I64d", (__int64)((int64 *) raw_data)[j]);
#else
fprintf(fd, "%lld", (long long)((int64 *) raw_data)[j]);
#endif
else if(fip->field_type == TIFF_IFD8)
#if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
fprintf(fd, "0x%I64x",
(unsigned __int64)((uint64 *) raw_data)[j]);
#else
fprintf(fd, "0x%llx",
(unsigned long long)((uint64 *) raw_data)[j]);
#endif
else if(fip->field_type == TIFF_FLOAT)
fprintf(fd, "%f", ((float *)raw_data)[j]);
else if(fip->field_type == TIFF_DOUBLE)
fprintf(fd, "%f", ((double *) raw_data)[j]);
else if(fip->field_type == TIFF_ASCII) { else if(fip->field_type == TIFF_ASCII) {
fprintf(fd, "%s", (char *) raw_data); fprintf(fd, "%s", (char *) raw_data);
break; break;
} }
else if(fip->field_type == TIFF_DOUBLE)
fprintf(fd, "%f", ((double *) raw_data)[j]);
else if(fip->field_type == TIFF_FLOAT)
fprintf(fd, "%f", ((float *)raw_data)[j]);
else { else {
fprintf(fd, "<unsupported data type in TIFFPrint>"); fprintf(fd, "<unsupported data type in TIFFPrint>");
break; break;
@ -112,11 +135,11 @@ _TIFFPrintField(FILE* fd, const TIFFFieldInfo *fip,
} }
static int static int
_TIFFPrettyPrintField(TIFF* tif, FILE* fd, ttag_t tag, _TIFFPrettyPrintField(TIFF* tif, FILE* fd, uint32 tag,
uint32 value_count, void *raw_data) uint32 value_count, void *raw_data)
{ {
//TIFFDirectory *td = &tif->tif_dir; (void) tif;
switch (tag) switch (tag)
{ {
case TIFFTAG_INKSET: case TIFFTAG_INKSET:
@ -127,33 +150,23 @@ _TIFFPrettyPrintField(TIFF* tif, FILE* fd, ttag_t tag,
break; break;
default: default:
fprintf(fd, "%u (0x%x)\n", fprintf(fd, "%u (0x%x)\n",
*((uint16*)raw_data), *((uint16*)raw_data),
*((uint16*)raw_data)); *((uint16*)raw_data));
break; break;
} }
return 1; return 1;
case TIFFTAG_DOTRANGE: case TIFFTAG_DOTRANGE:
fprintf(fd, " Dot Range: %u-%u\n", fprintf(fd, " Dot Range: %u-%u\n",
((uint16*)raw_data)[0], ((uint16*)raw_data)[1]); ((uint16*)raw_data)[0], ((uint16*)raw_data)[1]);
return 1; return 1;
case TIFFTAG_WHITEPOINT: case TIFFTAG_WHITEPOINT:
fprintf(fd, " White Point: %g-%g\n", fprintf(fd, " White Point: %g-%g\n",
((float *)raw_data)[0], ((float *)raw_data)[1]); return 1; ((float *)raw_data)[0], ((float *)raw_data)[1]);
case TIFFTAG_REFERENCEBLACKWHITE:
{
uint16 i;
fprintf(fd, " Reference Black/White:\n");
for (i = 0; i < 3; i++)
fprintf(fd, " %2d: %5g %5g\n", i,
((float *)raw_data)[2*i+0],
((float *)raw_data)[2*i+1]);
return 1; return 1;
}
case TIFFTAG_XMLPACKET: case TIFFTAG_XMLPACKET:
{ {
uint32 i; uint32 i;
fprintf(fd, " XMLPacket (XMP Metadata):\n" ); fprintf(fd, " XMLPacket (XMP Metadata):\n" );
for(i = 0; i < value_count; i++) for(i = 0; i < value_count; i++)
fputc(((char *)raw_data)[i], fd); fputc(((char *)raw_data)[i], fd);
@ -166,23 +179,23 @@ _TIFFPrettyPrintField(TIFF* tif, FILE* fd, ttag_t tag,
* defined as array of LONG values. * defined as array of LONG values.
*/ */
fprintf(fd, fprintf(fd,
" RichTIFFIPTC Data: <present>, %lu bytes\n", " RichTIFFIPTC Data: <present>, %lu bytes\n",
(unsigned long) value_count * 4); (unsigned long) value_count * 4);
return 1; return 1;
case TIFFTAG_PHOTOSHOP: case TIFFTAG_PHOTOSHOP:
fprintf(fd, " Photoshop Data: <present>, %lu bytes\n", fprintf(fd, " Photoshop Data: <present>, %lu bytes\n",
(unsigned long) value_count); (unsigned long) value_count);
return 1; return 1;
case TIFFTAG_ICCPROFILE: case TIFFTAG_ICCPROFILE:
fprintf(fd, " ICC Profile: <present>, %lu bytes\n", fprintf(fd, " ICC Profile: <present>, %lu bytes\n",
(unsigned long) value_count); (unsigned long) value_count);
return 1; return 1;
case TIFFTAG_STONITS: case TIFFTAG_STONITS:
fprintf(fd, fprintf(fd,
" Sample to Nits conversion factor: %.4e\n", " Sample to Nits conversion factor: %.4e\n",
*((double*)raw_data)); *((double*)raw_data));
return 1; return 1;
} }
return 0; return 0;
} }
@ -199,8 +212,15 @@ TIFFPrintDirectory(TIFF* tif, FILE* fd, long flags)
uint16 i; uint16 i;
long l, n; long l, n;
fprintf(fd, "TIFF Directory at offset 0x%lx (%lu)\n", #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
(unsigned long)tif->tif_diroff, (unsigned long)tif->tif_diroff); fprintf(fd, "TIFF Directory at offset 0x%I64x (%I64u)\n",
(unsigned __int64) tif->tif_diroff,
(unsigned __int64) tif->tif_diroff);
#else
fprintf(fd, "TIFF Directory at offset 0x%llx (%llu)\n",
(unsigned long long) tif->tif_diroff,
(unsigned long long) tif->tif_diroff);
#endif
if (TIFFFieldSet(tif,FIELD_SUBFILETYPE)) { if (TIFFFieldSet(tif,FIELD_SUBFILETYPE)) {
fprintf(fd, " Subfile Type:"); fprintf(fd, " Subfile Type:");
sep = " "; sep = " ";
@ -386,18 +406,9 @@ TIFFPrintDirectory(TIFF* tif, FILE* fd, long flags)
} }
if (TIFFFieldSet(tif,FIELD_YCBCRSUBSAMPLING)) if (TIFFFieldSet(tif,FIELD_YCBCRSUBSAMPLING))
{ {
/*
* For hacky reasons (see tif_jpeg.c - JPEGFixupTestSubsampling),
* we need to fetch this rather than trust what is in our
* structures.
*/
uint16 subsampling[2];
TIFFGetField( tif, TIFFTAG_YCBCRSUBSAMPLING,
subsampling + 0, subsampling + 1 );
fprintf(fd, " YCbCr Subsampling: %u, %u\n", fprintf(fd, " YCbCr Subsampling: %u, %u\n",
subsampling[0], subsampling[1] ); td->td_ycbcrsubsampling[0], td->td_ycbcrsubsampling[1] );
} }
if (TIFFFieldSet(tif,FIELD_YCBCRPOSITIONING)) { if (TIFFFieldSet(tif,FIELD_YCBCRPOSITIONING)) {
fprintf(fd, " YCbCr Positioning: "); fprintf(fd, " YCbCr Positioning: ");
switch (td->td_ycbcrpositioning) { switch (td->td_ycbcrpositioning) {
@ -437,12 +448,18 @@ TIFFPrintDirectory(TIFF* tif, FILE* fd, long flags)
fprintf(fd, " Min Sample Value: %u\n", td->td_minsamplevalue); fprintf(fd, " Min Sample Value: %u\n", td->td_minsamplevalue);
if (TIFFFieldSet(tif,FIELD_MAXSAMPLEVALUE)) if (TIFFFieldSet(tif,FIELD_MAXSAMPLEVALUE))
fprintf(fd, " Max Sample Value: %u\n", td->td_maxsamplevalue); fprintf(fd, " Max Sample Value: %u\n", td->td_maxsamplevalue);
if (TIFFFieldSet(tif,FIELD_SMINSAMPLEVALUE)) if (TIFFFieldSet(tif,FIELD_SMINSAMPLEVALUE)) {
fprintf(fd, " SMin Sample Value: %g\n", fprintf(fd, " SMin Sample Value:");
td->td_sminsamplevalue); for (i = 0; i < td->td_samplesperpixel; ++i)
if (TIFFFieldSet(tif,FIELD_SMAXSAMPLEVALUE)) fprintf(fd, " %g", td->td_sminsamplevalue[i]);
fprintf(fd, " SMax Sample Value: %g\n", fprintf(fd, "\n");
td->td_smaxsamplevalue); }
if (TIFFFieldSet(tif,FIELD_SMAXSAMPLEVALUE)) {
fprintf(fd, " SMax Sample Value:");
for (i = 0; i < td->td_samplesperpixel; ++i)
fprintf(fd, " %g", td->td_smaxsamplevalue[i]);
fprintf(fd, "\n");
}
if (TIFFFieldSet(tif,FIELD_PLANARCONFIG)) { if (TIFFFieldSet(tif,FIELD_PLANARCONFIG)) {
fprintf(fd, " Planar Configuration: "); fprintf(fd, " Planar Configuration: ");
switch (td->td_planarconfig) { switch (td->td_planarconfig) {
@ -475,6 +492,13 @@ TIFFPrintDirectory(TIFF* tif, FILE* fd, long flags)
} else } else
fprintf(fd, "(present)\n"); fprintf(fd, "(present)\n");
} }
if (TIFFFieldSet(tif,FIELD_REFBLACKWHITE)) {
fprintf(fd, " Reference Black/White:\n");
for (i = 0; i < 3; i++)
fprintf(fd, " %2d: %5g %5g\n", i,
td->td_refblackwhite[2*i+0],
td->td_refblackwhite[2*i+1]);
}
if (TIFFFieldSet(tif,FIELD_TRANSFERFUNCTION)) { if (TIFFFieldSet(tif,FIELD_TRANSFERFUNCTION)) {
fprintf(fd, " Transfer Function: "); fprintf(fd, " Transfer Function: ");
if (flags & TIFFPRINT_CURVES) { if (flags & TIFFPRINT_CURVES) {
@ -494,117 +518,130 @@ TIFFPrintDirectory(TIFF* tif, FILE* fd, long flags)
if (TIFFFieldSet(tif, FIELD_SUBIFD) && (td->td_subifd)) { if (TIFFFieldSet(tif, FIELD_SUBIFD) && (td->td_subifd)) {
fprintf(fd, " SubIFD Offsets:"); fprintf(fd, " SubIFD Offsets:");
for (i = 0; i < td->td_nsubifd; i++) for (i = 0; i < td->td_nsubifd; i++)
fprintf(fd, " %5lu", (long) td->td_subifd[i]); #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
fprintf(fd, " %5I64u",
(unsigned __int64) td->td_subifd[i]);
#else
fprintf(fd, " %5llu",
(unsigned long long) td->td_subifd[i]);
#endif
fputc('\n', fd); fputc('\n', fd);
} }
/* /*
** Custom tag support. ** Custom tag support.
*/ */
{ {
int i; int i;
short count; short count;
count = (short) TIFFGetTagListCount(tif); count = (short) TIFFGetTagListCount(tif);
for(i = 0; i < count; i++) { for(i = 0; i < count; i++) {
ttag_t tag = TIFFGetTagListEntry(tif, i); uint32 tag = TIFFGetTagListEntry(tif, i);
const TIFFFieldInfo *fip; const TIFFField *fip;
uint32 value_count; uint32 value_count;
int mem_alloc = 0; int mem_alloc = 0;
void *raw_data; void *raw_data;
fip = TIFFFieldWithTag(tif, tag); fip = TIFFFieldWithTag(tif, tag);
if(fip == NULL) if(fip == NULL)
continue;
if(fip->field_passcount) {
if(TIFFGetField(tif, tag, &value_count, &raw_data) != 1)
continue; continue;
} else {
if (fip->field_readcount == TIFF_VARIABLE if(fip->field_passcount) {
|| fip->field_readcount == TIFF_VARIABLE2) if(TIFFGetField(tif, tag, &value_count, &raw_data) != 1)
value_count = 1;
else if (fip->field_readcount == TIFF_SPP)
value_count = td->td_samplesperpixel;
else
value_count = fip->field_readcount;
if ((fip->field_type == TIFF_ASCII
|| fip->field_readcount == TIFF_VARIABLE
|| fip->field_readcount == TIFF_VARIABLE2
|| fip->field_readcount == TIFF_SPP
|| value_count > 1)
&& fip->field_tag != TIFFTAG_PAGENUMBER
&& fip->field_tag != TIFFTAG_HALFTONEHINTS
&& fip->field_tag != TIFFTAG_YCBCRSUBSAMPLING
&& fip->field_tag != TIFFTAG_DOTRANGE) {
if(TIFFGetField(tif, tag, &raw_data) != 1)
continue; continue;
} else if (fip->field_tag != TIFFTAG_PAGENUMBER
&& fip->field_tag != TIFFTAG_HALFTONEHINTS
&& fip->field_tag != TIFFTAG_YCBCRSUBSAMPLING
&& fip->field_tag != TIFFTAG_DOTRANGE) {
raw_data = _TIFFmalloc(
_TIFFDataSize(fip->field_type)
* value_count);
mem_alloc = 1;
if(TIFFGetField(tif, tag, raw_data) != 1) {
_TIFFfree(raw_data);
continue;
}
} else { } else {
/* if (fip->field_readcount == TIFF_VARIABLE
* XXX: Should be fixed and removed, see the || fip->field_readcount == TIFF_VARIABLE2)
* notes related to TIFFTAG_PAGENUMBER, value_count = 1;
* TIFFTAG_HALFTONEHINTS, else if (fip->field_readcount == TIFF_SPP)
* TIFFTAG_YCBCRSUBSAMPLING and value_count = td->td_samplesperpixel;
* TIFFTAG_DOTRANGE tags in tif_dir.c. */ else
char *tmp; value_count = fip->field_readcount;
raw_data = _TIFFmalloc( if ((fip->field_type == TIFF_ASCII
_TIFFDataSize(fip->field_type) || fip->field_readcount == TIFF_VARIABLE
* value_count); || fip->field_readcount == TIFF_VARIABLE2
tmp = raw_data; || fip->field_readcount == TIFF_SPP
mem_alloc = 1; || value_count > 1)
if(TIFFGetField(tif, tag, tmp, && fip->field_tag != TIFFTAG_PAGENUMBER
tmp + _TIFFDataSize(fip->field_type)) != 1) { && fip->field_tag != TIFFTAG_HALFTONEHINTS
_TIFFfree(raw_data); && fip->field_tag != TIFFTAG_YCBCRSUBSAMPLING
continue; && fip->field_tag != TIFFTAG_DOTRANGE) {
if(TIFFGetField(tif, tag, &raw_data) != 1)
continue;
} else if (fip->field_tag != TIFFTAG_PAGENUMBER
&& fip->field_tag != TIFFTAG_HALFTONEHINTS
&& fip->field_tag != TIFFTAG_YCBCRSUBSAMPLING
&& fip->field_tag != TIFFTAG_DOTRANGE) {
raw_data = _TIFFmalloc(
_TIFFDataSize(fip->field_type)
* value_count);
mem_alloc = 1;
if(TIFFGetField(tif, tag, raw_data) != 1) {
_TIFFfree(raw_data);
continue;
}
} else {
/*
* XXX: Should be fixed and removed,
* see the notes related to
* TIFFTAG_PAGENUMBER,
* TIFFTAG_HALFTONEHINTS,
* TIFFTAG_YCBCRSUBSAMPLING and
* TIFFTAG_DOTRANGE tags in tif_dir.c.
*/
char *tmp;
raw_data = _TIFFmalloc(
_TIFFDataSize(fip->field_type)
* value_count);
tmp = raw_data;
mem_alloc = 1;
if(TIFFGetField(tif, tag, tmp,
tmp + _TIFFDataSize(fip->field_type)) != 1) {
_TIFFfree(raw_data);
continue;
}
} }
} }
}
/* /*
* Catch the tags which needs to be specially handled and * Catch the tags which needs to be specially handled
* pretty print them. If tag not handled in * and pretty print them. If tag not handled in
* _TIFFPrettyPrintField() fall down and print it as any other * _TIFFPrettyPrintField() fall down and print it as
* tag. * any other tag.
*/ */
if (_TIFFPrettyPrintField(tif, fd, tag, value_count, raw_data)) { if (!_TIFFPrettyPrintField(tif, fd, tag, value_count, raw_data))
_TIFFPrintField(fd, fip, value_count, raw_data);
if(mem_alloc) if(mem_alloc)
_TIFFfree(raw_data); _TIFFfree(raw_data);
continue;
} }
else }
_TIFFPrintField(fd, fip, value_count, raw_data);
if(mem_alloc)
_TIFFfree(raw_data);
}
}
if (tif->tif_tagmethods.printdir) if (tif->tif_tagmethods.printdir)
(*tif->tif_tagmethods.printdir)(tif, fd, flags); (*tif->tif_tagmethods.printdir)(tif, fd, flags);
_TIFFFillStriles( tif );
if ((flags & TIFFPRINT_STRIPS) && if ((flags & TIFFPRINT_STRIPS) &&
TIFFFieldSet(tif,FIELD_STRIPOFFSETS)) { TIFFFieldSet(tif,FIELD_STRIPOFFSETS)) {
tstrip_t s; uint32 s;
fprintf(fd, " %lu %s:\n", fprintf(fd, " %lu %s:\n",
(long) td->td_nstrips, (long) td->td_nstrips,
isTiled(tif) ? "Tiles" : "Strips"); isTiled(tif) ? "Tiles" : "Strips");
for (s = 0; s < td->td_nstrips; s++) for (s = 0; s < td->td_nstrips; s++)
fprintf(fd, " %3lu: [%8lu, %8lu]\n", #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
fprintf(fd, " %3lu: [%8I64u, %8I64u]\n",
(unsigned long) s, (unsigned long) s,
(unsigned long) td->td_stripoffset[s], (unsigned __int64) td->td_stripoffset[s],
(unsigned long) td->td_stripbytecount[s]); (unsigned __int64) td->td_stripbytecount[s]);
#else
fprintf(fd, " %3lu: [%8llu, %8llu]\n",
(unsigned long) s,
(unsigned long long) td->td_stripoffset[s],
(unsigned long long) td->td_stripbytecount[s]);
#endif
} }
} }

File diff suppressed because it is too large Load Diff

View File

@ -1,4 +1,4 @@
/* $Id: tif_stream.cxx,v 1.6.2.1 2009-01-01 00:10:43 bfriesen Exp $ */ /* $Id: tif_stream.cxx,v 1.11 2010-12-11 23:12:29 faxguy Exp $ */
/* /*
* Copyright (c) 1988-1996 Sam Leffler * Copyright (c) 1988-1996 Sam Leffler
@ -34,76 +34,166 @@
using namespace std; using namespace std;
#endif #endif
class tiffis_data /*
{ ISO C++ uses a 'std::streamsize' type to define counts. This makes
public: it similar to, (but perhaps not the same as) size_t.
istream *myIS; The std::ios::pos_type is used to represent stream positions as used
long myStreamStartPos; by tellg(), tellp(), seekg(), and seekp(). This makes it similar to
(but perhaps not the same as) 'off_t'. The std::ios::streampos type
is used for character streams, but is documented to not be an
integral type anymore, so it should *not* be assigned to an integral
type.
The std::ios::off_type is used to specify relative offsets needed by
the variants of seekg() and seekp() which accept a relative offset
argument.
Useful prototype knowledge:
Obtain read position
ios::pos_type basic_istream::tellg()
Set read position
basic_istream& basic_istream::seekg(ios::pos_type)
basic_istream& basic_istream::seekg(ios::off_type, ios_base::seekdir)
Read data
basic_istream& istream::read(char *str, streamsize count)
Number of characters read in last unformatted read
streamsize istream::gcount();
Obtain write position
ios::pos_type basic_ostream::tellp()
Set write position
basic_ostream& basic_ostream::seekp(ios::pos_type)
basic_ostream& basic_ostream::seekp(ios::off_type, ios_base::seekdir)
Write data
basic_ostream& ostream::write(const char *str, streamsize count)
*/
struct tiffis_data;
struct tiffos_data;
extern "C" {
static tmsize_t _tiffosReadProc(thandle_t, void*, tmsize_t);
static tmsize_t _tiffisReadProc(thandle_t fd, void* buf, tmsize_t size);
static tmsize_t _tiffosWriteProc(thandle_t fd, void* buf, tmsize_t size);
static tmsize_t _tiffisWriteProc(thandle_t, void*, tmsize_t);
static uint64 _tiffosSeekProc(thandle_t fd, uint64 off, int whence);
static uint64 _tiffisSeekProc(thandle_t fd, uint64 off, int whence);
static uint64 _tiffosSizeProc(thandle_t fd);
static uint64 _tiffisSizeProc(thandle_t fd);
static int _tiffosCloseProc(thandle_t fd);
static int _tiffisCloseProc(thandle_t fd);
static int _tiffDummyMapProc(thandle_t , void** base, toff_t* size );
static void _tiffDummyUnmapProc(thandle_t , void* base, toff_t size );
static TIFF* _tiffStreamOpen(const char* name, const char* mode, void *fd);
struct tiffis_data
{
istream *stream;
ios::pos_type start_pos;
}; };
class tiffos_data struct tiffos_data
{ {
public: ostream *stream;
ios::pos_type start_pos;
ostream *myOS;
long myStreamStartPos;
}; };
static tsize_t static tmsize_t
_tiffosReadProc(thandle_t, tdata_t, tsize_t) _tiffosReadProc(thandle_t, void*, tmsize_t)
{ {
return 0; return 0;
} }
static tsize_t static tmsize_t
_tiffisReadProc(thandle_t fd, tdata_t buf, tsize_t size) _tiffisReadProc(thandle_t fd, void* buf, tmsize_t size)
{ {
tiffis_data *data = (tiffis_data *)fd; tiffis_data *data = reinterpret_cast<tiffis_data *>(fd);
data->myIS->read((char *)buf, (int)size); // Verify that type does not overflow.
streamsize request_size = size;
if (static_cast<tmsize_t>(request_size) != size)
return static_cast<tmsize_t>(-1);
return data->myIS->gcount(); data->stream->read((char *) buf, request_size);
return static_cast<tmsize_t>(data->stream->gcount());
} }
static tsize_t static tmsize_t
_tiffosWriteProc(thandle_t fd, tdata_t buf, tsize_t size) _tiffosWriteProc(thandle_t fd, void* buf, tmsize_t size)
{ {
tiffos_data *data = (tiffos_data *)fd; tiffos_data *data = reinterpret_cast<tiffos_data *>(fd);
ostream *os = data->myOS; ostream *os = data->stream;
int pos = os->tellp(); ios::pos_type pos = os->tellp();
os->write((const char *)buf, size); // Verify that type does not overflow.
streamsize request_size = size;
if (static_cast<tmsize_t>(request_size) != size)
return static_cast<tmsize_t>(-1);
return ((int)os->tellp()) - pos; os->write(reinterpret_cast<const char *>(buf), request_size);
return static_cast<tmsize_t>(os->tellp() - pos);
} }
static tsize_t static tmsize_t
_tiffisWriteProc(thandle_t, tdata_t, tsize_t) _tiffisWriteProc(thandle_t, void*, tmsize_t)
{ {
return 0; return 0;
} }
static toff_t static uint64
_tiffosSeekProc(thandle_t fd, toff_t off, int whence) _tiffosSeekProc(thandle_t fd, uint64 off, int whence)
{ {
tiffos_data *data = (tiffos_data *)fd; tiffos_data *data = reinterpret_cast<tiffos_data *>(fd);
ostream *os = data->myOS; ostream *os = data->stream;
// if the stream has already failed, don't do anything // if the stream has already failed, don't do anything
if( os->fail() ) if( os->fail() )
return os->tellp(); return static_cast<uint64>(-1);
switch(whence) { switch(whence) {
case SEEK_SET: case SEEK_SET:
os->seekp(data->myStreamStartPos + off, ios::beg); {
// Compute 64-bit offset
uint64 new_offset = static_cast<uint64>(data->start_pos) + off;
// Verify that value does not overflow
ios::off_type offset = static_cast<ios::off_type>(new_offset);
if (static_cast<uint64>(offset) != new_offset)
return static_cast<uint64>(-1);
os->seekp(offset, ios::beg);
break; break;
}
case SEEK_CUR: case SEEK_CUR:
os->seekp(off, ios::cur); {
break; // Verify that value does not overflow
ios::off_type offset = static_cast<ios::off_type>(off);
if (static_cast<uint64>(offset) != off)
return static_cast<uint64>(-1);
os->seekp(offset, ios::cur);
break;
}
case SEEK_END: case SEEK_END:
os->seekp(off, ios::end); {
break; // Verify that value does not overflow
ios::off_type offset = static_cast<ios::off_type>(off);
if (static_cast<uint64>(offset) != off)
return static_cast<uint64>(-1);
os->seekp(offset, ios::end);
break;
}
} }
// Attempt to workaround problems with seeking past the end of the // Attempt to workaround problems with seeking past the end of the
@ -116,14 +206,15 @@ _tiffosSeekProc(thandle_t fd, toff_t off, int whence)
#else #else
ios::iostate old_state; ios::iostate old_state;
#endif #endif
toff_t origin=0; ios::pos_type origin;
old_state = os->rdstate(); old_state = os->rdstate();
// reset the fail bit or else tellp() won't work below // reset the fail bit or else tellp() won't work below
os->clear(os->rdstate() & ~ios::failbit); os->clear(os->rdstate() & ~ios::failbit);
switch( whence ) { switch( whence ) {
case SEEK_SET: case SEEK_SET:
origin = data->myStreamStartPos; default:
origin = data->start_pos;
break; break;
case SEEK_CUR: case SEEK_CUR:
origin = os->tellp(); origin = os->tellp();
@ -137,80 +228,104 @@ _tiffosSeekProc(thandle_t fd, toff_t off, int whence)
os->clear(old_state); os->clear(old_state);
// only do something if desired seek position is valid // only do something if desired seek position is valid
if( origin + off > data->myStreamStartPos ) { if( (static_cast<uint64>(origin) + off) > static_cast<uint64>(data->start_pos) ) {
toff_t num_fill; uint64 num_fill;
// clear the fail bit // clear the fail bit
os->clear(os->rdstate() & ~ios::failbit); os->clear(os->rdstate() & ~ios::failbit);
// extend the stream to the expected size // extend the stream to the expected size
os->seekp(0, ios::end); os->seekp(0, ios::end);
num_fill = origin + off - (toff_t)os->tellp(); num_fill = (static_cast<uint64>(origin)) + off - os->tellp();
for( toff_t i = 0; i < num_fill; i++ ) for( uint64 i = 0; i < num_fill; i++ )
os->put('\0'); os->put('\0');
// retry the seek // retry the seek
os->seekp(origin + off, ios::beg); os->seekp(static_cast<ios::off_type>(static_cast<uint64>(origin) + off), ios::beg);
} }
} }
return os->tellp(); return static_cast<uint64>(os->tellp());
} }
static toff_t static uint64
_tiffisSeekProc(thandle_t fd, toff_t off, int whence) _tiffisSeekProc(thandle_t fd, uint64 off, int whence)
{ {
tiffis_data *data = (tiffis_data *)fd; tiffis_data *data = reinterpret_cast<tiffis_data *>(fd);
switch(whence) { switch(whence) {
case SEEK_SET: case SEEK_SET:
data->myIS->seekg(data->myStreamStartPos + off, ios::beg); {
break; // Compute 64-bit offset
uint64 new_offset = static_cast<uint64>(data->start_pos) + off;
// Verify that value does not overflow
ios::off_type offset = static_cast<ios::off_type>(new_offset);
if (static_cast<uint64>(offset) != new_offset)
return static_cast<uint64>(-1);
data->stream->seekg(offset, ios::beg);
break;
}
case SEEK_CUR: case SEEK_CUR:
data->myIS->seekg(off, ios::cur); {
break; // Verify that value does not overflow
ios::off_type offset = static_cast<ios::off_type>(off);
if (static_cast<uint64>(offset) != off)
return static_cast<uint64>(-1);
data->stream->seekg(offset, ios::cur);
break;
}
case SEEK_END: case SEEK_END:
data->myIS->seekg(off, ios::end); {
break; // Verify that value does not overflow
ios::off_type offset = static_cast<ios::off_type>(off);
if (static_cast<uint64>(offset) != off)
return static_cast<uint64>(-1);
data->stream->seekg(offset, ios::end);
break;
}
} }
return ((long)data->myIS->tellg()) - data->myStreamStartPos; return (uint64) (data->stream->tellg() - data->start_pos);
} }
static toff_t static uint64
_tiffosSizeProc(thandle_t fd) _tiffosSizeProc(thandle_t fd)
{ {
tiffos_data *data = (tiffos_data *)fd; tiffos_data *data = reinterpret_cast<tiffos_data *>(fd);
ostream *os = data->myOS; ostream *os = data->stream;
toff_t pos = os->tellp(); ios::pos_type pos = os->tellp();
toff_t len; ios::pos_type len;
os->seekp(0, ios::end); os->seekp(0, ios::end);
len = os->tellp(); len = os->tellp();
os->seekp(pos); os->seekp(pos);
return len; return (uint64) len;
} }
static toff_t static uint64
_tiffisSizeProc(thandle_t fd) _tiffisSizeProc(thandle_t fd)
{ {
tiffis_data *data = (tiffis_data *)fd; tiffis_data *data = reinterpret_cast<tiffis_data *>(fd);
int pos = data->myIS->tellg(); ios::pos_type pos = data->stream->tellg();
int len; ios::pos_type len;
data->myIS->seekg(0, ios::end); data->stream->seekg(0, ios::end);
len = data->myIS->tellg(); len = data->stream->tellg();
data->myIS->seekg(pos); data->stream->seekg(pos);
return len; return (uint64) len;
} }
static int static int
_tiffosCloseProc(thandle_t fd) _tiffosCloseProc(thandle_t fd)
{ {
// Our stream was not allocated by us, so it shouldn't be closed by us. // Our stream was not allocated by us, so it shouldn't be closed by us.
delete (tiffos_data *)fd; delete reinterpret_cast<tiffos_data *>(fd);
return 0; return 0;
} }
@ -218,18 +333,18 @@ static int
_tiffisCloseProc(thandle_t fd) _tiffisCloseProc(thandle_t fd)
{ {
// Our stream was not allocated by us, so it shouldn't be closed by us. // Our stream was not allocated by us, so it shouldn't be closed by us.
delete (tiffis_data *)fd; delete reinterpret_cast<tiffis_data *>(fd);
return 0; return 0;
} }
static int static int
_tiffDummyMapProc(thandle_t , tdata_t* , toff_t* ) _tiffDummyMapProc(thandle_t , void** base, toff_t* size )
{ {
return (0); return (0);
} }
static void static void
_tiffDummyUnmapProc(thandle_t , tdata_t , toff_t ) _tiffDummyUnmapProc(thandle_t , void* base, toff_t size )
{ {
} }
@ -243,32 +358,40 @@ _tiffStreamOpen(const char* name, const char* mode, void *fd)
if( strchr(mode, 'w') ) { if( strchr(mode, 'w') ) {
tiffos_data *data = new tiffos_data; tiffos_data *data = new tiffos_data;
data->myOS = (ostream *)fd; data->stream = reinterpret_cast<ostream *>(fd);
data->myStreamStartPos = data->myOS->tellp(); data->start_pos = data->stream->tellp();
// Open for writing. // Open for writing.
tif = TIFFClientOpen(name, mode, tif = TIFFClientOpen(name, mode,
(thandle_t) data, reinterpret_cast<thandle_t>(data),
_tiffosReadProc, _tiffosWriteProc, _tiffosReadProc,
_tiffosSeekProc, _tiffosCloseProc, _tiffosWriteProc,
_tiffosSeekProc,
_tiffosCloseProc,
_tiffosSizeProc, _tiffosSizeProc,
_tiffDummyMapProc, _tiffDummyUnmapProc); _tiffDummyMapProc,
_tiffDummyUnmapProc);
} else { } else {
tiffis_data *data = new tiffis_data; tiffis_data *data = new tiffis_data;
data->myIS = (istream *)fd; data->stream = reinterpret_cast<istream *>(fd);
data->myStreamStartPos = data->myIS->tellg(); data->start_pos = data->stream->tellg();
// Open for reading. // Open for reading.
tif = TIFFClientOpen(name, mode, tif = TIFFClientOpen(name, mode,
(thandle_t) data, reinterpret_cast<thandle_t>(data),
_tiffisReadProc, _tiffisWriteProc, _tiffisReadProc,
_tiffisSeekProc, _tiffisCloseProc, _tiffisWriteProc,
_tiffisSeekProc,
_tiffisCloseProc,
_tiffisSizeProc, _tiffisSizeProc,
_tiffDummyMapProc, _tiffDummyUnmapProc); _tiffDummyMapProc,
_tiffDummyUnmapProc);
} }
return (tif); return (tif);
} }
} /* extern "C" */
TIFF* TIFF*
TIFFStreamOpen(const char* name, ostream *os) TIFFStreamOpen(const char* name, ostream *os)
{ {
@ -276,7 +399,7 @@ TIFFStreamOpen(const char* name, ostream *os)
// written to it yet, then tellp() will return -1 which will break us. // written to it yet, then tellp() will return -1 which will break us.
// We workaround this by writing out a dummy character and // We workaround this by writing out a dummy character and
// then seek back to the beginning. // then seek back to the beginning.
if( !os->fail() && (int)os->tellp() < 0 ) { if( !os->fail() && static_cast<int>(os->tellp()) < 0 ) {
*os << '\0'; *os << '\0';
os->seekp(0); os->seekp(0);
} }
@ -293,3 +416,10 @@ TIFFStreamOpen(const char* name, istream *is)
} }
/* vim: set ts=8 sts=8 sw=8 noet: */ /* vim: set ts=8 sts=8 sw=8 noet: */
/*
Local Variables:
mode: c
indent-tabs-mode: true
c-basic-offset: 8
End:
*/

View File

@ -1,4 +1,4 @@
/* $Id: tif_strip.c,v 1.19.2.1 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Id: tif_strip.c,v 1.34 2011-04-02 20:54:09 bfriesen Exp $ */
/* /*
* Copyright (c) 1991-1997 Sam Leffler * Copyright (c) 1991-1997 Sam Leffler
@ -31,54 +31,25 @@
*/ */
#include "tiffiop.h" #include "tiffiop.h"
static uint32
summarize(TIFF* tif, size_t summand1, size_t summand2, const char* where)
{
/*
* XXX: We are using casting to uint32 here, bacause sizeof(size_t)
* may be larger than sizeof(uint32) on 64-bit architectures.
*/
uint32 bytes = summand1 + summand2;
if (bytes - summand1 != summand2) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, "Integer overflow in %s", where);
bytes = 0;
}
return (bytes);
}
static uint32
multiply(TIFF* tif, size_t nmemb, size_t elem_size, const char* where)
{
uint32 bytes = nmemb * elem_size;
if (elem_size && bytes / elem_size != nmemb) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, "Integer overflow in %s", where);
bytes = 0;
}
return (bytes);
}
/* /*
* Compute which strip a (row,sample) value is in. * Compute which strip a (row,sample) value is in.
*/ */
tstrip_t uint32
TIFFComputeStrip(TIFF* tif, uint32 row, tsample_t sample) TIFFComputeStrip(TIFF* tif, uint32 row, uint16 sample)
{ {
static const char module[] = "TIFFComputeStrip";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
tstrip_t strip; uint32 strip;
strip = row / td->td_rowsperstrip; strip = row / td->td_rowsperstrip;
if (td->td_planarconfig == PLANARCONFIG_SEPARATE) { if (td->td_planarconfig == PLANARCONFIG_SEPARATE) {
if (sample >= td->td_samplesperpixel) { if (sample >= td->td_samplesperpixel) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"%lu: Sample out of range, max %lu", "%lu: Sample out of range, max %lu",
(unsigned long) sample, (unsigned long) td->td_samplesperpixel); (unsigned long) sample, (unsigned long) td->td_samplesperpixel);
return ((tstrip_t) 0); return (0);
} }
strip += sample*td->td_stripsperimage; strip += (uint32)sample*td->td_stripsperimage;
} }
return (strip); return (strip);
} }
@ -86,33 +57,34 @@ TIFFComputeStrip(TIFF* tif, uint32 row, tsample_t sample)
/* /*
* Compute how many strips are in an image. * Compute how many strips are in an image.
*/ */
tstrip_t uint32
TIFFNumberOfStrips(TIFF* tif) TIFFNumberOfStrips(TIFF* tif)
{ {
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
tstrip_t nstrips; uint32 nstrips;
nstrips = (td->td_rowsperstrip == (uint32) -1 ? 1 : nstrips = (td->td_rowsperstrip == (uint32) -1 ? 1 :
TIFFhowmany(td->td_imagelength, td->td_rowsperstrip)); TIFFhowmany_32(td->td_imagelength, td->td_rowsperstrip));
if (td->td_planarconfig == PLANARCONFIG_SEPARATE) if (td->td_planarconfig == PLANARCONFIG_SEPARATE)
nstrips = multiply(tif, nstrips, td->td_samplesperpixel, nstrips = _TIFFMultiply32(tif, nstrips, (uint32)td->td_samplesperpixel,
"TIFFNumberOfStrips"); "TIFFNumberOfStrips");
return (nstrips); return (nstrips);
} }
/* /*
* Compute the # bytes in a variable height, row-aligned strip. * Compute the # bytes in a variable height, row-aligned strip.
*/ */
tsize_t uint64
TIFFVStripSize(TIFF* tif, uint32 nrows) TIFFVStripSize64(TIFF* tif, uint32 nrows)
{ {
static const char module[] = "TIFFVStripSize64";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
if (nrows==(uint32)(-1))
if (nrows == (uint32) -1) nrows=td->td_imagelength;
nrows = td->td_imagelength; if ((td->td_planarconfig==PLANARCONFIG_CONTIG)&&
if (td->td_planarconfig == PLANARCONFIG_CONTIG && (td->td_photometric == PHOTOMETRIC_YCBCR)&&
td->td_photometric == PHOTOMETRIC_YCBCR && (!isUpSampled(tif)))
!isUpSampled(tif)) { {
/* /*
* Packed YCbCr data contain one Cb+Cr for every * Packed YCbCr data contain one Cb+Cr for every
* HorizontalSampling*VerticalSampling Y values. * HorizontalSampling*VerticalSampling Y values.
@ -122,53 +94,100 @@ TIFFVStripSize(TIFF* tif, uint32 nrows)
* YCbCr data for the extended image. * YCbCr data for the extended image.
*/ */
uint16 ycbcrsubsampling[2]; uint16 ycbcrsubsampling[2];
tsize_t w, scanline, samplingarea; uint16 samplingblock_samples;
uint32 samplingblocks_hor;
TIFFGetField( tif, TIFFTAG_YCBCRSUBSAMPLING, uint32 samplingblocks_ver;
ycbcrsubsampling + 0, uint64 samplingrow_samples;
ycbcrsubsampling + 1 ); uint64 samplingrow_size;
if(td->td_samplesperpixel!=3)
samplingarea = ycbcrsubsampling[0]*ycbcrsubsampling[1]; {
if (samplingarea == 0) { TIFFErrorExt(tif->tif_clientdata,module,
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, "Invalid td_samplesperpixel value");
"Invalid YCbCr subsampling");
return 0; return 0;
} }
TIFFGetFieldDefaulted(tif,TIFFTAG_YCBCRSUBSAMPLING,ycbcrsubsampling+0,
w = TIFFroundup(td->td_imagewidth, ycbcrsubsampling[0]); ycbcrsubsampling+1);
scanline = TIFFhowmany8(multiply(tif, w, td->td_bitspersample, if (((ycbcrsubsampling[0]!=1)&&(ycbcrsubsampling[0]!=2)&&(ycbcrsubsampling[0]!=4)) ||
"TIFFVStripSize")); ((ycbcrsubsampling[1]!=1)&&(ycbcrsubsampling[1]!=2)&&(ycbcrsubsampling[1]!=4)))
nrows = TIFFroundup(nrows, ycbcrsubsampling[1]); {
/* NB: don't need TIFFhowmany here 'cuz everything is rounded */ TIFFErrorExt(tif->tif_clientdata,module,
scanline = multiply(tif, nrows, scanline, "TIFFVStripSize"); "Invalid YCbCr subsampling");
return ((tsize_t) return 0;
summarize(tif, scanline, }
multiply(tif, 2, scanline / samplingarea, samplingblock_samples=ycbcrsubsampling[0]*ycbcrsubsampling[1]+2;
"TIFFVStripSize"), "TIFFVStripSize")); samplingblocks_hor=TIFFhowmany_32(td->td_imagewidth,ycbcrsubsampling[0]);
} else samplingblocks_ver=TIFFhowmany_32(nrows,ycbcrsubsampling[1]);
return ((tsize_t) multiply(tif, nrows, TIFFScanlineSize(tif), samplingrow_samples=_TIFFMultiply64(tif,samplingblocks_hor,samplingblock_samples,module);
"TIFFVStripSize")); samplingrow_size=TIFFhowmany8_64(_TIFFMultiply64(tif,samplingrow_samples,td->td_bitspersample,module));
return(_TIFFMultiply64(tif,samplingrow_size,samplingblocks_ver,module));
}
else
return(_TIFFMultiply64(tif,nrows,TIFFScanlineSize64(tif),module));
}
tmsize_t
TIFFVStripSize(TIFF* tif, uint32 nrows)
{
static const char module[] = "TIFFVStripSize";
uint64 m;
tmsize_t n;
m=TIFFVStripSize64(tif,nrows);
n=(tmsize_t)m;
if ((uint64)n!=m)
{
TIFFErrorExt(tif->tif_clientdata,module,"Integer overflow");
n=0;
}
return(n);
} }
/* /*
* Compute the # bytes in a raw strip. * Compute the # bytes in a raw strip.
*/ */
tsize_t uint64
TIFFRawStripSize(TIFF* tif, tstrip_t strip) TIFFRawStripSize64(TIFF* tif, uint32 strip)
{ {
static const char module[] = "TIFFRawStripSize64";
TIFFDirectory* td = &tif->tif_dir; TIFFDirectory* td = &tif->tif_dir;
tsize_t bytecount = td->td_stripbytecount[strip]; uint64 bytecount = td->td_stripbytecount[strip];
if (bytecount <= 0) { if (bytecount == 0)
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, {
"%lu: Invalid strip byte count, strip %lu", #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
(unsigned long) bytecount, (unsigned long) strip); TIFFErrorExt(tif->tif_clientdata, module,
bytecount = (tsize_t) -1; "%I64u: Invalid strip byte count, strip %lu",
(unsigned __int64) bytecount,
(unsigned long) strip);
#else
TIFFErrorExt(tif->tif_clientdata, module,
"%llu: Invalid strip byte count, strip %lu",
(unsigned long long) bytecount,
(unsigned long) strip);
#endif
bytecount = (uint64) -1;
} }
return bytecount; return bytecount;
} }
tmsize_t
TIFFRawStripSize(TIFF* tif, uint32 strip)
{
static const char module[] = "TIFFRawStripSize";
uint64 m;
tmsize_t n;
m=TIFFRawStripSize64(tif,strip);
if (m==(uint64)(-1))
n=(tmsize_t)(-1);
else
{
n=(tmsize_t)m;
if ((uint64)n!=m)
{
TIFFErrorExt(tif->tif_clientdata,module,"Integer overflow");
n=0;
}
}
return(n);
}
/* /*
* Compute the # bytes in a (row-aligned) strip. * Compute the # bytes in a (row-aligned) strip.
@ -178,14 +197,29 @@ TIFFRawStripSize(TIFF* tif, tstrip_t strip)
* truncated to reflect the actual space required * truncated to reflect the actual space required
* to hold the strip. * to hold the strip.
*/ */
tsize_t uint64
TIFFStripSize(TIFF* tif) TIFFStripSize64(TIFF* tif)
{ {
TIFFDirectory* td = &tif->tif_dir; TIFFDirectory* td = &tif->tif_dir;
uint32 rps = td->td_rowsperstrip; uint32 rps = td->td_rowsperstrip;
if (rps > td->td_imagelength) if (rps > td->td_imagelength)
rps = td->td_imagelength; rps = td->td_imagelength;
return (TIFFVStripSize(tif, rps)); return (TIFFVStripSize64(tif, rps));
}
tmsize_t
TIFFStripSize(TIFF* tif)
{
static const char module[] = "TIFFStripSize";
uint64 m;
tmsize_t n;
m=TIFFStripSize64(tif);
n=(tmsize_t)m;
if ((uint64)n!=m)
{
TIFFErrorExt(tif->tif_clientdata,module,"Integer overflow");
n=0;
}
return(n);
} }
/* /*
@ -209,82 +243,21 @@ _TIFFDefaultStripSize(TIFF* tif, uint32 s)
* image up into strips that are approximately * image up into strips that are approximately
* STRIP_SIZE_DEFAULT bytes long. * STRIP_SIZE_DEFAULT bytes long.
*/ */
tsize_t scanline = TIFFScanlineSize(tif); uint64 scanlinesize;
s = (uint32)STRIP_SIZE_DEFAULT / (scanline == 0 ? 1 : scanline); uint64 rows;
if (s == 0) /* very wide images */ scanlinesize=TIFFScanlineSize64(tif);
s = 1; if (scanlinesize==0)
scanlinesize=1;
rows=(uint64)STRIP_SIZE_DEFAULT/scanlinesize;
if (rows==0)
rows=1;
else if (rows>0xFFFFFFFF)
rows=0xFFFFFFFF;
s=(uint32)rows;
} }
return (s); return (s);
} }
/*
* Return the number of bytes to read/write in a call to
* one of the scanline-oriented i/o routines. Note that
* this number may be 1/samples-per-pixel if data is
* stored as separate planes.
*/
tsize_t
TIFFScanlineSize(TIFF* tif)
{
TIFFDirectory *td = &tif->tif_dir;
tsize_t scanline;
if (td->td_planarconfig == PLANARCONFIG_CONTIG) {
if (td->td_photometric == PHOTOMETRIC_YCBCR
&& !isUpSampled(tif)) {
uint16 ycbcrsubsampling[2];
TIFFGetField(tif, TIFFTAG_YCBCRSUBSAMPLING,
ycbcrsubsampling + 0,
ycbcrsubsampling + 1);
if (ycbcrsubsampling[0] == 0) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name,
"Invalid YCbCr subsampling");
return 0;
}
scanline = TIFFroundup(td->td_imagewidth,
ycbcrsubsampling[0]);
scanline = TIFFhowmany8(multiply(tif, scanline,
td->td_bitspersample,
"TIFFScanlineSize"));
return ((tsize_t)
summarize(tif, scanline,
multiply(tif, 2,
scanline / ycbcrsubsampling[0],
"TIFFVStripSize"),
"TIFFVStripSize"));
} else {
scanline = multiply(tif, td->td_imagewidth,
td->td_samplesperpixel,
"TIFFScanlineSize");
}
} else
scanline = td->td_imagewidth;
return ((tsize_t) TIFFhowmany8(multiply(tif, scanline,
td->td_bitspersample,
"TIFFScanlineSize")));
}
/*
* Some stuff depends on this older version of TIFFScanlineSize
* TODO: resolve this
*/
tsize_t
TIFFOldScanlineSize(TIFF* tif)
{
TIFFDirectory *td = &tif->tif_dir;
tsize_t scanline;
scanline = multiply (tif, td->td_bitspersample, td->td_imagewidth,
"TIFFScanlineSize");
if (td->td_planarconfig == PLANARCONFIG_CONTIG)
scanline = multiply (tif, scanline, td->td_samplesperpixel,
"TIFFScanlineSize");
return ((tsize_t) TIFFhowmany8(scanline));
}
/* /*
* Return the number of bytes to read/write in a call to * Return the number of bytes to read/write in a call to
* one of the scanline-oriented i/o routines. Note that * one of the scanline-oriented i/o routines. Note that
@ -294,46 +267,71 @@ TIFFOldScanlineSize(TIFF* tif)
* strip size divided by the strip height, i.e. the size of a pack of vertical * strip size divided by the strip height, i.e. the size of a pack of vertical
* subsampling lines divided by vertical subsampling. It should thus make * subsampling lines divided by vertical subsampling. It should thus make
* sense when multiplied by a multiple of vertical subsampling. * sense when multiplied by a multiple of vertical subsampling.
* Some stuff depends on this newer version of TIFFScanlineSize
* TODO: resolve this
*/ */
tsize_t uint64
TIFFNewScanlineSize(TIFF* tif) TIFFScanlineSize64(TIFF* tif)
{ {
static const char module[] = "TIFFScanlineSize64";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
tsize_t scanline; uint64 scanline_size;
if (td->td_planarconfig==PLANARCONFIG_CONTIG)
if (td->td_planarconfig == PLANARCONFIG_CONTIG) { {
if (td->td_photometric == PHOTOMETRIC_YCBCR if ((td->td_photometric==PHOTOMETRIC_YCBCR)&&
&& !isUpSampled(tif)) { (td->td_samplesperpixel==3)&&
(!isUpSampled(tif)))
{
uint16 ycbcrsubsampling[2]; uint16 ycbcrsubsampling[2];
uint16 samplingblock_samples;
TIFFGetField(tif, TIFFTAG_YCBCRSUBSAMPLING, uint32 samplingblocks_hor;
ycbcrsubsampling + 0, uint64 samplingrow_samples;
ycbcrsubsampling + 1); uint64 samplingrow_size;
if(td->td_samplesperpixel!=3)
if (ycbcrsubsampling[0]*ycbcrsubsampling[1] == 0) { {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata,module,
"Invalid YCbCr subsampling"); "Invalid td_samplesperpixel value");
return 0; return 0;
} }
TIFFGetFieldDefaulted(tif,TIFFTAG_YCBCRSUBSAMPLING,
return((tsize_t) ((((td->td_imagewidth+ycbcrsubsampling[0]-1) ycbcrsubsampling+0,
/ycbcrsubsampling[0]) ycbcrsubsampling+1);
*(ycbcrsubsampling[0]*ycbcrsubsampling[1]+2) if (((ycbcrsubsampling[0]!=1)&&(ycbcrsubsampling[0]!=2)&&(ycbcrsubsampling[0]!=4)) ||
*td->td_bitspersample+7) ((ycbcrsubsampling[1]!=1)&&(ycbcrsubsampling[1]!=2)&&(ycbcrsubsampling[1]!=4)))
/8)/ycbcrsubsampling[1]); {
TIFFErrorExt(tif->tif_clientdata,module,
} else { "Invalid YCbCr subsampling");
scanline = multiply(tif, td->td_imagewidth, return 0;
td->td_samplesperpixel, }
"TIFFScanlineSize"); samplingblock_samples = ycbcrsubsampling[0]*ycbcrsubsampling[1]+2;
samplingblocks_hor = TIFFhowmany_32(td->td_imagewidth,ycbcrsubsampling[0]);
samplingrow_samples = _TIFFMultiply64(tif,samplingblocks_hor,samplingblock_samples,module);
samplingrow_size = TIFFhowmany_64(_TIFFMultiply64(tif,samplingrow_samples,td->td_bitspersample,module),8);
scanline_size = (samplingrow_size/ycbcrsubsampling[1]);
} }
} else else
scanline = td->td_imagewidth; {
return ((tsize_t) TIFFhowmany8(multiply(tif, scanline, uint64 scanline_samples;
td->td_bitspersample, scanline_samples=_TIFFMultiply64(tif,td->td_imagewidth,td->td_samplesperpixel,module);
"TIFFScanlineSize"))); scanline_size=TIFFhowmany_64(_TIFFMultiply64(tif,scanline_samples,td->td_bitspersample,module),8);
}
}
else
scanline_size=TIFFhowmany_64(_TIFFMultiply64(tif,td->td_imagewidth,td->td_bitspersample,module),8);
return(scanline_size);
}
tmsize_t
TIFFScanlineSize(TIFF* tif)
{
static const char module[] = "TIFFScanlineSize";
uint64 m;
tmsize_t n;
m=TIFFScanlineSize64(tif);
n=(tmsize_t)m;
if ((uint64)n!=m)
{
TIFFErrorExt(tif->tif_clientdata,module,"Integer arithmetic overflow");
n=0;
}
return(n);
} }
/* /*
@ -342,22 +340,35 @@ TIFFNewScanlineSize(TIFF* tif)
* I/O size returned by TIFFScanlineSize which may be less * I/O size returned by TIFFScanlineSize which may be less
* if data is store as separate planes). * if data is store as separate planes).
*/ */
tsize_t uint64
TIFFRasterScanlineSize64(TIFF* tif)
{
static const char module[] = "TIFFRasterScanlineSize64";
TIFFDirectory *td = &tif->tif_dir;
uint64 scanline;
scanline = _TIFFMultiply64(tif, td->td_bitspersample, td->td_imagewidth, module);
if (td->td_planarconfig == PLANARCONFIG_CONTIG) {
scanline = _TIFFMultiply64(tif, scanline, td->td_samplesperpixel, module);
return (TIFFhowmany8_64(scanline));
} else
return (_TIFFMultiply64(tif, TIFFhowmany8_64(scanline),
td->td_samplesperpixel, module));
}
tmsize_t
TIFFRasterScanlineSize(TIFF* tif) TIFFRasterScanlineSize(TIFF* tif)
{ {
TIFFDirectory *td = &tif->tif_dir; static const char module[] = "TIFFRasterScanlineSize";
tsize_t scanline; uint64 m;
tmsize_t n;
scanline = multiply (tif, td->td_bitspersample, td->td_imagewidth, m=TIFFRasterScanlineSize64(tif);
"TIFFRasterScanlineSize"); n=(tmsize_t)m;
if (td->td_planarconfig == PLANARCONFIG_CONTIG) { if ((uint64)n!=m)
scanline = multiply (tif, scanline, td->td_samplesperpixel, {
"TIFFRasterScanlineSize"); TIFFErrorExt(tif->tif_clientdata,module,"Integer arithmetic overflow");
return ((tsize_t) TIFFhowmany8(scanline)); n=0;
} else }
return ((tsize_t) multiply (tif, TIFFhowmany8(scanline), return(n);
td->td_samplesperpixel,
"TIFFRasterScanlineSize"));
} }
/* vim: set ts=8 sts=8 sw=8 noet: */ /* vim: set ts=8 sts=8 sw=8 noet: */

View File

@ -1,4 +1,4 @@
/* $Id: tif_swab.c,v 1.4.2.1 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Id: tif_swab.c,v 1.13 2010-03-10 18:56:49 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -37,7 +37,7 @@ TIFFSwabShort(uint16* wp)
{ {
register unsigned char* cp = (unsigned char*) wp; register unsigned char* cp = (unsigned char*) wp;
unsigned char t; unsigned char t;
assert(sizeof(uint16)==2);
t = cp[1]; cp[1] = cp[0]; cp[0] = t; t = cp[1]; cp[1] = cp[0]; cp[0] = t;
} }
#endif #endif
@ -48,19 +48,33 @@ TIFFSwabLong(uint32* lp)
{ {
register unsigned char* cp = (unsigned char*) lp; register unsigned char* cp = (unsigned char*) lp;
unsigned char t; unsigned char t;
assert(sizeof(uint32)==4);
t = cp[3]; cp[3] = cp[0]; cp[0] = t; t = cp[3]; cp[3] = cp[0]; cp[0] = t;
t = cp[2]; cp[2] = cp[1]; cp[1] = t; t = cp[2]; cp[2] = cp[1]; cp[1] = t;
} }
#endif #endif
#ifndef TIFFSwabLong8
void
TIFFSwabLong8(uint64* lp)
{
register unsigned char* cp = (unsigned char*) lp;
unsigned char t;
assert(sizeof(uint64)==8);
t = cp[7]; cp[7] = cp[0]; cp[0] = t;
t = cp[6]; cp[6] = cp[1]; cp[1] = t;
t = cp[5]; cp[5] = cp[2]; cp[2] = t;
t = cp[4]; cp[4] = cp[3]; cp[3] = t;
}
#endif
#ifndef TIFFSwabArrayOfShort #ifndef TIFFSwabArrayOfShort
void void
TIFFSwabArrayOfShort(uint16* wp, register unsigned long n) TIFFSwabArrayOfShort(register uint16* wp, tmsize_t n)
{ {
register unsigned char* cp; register unsigned char* cp;
register unsigned char t; register unsigned char t;
assert(sizeof(uint16)==2);
/* XXX unroll loop some */ /* XXX unroll loop some */
while (n-- > 0) { while (n-- > 0) {
cp = (unsigned char*) wp; cp = (unsigned char*) wp;
@ -72,7 +86,7 @@ TIFFSwabArrayOfShort(uint16* wp, register unsigned long n)
#ifndef TIFFSwabArrayOfTriples #ifndef TIFFSwabArrayOfTriples
void void
TIFFSwabArrayOfTriples(uint8* tp, unsigned long n) TIFFSwabArrayOfTriples(register uint8* tp, tmsize_t n)
{ {
unsigned char* cp; unsigned char* cp;
unsigned char t; unsigned char t;
@ -88,11 +102,11 @@ TIFFSwabArrayOfTriples(uint8* tp, unsigned long n)
#ifndef TIFFSwabArrayOfLong #ifndef TIFFSwabArrayOfLong
void void
TIFFSwabArrayOfLong(register uint32* lp, register unsigned long n) TIFFSwabArrayOfLong(register uint32* lp, tmsize_t n)
{ {
register unsigned char *cp; register unsigned char *cp;
register unsigned char t; register unsigned char t;
assert(sizeof(uint32)==4);
/* XXX unroll loop some */ /* XXX unroll loop some */
while (n-- > 0) { while (n-- > 0) {
cp = (unsigned char *)lp; cp = (unsigned char *)lp;
@ -103,30 +117,84 @@ TIFFSwabArrayOfLong(register uint32* lp, register unsigned long n)
} }
#endif #endif
#ifndef TIFFSwabArrayOfLong8
void
TIFFSwabArrayOfLong8(register uint64* lp, tmsize_t n)
{
register unsigned char *cp;
register unsigned char t;
assert(sizeof(uint64)==8);
/* XXX unroll loop some */
while (n-- > 0) {
cp = (unsigned char *)lp;
t = cp[7]; cp[7] = cp[0]; cp[0] = t;
t = cp[6]; cp[6] = cp[1]; cp[1] = t;
t = cp[5]; cp[5] = cp[2]; cp[2] = t;
t = cp[4]; cp[4] = cp[3]; cp[3] = t;
lp++;
}
}
#endif
#ifndef TIFFSwabFloat
void
TIFFSwabFloat(float* fp)
{
register unsigned char* cp = (unsigned char*) fp;
unsigned char t;
assert(sizeof(float)==4);
t = cp[3]; cp[3] = cp[0]; cp[0] = t;
t = cp[2]; cp[2] = cp[1]; cp[1] = t;
}
#endif
#ifndef TIFFSwabArrayOfFloat
void
TIFFSwabArrayOfFloat(register float* fp, tmsize_t n)
{
register unsigned char *cp;
register unsigned char t;
assert(sizeof(float)==4);
/* XXX unroll loop some */
while (n-- > 0) {
cp = (unsigned char *)fp;
t = cp[3]; cp[3] = cp[0]; cp[0] = t;
t = cp[2]; cp[2] = cp[1]; cp[1] = t;
fp++;
}
}
#endif
#ifndef TIFFSwabDouble #ifndef TIFFSwabDouble
void void
TIFFSwabDouble(double *dp) TIFFSwabDouble(double *dp)
{ {
register uint32* lp = (uint32*) dp; register unsigned char* cp = (unsigned char*) dp;
uint32 t; unsigned char t;
assert(sizeof(double)==8);
TIFFSwabArrayOfLong(lp, 2); t = cp[7]; cp[7] = cp[0]; cp[0] = t;
t = lp[0]; lp[0] = lp[1]; lp[1] = t; t = cp[6]; cp[6] = cp[1]; cp[1] = t;
t = cp[5]; cp[5] = cp[2]; cp[2] = t;
t = cp[4]; cp[4] = cp[3]; cp[3] = t;
} }
#endif #endif
#ifndef TIFFSwabArrayOfDouble #ifndef TIFFSwabArrayOfDouble
void void
TIFFSwabArrayOfDouble(double* dp, register unsigned long n) TIFFSwabArrayOfDouble(double* dp, tmsize_t n)
{ {
register uint32* lp = (uint32*) dp; register unsigned char *cp;
register uint32 t; register unsigned char t;
assert(sizeof(double)==8);
TIFFSwabArrayOfLong(lp, n + n); /* XXX unroll loop some */
while (n-- > 0) { while (n-- > 0) {
t = lp[0]; lp[0] = lp[1]; lp[1] = t; cp = (unsigned char *)dp;
lp += 2; t = cp[7]; cp[7] = cp[0]; cp[0] = t;
} t = cp[6]; cp[6] = cp[1]; cp[1] = t;
t = cp[5]; cp[5] = cp[2]; cp[2] = t;
t = cp[4]; cp[4] = cp[3]; cp[3] = t;
dp++;
}
} }
#endif #endif
@ -215,7 +283,7 @@ TIFFGetBitRevTable(int reversed)
} }
void void
TIFFReverseBits(register unsigned char* cp, register unsigned long n) TIFFReverseBits(uint8* cp, tmsize_t n)
{ {
for (; n > 8; n -= 8) { for (; n > 8; n -= 8) {
cp[0] = TIFFBitRevTable[cp[0]]; cp[0] = TIFFBitRevTable[cp[0]];

View File

@ -1,4 +1,4 @@
/* $Id: tif_thunder.c,v 1.5.2.1 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Id: tif_thunder.c,v 1.12 2011-04-02 20:54:09 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -25,6 +25,7 @@
*/ */
#include "tiffiop.h" #include "tiffiop.h"
#include <assert.h>
#ifdef THUNDER_SUPPORT #ifdef THUNDER_SUPPORT
/* /*
* TIFF Library. * TIFF Library.
@ -55,21 +56,42 @@
static const int twobitdeltas[4] = { 0, 1, 0, -1 }; static const int twobitdeltas[4] = { 0, 1, 0, -1 };
static const int threebitdeltas[8] = { 0, 1, 2, 3, 0, -3, -2, -1 }; static const int threebitdeltas[8] = { 0, 1, 2, 3, 0, -3, -2, -1 };
#define SETPIXEL(op, v) { \ #define SETPIXEL(op, v) { \
lastpixel = (v) & 0xf; \ lastpixel = (v) & 0xf; \
if (npixels++ & 1) \ if ( npixels < maxpixels ) \
*op++ |= lastpixel; \ { \
else \ if (npixels++ & 1) \
op[0] = (tidataval_t) (lastpixel << 4); \ *op++ |= lastpixel; \
else \
op[0] = (uint8) (lastpixel << 4); \
} \
} }
static int static int
ThunderDecode(TIFF* tif, tidata_t op, tsize_t maxpixels) ThunderSetupDecode(TIFF* tif)
{ {
static const char module[] = "ThunderSetupDecode";
if( tif->tif_dir.td_bitspersample != 4 )
{
TIFFErrorExt(tif->tif_clientdata, module,
"Wrong bitspersample value (%d), Thunder decoder only supports 4bits per sample.",
(int) tif->tif_dir.td_bitspersample );
return 0;
}
return (1);
}
static int
ThunderDecode(TIFF* tif, uint8* op, tmsize_t maxpixels)
{
static const char module[] = "ThunderDecode";
register unsigned char *bp; register unsigned char *bp;
register tsize_t cc; register tmsize_t cc;
unsigned int lastpixel; unsigned int lastpixel;
tsize_t npixels; tmsize_t npixels;
bp = (unsigned char *)tif->tif_rawcp; bp = (unsigned char *)tif->tif_rawcp;
cc = tif->tif_rawcc; cc = tif->tif_rawcc;
@ -93,7 +115,7 @@ ThunderDecode(TIFF* tif, tidata_t op, tsize_t maxpixels)
npixels += n; npixels += n;
if (npixels < maxpixels) { if (npixels < maxpixels) {
for (; n > 0; n -= 2) for (; n > 0; n -= 2)
*op++ = (tidataval_t) lastpixel; *op++ = (uint8) lastpixel;
} }
if (n == -1) if (n == -1)
*--op &= 0xf0; *--op &= 0xf0;
@ -118,25 +140,43 @@ ThunderDecode(TIFF* tif, tidata_t op, tsize_t maxpixels)
break; break;
} }
} }
tif->tif_rawcp = (tidata_t) bp; tif->tif_rawcp = (uint8*) bp;
tif->tif_rawcc = cc; tif->tif_rawcc = cc;
if (npixels != maxpixels) { if (npixels != maxpixels) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, #if defined(__WIN32__) && (defined(_MSC_VER) || defined(__MINGW32__))
"ThunderDecode: %s data at scanline %ld (%lu != %lu)", TIFFErrorExt(tif->tif_clientdata, module,
npixels < maxpixels ? "Not enough" : "Too much", "%s data at scanline %lu (%I64u != %I64u)",
(long) tif->tif_row, (long) npixels, (long) maxpixels); npixels < maxpixels ? "Not enough" : "Too much",
(unsigned long) tif->tif_row,
(unsigned __int64) npixels,
(unsigned __int64) maxpixels);
#else
TIFFErrorExt(tif->tif_clientdata, module,
"%s data at scanline %lu (%llu != %llu)",
npixels < maxpixels ? "Not enough" : "Too much",
(unsigned long) tif->tif_row,
(unsigned long long) npixels,
(unsigned long long) maxpixels);
#endif
return (0); return (0);
} }
return (1);
return (1);
} }
static int static int
ThunderDecodeRow(TIFF* tif, tidata_t buf, tsize_t occ, tsample_t s) ThunderDecodeRow(TIFF* tif, uint8* buf, tmsize_t occ, uint16 s)
{ {
tidata_t row = buf; static const char module[] = "ThunderDecodeRow";
uint8* row = buf;
(void) s; (void) s;
while ((long)occ > 0) { if (occ % tif->tif_scanlinesize)
{
TIFFErrorExt(tif->tif_clientdata, module, "Fractional scanlines cannot be read");
return (0);
}
while (occ > 0) {
if (!ThunderDecode(tif, row, tif->tif_dir.td_imagewidth)) if (!ThunderDecode(tif, row, tif->tif_dir.td_imagewidth))
return (0); return (0);
occ -= tif->tif_scanlinesize; occ -= tif->tif_scanlinesize;
@ -149,8 +189,10 @@ int
TIFFInitThunderScan(TIFF* tif, int scheme) TIFFInitThunderScan(TIFF* tif, int scheme)
{ {
(void) scheme; (void) scheme;
tif->tif_setupdecode = ThunderSetupDecode;
tif->tif_decoderow = ThunderDecodeRow; tif->tif_decoderow = ThunderDecodeRow;
tif->tif_decodestrip = ThunderDecodeRow; tif->tif_decodestrip = ThunderDecodeRow;
return (1); return (1);
} }
#endif /* THUNDER_SUPPORT */ #endif /* THUNDER_SUPPORT */

View File

@ -1,4 +1,4 @@
/* $Id: tif_tile.c,v 1.12.2.1 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Id: tif_tile.c,v 1.22 2010-07-01 15:33:28 dron Exp $ */
/* /*
* Copyright (c) 1991-1997 Sam Leffler * Copyright (c) 1991-1997 Sam Leffler
@ -31,47 +31,17 @@
*/ */
#include "tiffiop.h" #include "tiffiop.h"
static uint32
summarize(TIFF* tif, size_t summand1, size_t summand2, const char* where)
{
/*
* XXX: We are using casting to uint32 here, because sizeof(size_t)
* may be larger than sizeof(uint32) on 64-bit architectures.
*/
uint32 bytes = summand1 + summand2;
if (bytes - summand1 != summand2) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, "Integer overflow in %s", where);
bytes = 0;
}
return (bytes);
}
static uint32
multiply(TIFF* tif, size_t nmemb, size_t elem_size, const char* where)
{
uint32 bytes = nmemb * elem_size;
if (elem_size && bytes / elem_size != nmemb) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, "Integer overflow in %s", where);
bytes = 0;
}
return (bytes);
}
/* /*
* Compute which tile an (x,y,z,s) value is in. * Compute which tile an (x,y,z,s) value is in.
*/ */
ttile_t uint32
TIFFComputeTile(TIFF* tif, uint32 x, uint32 y, uint32 z, tsample_t s) TIFFComputeTile(TIFF* tif, uint32 x, uint32 y, uint32 z, uint16 s)
{ {
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
uint32 dx = td->td_tilewidth; uint32 dx = td->td_tilewidth;
uint32 dy = td->td_tilelength; uint32 dy = td->td_tilelength;
uint32 dz = td->td_tiledepth; uint32 dz = td->td_tiledepth;
ttile_t tile = 1; uint32 tile = 1;
if (td->td_imagedepth == 1) if (td->td_imagedepth == 1)
z = 0; z = 0;
@ -82,9 +52,9 @@ TIFFComputeTile(TIFF* tif, uint32 x, uint32 y, uint32 z, tsample_t s)
if (dz == (uint32) -1) if (dz == (uint32) -1)
dz = td->td_imagedepth; dz = td->td_imagedepth;
if (dx != 0 && dy != 0 && dz != 0) { if (dx != 0 && dy != 0 && dz != 0) {
uint32 xpt = TIFFhowmany(td->td_imagewidth, dx); uint32 xpt = TIFFhowmany_32(td->td_imagewidth, dx);
uint32 ypt = TIFFhowmany(td->td_imagelength, dy); uint32 ypt = TIFFhowmany_32(td->td_imagelength, dy);
uint32 zpt = TIFFhowmany(td->td_imagedepth, dz); uint32 zpt = TIFFhowmany_32(td->td_imagedepth, dz);
if (td->td_planarconfig == PLANARCONFIG_SEPARATE) if (td->td_planarconfig == PLANARCONFIG_SEPARATE)
tile = (xpt*ypt*zpt)*s + tile = (xpt*ypt*zpt)*s +
@ -102,7 +72,7 @@ TIFFComputeTile(TIFF* tif, uint32 x, uint32 y, uint32 z, tsample_t s)
* against the image bounds. * against the image bounds.
*/ */
int int
TIFFCheckTile(TIFF* tif, uint32 x, uint32 y, uint32 z, tsample_t s) TIFFCheckTile(TIFF* tif, uint32 x, uint32 y, uint32 z, uint16 s)
{ {
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
@ -141,14 +111,14 @@ TIFFCheckTile(TIFF* tif, uint32 x, uint32 y, uint32 z, tsample_t s)
/* /*
* Compute how many tiles are in an image. * Compute how many tiles are in an image.
*/ */
ttile_t uint32
TIFFNumberOfTiles(TIFF* tif) TIFFNumberOfTiles(TIFF* tif)
{ {
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
uint32 dx = td->td_tilewidth; uint32 dx = td->td_tilewidth;
uint32 dy = td->td_tilelength; uint32 dy = td->td_tilelength;
uint32 dz = td->td_tiledepth; uint32 dz = td->td_tiledepth;
ttile_t ntiles; uint32 ntiles;
if (dx == (uint32) -1) if (dx == (uint32) -1)
dx = td->td_imagewidth; dx = td->td_imagewidth;
@ -157,50 +127,66 @@ TIFFNumberOfTiles(TIFF* tif)
if (dz == (uint32) -1) if (dz == (uint32) -1)
dz = td->td_imagedepth; dz = td->td_imagedepth;
ntiles = (dx == 0 || dy == 0 || dz == 0) ? 0 : ntiles = (dx == 0 || dy == 0 || dz == 0) ? 0 :
multiply(tif, multiply(tif, TIFFhowmany(td->td_imagewidth, dx), _TIFFMultiply32(tif, _TIFFMultiply32(tif, TIFFhowmany_32(td->td_imagewidth, dx),
TIFFhowmany(td->td_imagelength, dy), TIFFhowmany_32(td->td_imagelength, dy),
"TIFFNumberOfTiles"), "TIFFNumberOfTiles"),
TIFFhowmany(td->td_imagedepth, dz), "TIFFNumberOfTiles"); TIFFhowmany_32(td->td_imagedepth, dz), "TIFFNumberOfTiles");
if (td->td_planarconfig == PLANARCONFIG_SEPARATE) if (td->td_planarconfig == PLANARCONFIG_SEPARATE)
ntiles = multiply(tif, ntiles, td->td_samplesperpixel, ntiles = _TIFFMultiply32(tif, ntiles, td->td_samplesperpixel,
"TIFFNumberOfTiles"); "TIFFNumberOfTiles");
return (ntiles); return (ntiles);
} }
/* /*
* Compute the # bytes in each row of a tile. * Compute the # bytes in each row of a tile.
*/ */
tsize_t uint64
TIFFTileRowSize(TIFF* tif) TIFFTileRowSize64(TIFF* tif)
{ {
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
tsize_t rowsize; uint64 rowsize;
if (td->td_tilelength == 0 || td->td_tilewidth == 0) if (td->td_tilelength == 0 || td->td_tilewidth == 0)
return ((tsize_t) 0); return (0);
rowsize = multiply(tif, td->td_bitspersample, td->td_tilewidth, rowsize = _TIFFMultiply64(tif, td->td_bitspersample, td->td_tilewidth,
"TIFFTileRowSize"); "TIFFTileRowSize");
if (td->td_planarconfig == PLANARCONFIG_CONTIG) if (td->td_planarconfig == PLANARCONFIG_CONTIG)
rowsize = multiply(tif, rowsize, td->td_samplesperpixel, rowsize = _TIFFMultiply64(tif, rowsize, td->td_samplesperpixel,
"TIFFTileRowSize"); "TIFFTileRowSize");
return ((tsize_t) TIFFhowmany8(rowsize)); return (TIFFhowmany8_64(rowsize));
}
tmsize_t
TIFFTileRowSize(TIFF* tif)
{
static const char module[] = "TIFFTileRowSize";
uint64 m;
tmsize_t n;
m=TIFFTileRowSize64(tif);
n=(tmsize_t)m;
if ((uint64)n!=m)
{
TIFFErrorExt(tif->tif_clientdata,module,"Integer overflow");
n=0;
}
return(n);
} }
/* /*
* Compute the # bytes in a variable length, row-aligned tile. * Compute the # bytes in a variable length, row-aligned tile.
*/ */
tsize_t uint64
TIFFVTileSize(TIFF* tif, uint32 nrows) TIFFVTileSize64(TIFF* tif, uint32 nrows)
{ {
static const char module[] = "TIFFVTileSize64";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
tsize_t tilesize;
if (td->td_tilelength == 0 || td->td_tilewidth == 0 || if (td->td_tilelength == 0 || td->td_tilewidth == 0 ||
td->td_tiledepth == 0) td->td_tiledepth == 0)
return ((tsize_t) 0); return (0);
if (td->td_planarconfig == PLANARCONFIG_CONTIG && if ((td->td_planarconfig==PLANARCONFIG_CONTIG)&&
td->td_photometric == PHOTOMETRIC_YCBCR && (td->td_photometric==PHOTOMETRIC_YCBCR)&&
!isUpSampled(tif)) { (td->td_samplesperpixel==3)&&
(!isUpSampled(tif)))
{
/* /*
* Packed YCbCr data contain one Cb+Cr for every * Packed YCbCr data contain one Cb+Cr for every
* HorizontalSampling*VerticalSampling Y values. * HorizontalSampling*VerticalSampling Y values.
@ -209,38 +195,70 @@ TIFFVTileSize(TIFF* tif, uint32 nrows)
* horizontal/vertical subsampling area include * horizontal/vertical subsampling area include
* YCbCr data for the extended image. * YCbCr data for the extended image.
*/ */
tsize_t w = uint16 ycbcrsubsampling[2];
TIFFroundup(td->td_tilewidth, td->td_ycbcrsubsampling[0]); uint16 samplingblock_samples;
tsize_t rowsize = uint32 samplingblocks_hor;
TIFFhowmany8(multiply(tif, w, td->td_bitspersample, uint32 samplingblocks_ver;
"TIFFVTileSize")); uint64 samplingrow_samples;
tsize_t samplingarea = uint64 samplingrow_size;
td->td_ycbcrsubsampling[0]*td->td_ycbcrsubsampling[1]; TIFFGetFieldDefaulted(tif,TIFFTAG_YCBCRSUBSAMPLING,ycbcrsubsampling+0,
if (samplingarea == 0) { ycbcrsubsampling+1);
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, "Invalid YCbCr subsampling"); assert((ycbcrsubsampling[0]==1)||(ycbcrsubsampling[0]==2)||(ycbcrsubsampling[0]==4));
assert((ycbcrsubsampling[1]==1)||(ycbcrsubsampling[1]==2)||(ycbcrsubsampling[1]==4));
if (ycbcrsubsampling[0]*ycbcrsubsampling[1]==0)
{
TIFFErrorExt(tif->tif_clientdata,module,
"Invalid YCbCr subsampling");
return 0; return 0;
} }
nrows = TIFFroundup(nrows, td->td_ycbcrsubsampling[1]); samplingblock_samples=ycbcrsubsampling[0]*ycbcrsubsampling[1]+2;
/* NB: don't need TIFFhowmany here 'cuz everything is rounded */ samplingblocks_hor=TIFFhowmany_32(td->td_tilewidth,ycbcrsubsampling[0]);
tilesize = multiply(tif, nrows, rowsize, "TIFFVTileSize"); samplingblocks_ver=TIFFhowmany_32(nrows,ycbcrsubsampling[1]);
tilesize = summarize(tif, tilesize, samplingrow_samples=_TIFFMultiply64(tif,samplingblocks_hor,samplingblock_samples,module);
multiply(tif, 2, tilesize / samplingarea, samplingrow_size=TIFFhowmany8_64(_TIFFMultiply64(tif,samplingrow_samples,td->td_bitspersample,module));
"TIFFVTileSize"), return(_TIFFMultiply64(tif,samplingrow_size,samplingblocks_ver,module));
"TIFFVTileSize"); }
} else else
tilesize = multiply(tif, nrows, TIFFTileRowSize(tif), return(_TIFFMultiply64(tif,nrows,TIFFTileRowSize64(tif),module));
"TIFFVTileSize"); }
return ((tsize_t) tmsize_t
multiply(tif, tilesize, td->td_tiledepth, "TIFFVTileSize")); TIFFVTileSize(TIFF* tif, uint32 nrows)
{
static const char module[] = "TIFFVTileSize";
uint64 m;
tmsize_t n;
m=TIFFVTileSize64(tif,nrows);
n=(tmsize_t)m;
if ((uint64)n!=m)
{
TIFFErrorExt(tif->tif_clientdata,module,"Integer overflow");
n=0;
}
return(n);
} }
/* /*
* Compute the # bytes in a row-aligned tile. * Compute the # bytes in a row-aligned tile.
*/ */
tsize_t uint64
TIFFTileSize64(TIFF* tif)
{
return (TIFFVTileSize64(tif, tif->tif_dir.td_tilelength));
}
tmsize_t
TIFFTileSize(TIFF* tif) TIFFTileSize(TIFF* tif)
{ {
return (TIFFVTileSize(tif, tif->tif_dir.td_tilelength)); static const char module[] = "TIFFTileSize";
uint64 m;
tmsize_t n;
m=TIFFTileSize64(tif);
n=(tmsize_t)m;
if ((uint64)n!=m)
{
TIFFErrorExt(tif->tif_clientdata,module,"Integer overflow");
n=0;
}
return(n);
} }
/* /*
@ -265,9 +283,9 @@ _TIFFDefaultTileSize(TIFF* tif, uint32* tw, uint32* th)
*th = 256; *th = 256;
/* roundup to a multiple of 16 per the spec */ /* roundup to a multiple of 16 per the spec */
if (*tw & 0xf) if (*tw & 0xf)
*tw = TIFFroundup(*tw, 16); *tw = TIFFroundup_32(*tw, 16);
if (*th & 0xf) if (*th & 0xf)
*th = TIFFroundup(*th, 16); *th = TIFFroundup_32(*th, 16);
} }
/* vim: set ts=8 sts=8 sw=8 noet: */ /* vim: set ts=8 sts=8 sw=8 noet: */

View File

@ -1,26 +1,26 @@
/* $Id: tif_unix.c,v 1.12.2.1 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Id: tif_unix.c,v 1.22 2010-03-10 18:56:49 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
* Copyright (c) 1991-1997 Silicon Graphics, Inc. * Copyright (c) 1991-1997 Silicon Graphics, Inc.
* *
* Permission to use, copy, modify, distribute, and sell this software and * Permission to use, copy, modify, distribute, and sell this software and
* its documentation for any purpose is hereby granted without fee, provided * its documentation for any purpose is hereby granted without fee, provided
* that (i) the above copyright notices and this permission notice appear in * that (i) the above copyright notices and this permission notice appear in
* all copies of the software and related documentation, and (ii) the names of * all copies of the software and related documentation, and (ii) the names of
* Sam Leffler and Silicon Graphics may not be used in any advertising or * Sam Leffler and Silicon Graphics may not be used in any advertising or
* publicity relating to the software without the specific, prior written * publicity relating to the software without the specific, prior written
* permission of Sam Leffler and Silicon Graphics. * permission of Sam Leffler and Silicon Graphics.
* *
* THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND, * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
* EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
* WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
* *
* IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
* ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
* OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
* WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
* LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
* OF THIS SOFTWARE. * OF THIS SOFTWARE.
*/ */
@ -28,12 +28,15 @@
* TIFF Library UNIX-specific Routines. These are should also work with the * TIFF Library UNIX-specific Routines. These are should also work with the
* Windows Common RunTime Library. * Windows Common RunTime Library.
*/ */
#include "tif_config.h" #include "tif_config.h"
#ifdef HAVE_SYS_TYPES_H #ifdef HAVE_SYS_TYPES_H
# include <sys/types.h> # include <sys/types.h>
#endif #endif
#include <errno.h>
#include <stdarg.h> #include <stdarg.h>
#include <stdlib.h> #include <stdlib.h>
#include <sys/stat.h> #include <sys/stat.h>
@ -46,57 +49,77 @@
# include <fcntl.h> # include <fcntl.h>
#endif #endif
#ifdef HAVE_IO_H
# include <io.h>
#endif
#include "tiffiop.h" #include "tiffiop.h"
static tsize_t static tmsize_t
_tiffReadProc(thandle_t fd, tdata_t buf, tsize_t size) _tiffReadProc(thandle_t fd, void* buf, tmsize_t size)
{ {
return ((tsize_t) read((int) fd, buf, (size_t) size)); size_t size_io = (size_t) size;
if ((tmsize_t) size_io != size)
{
errno=EINVAL;
return (tmsize_t) -1;
}
return ((tmsize_t) read((int) fd, buf, size_io));
} }
static tsize_t static tmsize_t
_tiffWriteProc(thandle_t fd, tdata_t buf, tsize_t size) _tiffWriteProc(thandle_t fd, void* buf, tmsize_t size)
{ {
return ((tsize_t) write((int) fd, buf, (size_t) size)); size_t size_io = (size_t) size;
if ((tmsize_t) size_io != size)
{
errno=EINVAL;
return (tmsize_t) -1;
}
return ((tmsize_t) write((int) fd, buf, size_io));
} }
static toff_t static uint64
_tiffSeekProc(thandle_t fd, toff_t off, int whence) _tiffSeekProc(thandle_t fd, uint64 off, int whence)
{ {
return ((toff_t) lseek((int) fd, (off_t) off, whence)); off_t off_io = (off_t) off;
if ((uint64) off_io != off)
{
errno=EINVAL;
return (uint64) -1; /* this is really gross */
}
return((uint64)lseek((int)fd,off_io,whence));
} }
static int static int
_tiffCloseProc(thandle_t fd) _tiffCloseProc(thandle_t fd)
{ {
return (close((int) fd)); return(close((int)fd));
} }
static uint64
static toff_t
_tiffSizeProc(thandle_t fd) _tiffSizeProc(thandle_t fd)
{ {
#ifdef _AM29K
long fsize;
return ((fsize = lseek((int) fd, 0, SEEK_END)) < 0 ? 0 : fsize);
#else
struct stat sb; struct stat sb;
return (toff_t) (fstat((int) fd, &sb) < 0 ? 0 : sb.st_size); if (fstat((int)fd,&sb)<0)
#endif return(0);
else
return((uint64)sb.st_size);
} }
#ifdef HAVE_MMAP #ifdef HAVE_MMAP
#include <sys/mman.h> #include <sys/mman.h>
static int static int
_tiffMapProc(thandle_t fd, tdata_t* pbase, toff_t* psize) _tiffMapProc(thandle_t fd, void** pbase, toff_t* psize)
{ {
toff_t size = _tiffSizeProc(fd); uint64 size64 = _tiffSizeProc(fd);
if (size != (toff_t) -1) { tmsize_t sizem = (tmsize_t)size64;
*pbase = (tdata_t) if ((uint64)sizem==size64) {
mmap(0, size, PROT_READ, MAP_SHARED, (int) fd, 0); *pbase = (void*)
if (*pbase != (tdata_t) -1) { mmap(0, (size_t)sizem, PROT_READ, MAP_SHARED, (int) fd, 0);
*psize = size; if (*pbase != (void*) -1) {
*psize = (tmsize_t)sizem;
return (1); return (1);
} }
} }
@ -104,21 +127,21 @@ _tiffMapProc(thandle_t fd, tdata_t* pbase, toff_t* psize)
} }
static void static void
_tiffUnmapProc(thandle_t fd, tdata_t base, toff_t size) _tiffUnmapProc(thandle_t fd, void* base, toff_t size)
{ {
(void) fd; (void) fd;
(void) munmap(base, (off_t) size); (void) munmap(base, (off_t) size);
} }
#else /* !HAVE_MMAP */ #else /* !HAVE_MMAP */
static int static int
_tiffMapProc(thandle_t fd, tdata_t* pbase, toff_t* psize) _tiffMapProc(thandle_t fd, void** pbase, toff_t* psize)
{ {
(void) fd; (void) pbase; (void) psize; (void) fd; (void) pbase; (void) psize;
return (0); return (0);
} }
static void static void
_tiffUnmapProc(thandle_t fd, tdata_t base, toff_t size) _tiffUnmapProc(thandle_t fd, void* base, toff_t size)
{ {
(void) fd; (void) base; (void) size; (void) fd; (void) base; (void) size;
} }
@ -150,22 +173,18 @@ TIFFOpen(const char* name, const char* mode)
{ {
static const char module[] = "TIFFOpen"; static const char module[] = "TIFFOpen";
int m, fd; int m, fd;
TIFF* tif; TIFF* tif;
m = _TIFFgetMode(mode, module); m = _TIFFgetMode(mode, module);
if (m == -1) if (m == -1)
return ((TIFF*)0); return ((TIFF*)0);
/* for cygwin and mingw */ /* for cygwin and mingw */
#ifdef O_BINARY #ifdef O_BINARY
m |= O_BINARY; m |= O_BINARY;
#endif
#ifdef _AM29K
fd = open(name, m);
#else
fd = open(name, m, 0666);
#endif #endif
fd = open(name, m, 0666);
if (fd < 0) { if (fd < 0) {
TIFFErrorExt(0, module, "%s: Cannot open", name); TIFFErrorExt(0, module, "%s: Cannot open", name);
return ((TIFF *)0); return ((TIFF *)0);
@ -195,11 +214,11 @@ TIFFOpenW(const wchar_t* name, const char* mode)
if (m == -1) if (m == -1)
return ((TIFF*)0); return ((TIFF*)0);
/* for cygwin and mingw */ /* for cygwin and mingw */
#ifdef O_BINARY #ifdef O_BINARY
m |= O_BINARY; m |= O_BINARY;
#endif #endif
fd = _wopen(name, m, 0666); fd = _wopen(name, m, 0666);
if (fd < 0) { if (fd < 0) {
TIFFErrorExt(0, module, "%s: Cannot open", name); TIFFErrorExt(0, module, "%s: Cannot open", name);
@ -232,37 +251,37 @@ TIFFOpenW(const wchar_t* name, const char* mode)
#endif #endif
void* void*
_TIFFmalloc(tsize_t s) _TIFFmalloc(tmsize_t s)
{ {
return (malloc((size_t) s)); return (malloc((size_t) s));
} }
void void
_TIFFfree(tdata_t p) _TIFFfree(void* p)
{ {
free(p); free(p);
} }
void* void*
_TIFFrealloc(tdata_t p, tsize_t s) _TIFFrealloc(void* p, tmsize_t s)
{ {
return (realloc(p, (size_t) s)); return (realloc(p, (size_t) s));
} }
void void
_TIFFmemset(tdata_t p, int v, tsize_t c) _TIFFmemset(void* p, int v, tmsize_t c)
{ {
memset(p, v, (size_t) c); memset(p, v, (size_t) c);
} }
void void
_TIFFmemcpy(tdata_t d, const tdata_t s, tsize_t c) _TIFFmemcpy(void* d, const void* s, tmsize_t c)
{ {
memcpy(d, s, (size_t) c); memcpy(d, s, (size_t) c);
} }
int int
_TIFFmemcmp(const tdata_t p1, const tdata_t p2, tsize_t c) _TIFFmemcmp(const void* p1, const void* p2, tmsize_t c)
{ {
return (memcmp(p1, p2, (size_t) c)); return (memcmp(p1, p2, (size_t) c));
} }
@ -287,6 +306,9 @@ unixErrorHandler(const char* module, const char* fmt, va_list ap)
fprintf(stderr, ".\n"); fprintf(stderr, ".\n");
} }
TIFFErrorHandler _TIFFerrorHandler = unixErrorHandler; TIFFErrorHandler _TIFFerrorHandler = unixErrorHandler;
/* vim: set ts=8 sts=8 sw=8 noet: */
/* /*
* Local Variables: * Local Variables:
* mode: c * mode: c

View File

@ -1,4 +1,4 @@
/* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/tif_version.c,v 1.2.2.1 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/tif_version.c,v 1.3 2010-03-10 18:56:49 bfriesen Exp $ */
/* /*
* Copyright (c) 1992-1997 Sam Leffler * Copyright (c) 1992-1997 Sam Leffler
* Copyright (c) 1992-1997 Silicon Graphics, Inc. * Copyright (c) 1992-1997 Silicon Graphics, Inc.

View File

@ -1,4 +1,4 @@
/* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/tif_warning.c,v 1.2.2.1 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Header: /cvs/maptools/cvsroot/libtiff/libtiff/tif_warning.c,v 1.3 2010-03-10 18:56:49 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler

View File

@ -1,4 +1,4 @@
/* $Id: tif_win32.c,v 1.21.2.1 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Id: tif_win32.c,v 1.39 2011-12-22 17:07:57 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -32,49 +32,91 @@
#include <windows.h> #include <windows.h>
static tsize_t static tmsize_t
_tiffReadProc(thandle_t fd, tdata_t buf, tsize_t size) _tiffReadProc(thandle_t fd, void* buf, tmsize_t size)
{ {
DWORD dwSizeRead; /* tmsize_t is 64bit on 64bit systems, but the WinAPI ReadFile takes
if (!ReadFile(fd, buf, size, &dwSizeRead, NULL)) * 32bit sizes, so we loop through the data in suitable 32bit sized
return(0); * chunks */
return ((tsize_t) dwSizeRead); uint8* ma;
uint64 mb;
DWORD n;
DWORD o;
tmsize_t p;
ma=(uint8*)buf;
mb=size;
p=0;
while (mb>0)
{
n=0x80000000UL;
if ((uint64)n>mb)
n=(DWORD)mb;
if (!ReadFile(fd,(LPVOID)ma,n,&o,NULL))
return(0);
ma+=o;
mb-=o;
p+=o;
if (o!=n)
break;
}
return(p);
} }
static tsize_t static tmsize_t
_tiffWriteProc(thandle_t fd, tdata_t buf, tsize_t size) _tiffWriteProc(thandle_t fd, void* buf, tmsize_t size)
{ {
DWORD dwSizeWritten; /* tmsize_t is 64bit on 64bit systems, but the WinAPI WriteFile takes
if (!WriteFile(fd, buf, size, &dwSizeWritten, NULL)) * 32bit sizes, so we loop through the data in suitable 32bit sized
return(0); * chunks */
return ((tsize_t) dwSizeWritten); uint8* ma;
uint64 mb;
DWORD n;
DWORD o;
tmsize_t p;
ma=(uint8*)buf;
mb=size;
p=0;
while (mb>0)
{
n=0x80000000UL;
if ((uint64)n>mb)
n=(DWORD)mb;
if (!WriteFile(fd,(LPVOID)ma,n,&o,NULL))
return(0);
ma+=o;
mb-=o;
p+=o;
if (o!=n)
break;
}
return(p);
} }
static toff_t static uint64
_tiffSeekProc(thandle_t fd, toff_t off, int whence) _tiffSeekProc(thandle_t fd, uint64 off, int whence)
{ {
ULARGE_INTEGER li; LARGE_INTEGER offli;
DWORD dwMoveMethod; DWORD dwMoveMethod;
offli.QuadPart = off;
li.QuadPart = off;
switch(whence) switch(whence)
{ {
case SEEK_SET: case SEEK_SET:
dwMoveMethod = FILE_BEGIN; dwMoveMethod = FILE_BEGIN;
break; break;
case SEEK_CUR: case SEEK_CUR:
dwMoveMethod = FILE_CURRENT; dwMoveMethod = FILE_CURRENT;
break; break;
case SEEK_END: case SEEK_END:
dwMoveMethod = FILE_END; dwMoveMethod = FILE_END;
break; break;
default: default:
dwMoveMethod = FILE_BEGIN; dwMoveMethod = FILE_BEGIN;
break; break;
} }
return ((toff_t)SetFilePointer(fd, (LONG) li.LowPart, offli.LowPart=SetFilePointer(fd,offli.LowPart,&offli.HighPart,dwMoveMethod);
(PLONG)&li.HighPart, dwMoveMethod)); if ((offli.LowPart==INVALID_SET_FILE_POINTER)&&(GetLastError()!=NO_ERROR))
offli.QuadPart=0;
return(offli.QuadPart);
} }
static int static int
@ -83,14 +125,16 @@ _tiffCloseProc(thandle_t fd)
return (CloseHandle(fd) ? 0 : -1); return (CloseHandle(fd) ? 0 : -1);
} }
static toff_t static uint64
_tiffSizeProc(thandle_t fd) _tiffSizeProc(thandle_t fd)
{ {
return ((toff_t)GetFileSize(fd, NULL)); ULARGE_INTEGER m;
m.LowPart=GetFileSize(fd,&m.HighPart);
return(m.QuadPart);
} }
static int static int
_tiffDummyMapProc(thandle_t fd, tdata_t* pbase, toff_t* psize) _tiffDummyMapProc(thandle_t fd, void** pbase, toff_t* psize)
{ {
(void) fd; (void) fd;
(void) pbase; (void) pbase;
@ -110,14 +154,20 @@ _tiffDummyMapProc(thandle_t fd, tdata_t* pbase, toff_t* psize)
* with Visual C++ 5.0 * with Visual C++ 5.0
*/ */
static int static int
_tiffMapProc(thandle_t fd, tdata_t* pbase, toff_t* psize) _tiffMapProc(thandle_t fd, void** pbase, toff_t* psize)
{ {
toff_t size; uint64 size;
tmsize_t sizem;
HANDLE hMapFile; HANDLE hMapFile;
if ((size = _tiffSizeProc(fd)) == 0xFFFFFFFF) size = _tiffSizeProc(fd);
sizem = (tmsize_t)size;
if ((uint64)sizem!=size)
return (0); return (0);
hMapFile = CreateFileMapping(fd, NULL, PAGE_READONLY, 0, size, NULL);
/* By passing in 0 for the maximum file size, it specifies that we
create a file mapping object for the full file size. */
hMapFile = CreateFileMapping(fd, NULL, PAGE_READONLY, 0, 0, NULL);
if (hMapFile == NULL) if (hMapFile == NULL)
return (0); return (0);
*pbase = MapViewOfFile(hMapFile, FILE_MAP_READ, 0, 0, 0); *pbase = MapViewOfFile(hMapFile, FILE_MAP_READ, 0, 0, 0);
@ -129,7 +179,7 @@ _tiffMapProc(thandle_t fd, tdata_t* pbase, toff_t* psize)
} }
static void static void
_tiffDummyUnmapProc(thandle_t fd, tdata_t base, toff_t size) _tiffDummyUnmapProc(thandle_t fd, void* base, toff_t size)
{ {
(void) fd; (void) fd;
(void) base; (void) base;
@ -137,8 +187,10 @@ _tiffDummyUnmapProc(thandle_t fd, tdata_t base, toff_t size)
} }
static void static void
_tiffUnmapProc(thandle_t fd, tdata_t base, toff_t size) _tiffUnmapProc(thandle_t fd, void* base, toff_t size)
{ {
(void) fd;
(void) size;
UnmapViewOfFile(base); UnmapViewOfFile(base);
} }
@ -151,8 +203,17 @@ TIFF*
TIFFFdOpen(int ifd, const char* name, const char* mode) TIFFFdOpen(int ifd, const char* name, const char* mode)
{ {
TIFF* tif; TIFF* tif;
BOOL fSuppressMap = (mode[1] == 'u' || (mode[1]!=0 && mode[2] == 'u')); int fSuppressMap;
int m;
fSuppressMap=0;
for (m=0; mode[m]!=0; m++)
{
if (mode[m]=='u')
{
fSuppressMap=1;
break;
}
}
tif = TIFFClientOpen(name, mode, (thandle_t)ifd, tif = TIFFClientOpen(name, mode, (thandle_t)ifd,
_tiffReadProc, _tiffWriteProc, _tiffReadProc, _tiffWriteProc,
_tiffSeekProc, _tiffCloseProc, _tiffSizeProc, _tiffSeekProc, _tiffCloseProc, _tiffSizeProc,
@ -179,26 +240,15 @@ TIFFOpen(const char* name, const char* mode)
m = _TIFFgetMode(mode, module); m = _TIFFgetMode(mode, module);
switch(m) switch(m) {
{ case O_RDONLY: dwMode = OPEN_EXISTING; break;
case O_RDONLY: case O_RDWR: dwMode = OPEN_ALWAYS; break;
dwMode = OPEN_EXISTING; case O_RDWR|O_CREAT: dwMode = OPEN_ALWAYS; break;
break; case O_RDWR|O_TRUNC: dwMode = CREATE_ALWAYS; break;
case O_RDWR: case O_RDWR|O_CREAT|O_TRUNC: dwMode = CREATE_ALWAYS; break;
dwMode = OPEN_ALWAYS; default: return ((TIFF*)0);
break;
case O_RDWR|O_CREAT:
dwMode = OPEN_ALWAYS;
break;
case O_RDWR|O_TRUNC:
dwMode = CREATE_ALWAYS;
break;
case O_RDWR|O_CREAT|O_TRUNC:
dwMode = CREATE_ALWAYS;
break;
default:
return ((TIFF*)0);
} }
fd = (thandle_t)CreateFileA(name, fd = (thandle_t)CreateFileA(name,
(m == O_RDONLY)?GENERIC_READ:(GENERIC_READ | GENERIC_WRITE), (m == O_RDONLY)?GENERIC_READ:(GENERIC_READ | GENERIC_WRITE),
FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, dwMode, FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, dwMode,
@ -242,7 +292,7 @@ TIFFOpenW(const wchar_t* name, const char* mode)
fd = (thandle_t)CreateFileW(name, fd = (thandle_t)CreateFileW(name,
(m == O_RDONLY)?GENERIC_READ:(GENERIC_READ|GENERIC_WRITE), (m == O_RDONLY)?GENERIC_READ:(GENERIC_READ|GENERIC_WRITE),
FILE_SHARE_READ, NULL, dwMode, FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, dwMode,
(m == O_RDONLY)?FILE_ATTRIBUTE_READONLY:FILE_ATTRIBUTE_NORMAL, (m == O_RDONLY)?FILE_ATTRIBUTE_READONLY:FILE_ATTRIBUTE_NORMAL,
NULL); NULL);
if (fd == INVALID_HANDLE_VALUE) { if (fd == INVALID_HANDLE_VALUE) {
@ -276,71 +326,48 @@ TIFFOpenW(const wchar_t* name, const char* mode)
#endif /* ndef _WIN32_WCE */ #endif /* ndef _WIN32_WCE */
void*
tdata_t _TIFFmalloc(tmsize_t s)
_TIFFmalloc(tsize_t s)
{ {
return ((tdata_t)GlobalAlloc(GMEM_FIXED, s)); return (malloc((size_t) s));
} }
void void
_TIFFfree(tdata_t p) _TIFFfree(void* p)
{ {
GlobalFree(p); free(p);
return;
} }
tdata_t void*
_TIFFrealloc(tdata_t p, tsize_t s) _TIFFrealloc(void* p, tmsize_t s)
{ {
void* pvTmp; return (realloc(p, (size_t) s));
tsize_t old;
if(p == NULL)
return ((tdata_t)GlobalAlloc(GMEM_FIXED, s));
old = GlobalSize(p);
if (old>=s) {
if ((pvTmp = GlobalAlloc(GMEM_FIXED, s)) != NULL) {
CopyMemory(pvTmp, p, s);
GlobalFree(p);
}
} else {
if ((pvTmp = GlobalAlloc(GMEM_FIXED, s)) != NULL) {
CopyMemory(pvTmp, p, old);
GlobalFree(p);
}
}
return ((tdata_t)pvTmp);
} }
void void
_TIFFmemset(void* p, int v, tsize_t c) _TIFFmemset(void* p, int v, tmsize_t c)
{ {
FillMemory(p, c, (BYTE)v); memset(p, v, (size_t) c);
} }
void void
_TIFFmemcpy(void* d, const tdata_t s, tsize_t c) _TIFFmemcpy(void* d, const void* s, tmsize_t c)
{ {
CopyMemory(d, s, c); memcpy(d, s, (size_t) c);
} }
int int
_TIFFmemcmp(const tdata_t p1, const tdata_t p2, tsize_t c) _TIFFmemcmp(const void* p1, const void* p2, tmsize_t c)
{ {
register const BYTE *pb1 = (const BYTE *) p1; return (memcmp(p1, p2, (size_t) c));
register const BYTE *pb2 = (const BYTE *) p2;
register DWORD dwTmp = c;
register int iTmp;
for (iTmp = 0; dwTmp-- && !iTmp; iTmp = (int)*pb1++ - (int)*pb2++)
;
return (iTmp);
} }
#ifndef _WIN32_WCE #ifndef _WIN32_WCE
#if (_MSC_VER < 1500)
# define vsnprintf _vsnprintf
#endif
static void static void
Win32WarningHandler(const char* module, const char* fmt, va_list ap) Win32WarningHandler(const char* module, const char* fmt, va_list ap)
{ {
@ -350,14 +377,17 @@ Win32WarningHandler(const char* module, const char* fmt, va_list ap)
LPCTSTR szTitleText = "%s Warning"; LPCTSTR szTitleText = "%s Warning";
LPCTSTR szDefaultModule = "LIBTIFF"; LPCTSTR szDefaultModule = "LIBTIFF";
LPCTSTR szTmpModule = (module == NULL) ? szDefaultModule : module; LPCTSTR szTmpModule = (module == NULL) ? szDefaultModule : module;
if ((szTitle = (LPTSTR)LocalAlloc(LMEM_FIXED, (strlen(szTmpModule) + SIZE_T nBufSize = (strlen(szTmpModule) +
strlen(szTitleText) + strlen(fmt) + 128)*sizeof(char))) == NULL) strlen(szTitleText) + strlen(fmt) + 256)*sizeof(char);
if ((szTitle = (LPTSTR)LocalAlloc(LMEM_FIXED, nBufSize)) == NULL)
return; return;
sprintf(szTitle, szTitleText, szTmpModule); sprintf(szTitle, szTitleText, szTmpModule);
szTmp = szTitle + (strlen(szTitle)+2)*sizeof(char); szTmp = szTitle + (strlen(szTitle)+2)*sizeof(char);
vsprintf(szTmp, fmt, ap); vsnprintf(szTmp, nBufSize-(strlen(szTitle)+2)*sizeof(char), fmt, ap);
MessageBoxA(GetFocus(), szTmp, szTitle, MB_OK | MB_ICONINFORMATION); MessageBoxA(GetFocus(), szTmp, szTitle, MB_OK | MB_ICONINFORMATION);
LocalFree(szTitle); LocalFree(szTitle);
return; return;
#else #else
if (module != NULL) if (module != NULL)
@ -378,12 +408,14 @@ Win32ErrorHandler(const char* module, const char* fmt, va_list ap)
LPCTSTR szTitleText = "%s Error"; LPCTSTR szTitleText = "%s Error";
LPCTSTR szDefaultModule = "LIBTIFF"; LPCTSTR szDefaultModule = "LIBTIFF";
LPCTSTR szTmpModule = (module == NULL) ? szDefaultModule : module; LPCTSTR szTmpModule = (module == NULL) ? szDefaultModule : module;
if ((szTitle = (LPTSTR)LocalAlloc(LMEM_FIXED, (strlen(szTmpModule) + SIZE_T nBufSize = (strlen(szTmpModule) +
strlen(szTitleText) + strlen(fmt) + 128)*sizeof(char))) == NULL) strlen(szTitleText) + strlen(fmt) + 256)*sizeof(char);
if ((szTitle = (LPTSTR)LocalAlloc(LMEM_FIXED, nBufSize)) == NULL)
return; return;
sprintf(szTitle, szTitleText, szTmpModule); sprintf(szTitle, szTitleText, szTmpModule);
szTmp = szTitle + (strlen(szTitle)+2)*sizeof(char); szTmp = szTitle + (strlen(szTitle)+2)*sizeof(char);
vsprintf(szTmp, fmt, ap); vsnprintf(szTmp, nBufSize-(strlen(szTitle)+2)*sizeof(char), fmt, ap);
MessageBoxA(GetFocus(), szTmp, szTitle, MB_OK | MB_ICONEXCLAMATION); MessageBoxA(GetFocus(), szTmp, szTitle, MB_OK | MB_ICONEXCLAMATION);
LocalFree(szTitle); LocalFree(szTitle);
return; return;

View File

@ -1,26 +1,26 @@
/* $Id: tif_write.c,v 1.22.2.5 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Id: tif_write.c,v 1.36 2011-02-18 20:53:04 fwarmerdam Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
* Copyright (c) 1991-1997 Silicon Graphics, Inc. * Copyright (c) 1991-1997 Silicon Graphics, Inc.
* *
* Permission to use, copy, modify, distribute, and sell this software and * Permission to use, copy, modify, distribute, and sell this software and
* its documentation for any purpose is hereby granted without fee, provided * its documentation for any purpose is hereby granted without fee, provided
* that (i) the above copyright notices and this permission notice appear in * that (i) the above copyright notices and this permission notice appear in
* all copies of the software and related documentation, and (ii) the names of * all copies of the software and related documentation, and (ii) the names of
* Sam Leffler and Silicon Graphics may not be used in any advertising or * Sam Leffler and Silicon Graphics may not be used in any advertising or
* publicity relating to the software without the specific, prior written * publicity relating to the software without the specific, prior written
* permission of Sam Leffler and Silicon Graphics. * permission of Sam Leffler and Silicon Graphics.
* *
* THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND, * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
* EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
* WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
* *
* IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
* ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
* OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
* WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
* LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
* OF THIS SOFTWARE. * OF THIS SOFTWARE.
*/ */
@ -32,26 +32,26 @@
#include "tiffiop.h" #include "tiffiop.h"
#include <stdio.h> #include <stdio.h>
#define STRIPINCR 20 /* expansion factor on strip array */ #define STRIPINCR 20 /* expansion factor on strip array */
#define WRITECHECKSTRIPS(tif, module) \ #define WRITECHECKSTRIPS(tif, module) \
(((tif)->tif_flags&TIFF_BEENWRITING) || TIFFWriteCheck((tif),0,module)) (((tif)->tif_flags&TIFF_BEENWRITING) || TIFFWriteCheck((tif),0,module))
#define WRITECHECKTILES(tif, module) \ #define WRITECHECKTILES(tif, module) \
(((tif)->tif_flags&TIFF_BEENWRITING) || TIFFWriteCheck((tif),1,module)) (((tif)->tif_flags&TIFF_BEENWRITING) || TIFFWriteCheck((tif),1,module))
#define BUFFERCHECK(tif) \ #define BUFFERCHECK(tif) \
((((tif)->tif_flags & TIFF_BUFFERSETUP) && tif->tif_rawdata) || \ ((((tif)->tif_flags & TIFF_BUFFERSETUP) && tif->tif_rawdata) || \
TIFFWriteBufferSetup((tif), NULL, (tsize_t) -1)) TIFFWriteBufferSetup((tif), NULL, (tmsize_t) -1))
static int TIFFGrowStrips(TIFF*, int, const char*); static int TIFFGrowStrips(TIFF* tif, uint32 delta, const char* module);
static int TIFFAppendToStrip(TIFF*, tstrip_t, tidata_t, tsize_t); static int TIFFAppendToStrip(TIFF* tif, uint32 strip, uint8* data, tmsize_t cc);
int int
TIFFWriteScanline(TIFF* tif, tdata_t buf, uint32 row, tsample_t sample) TIFFWriteScanline(TIFF* tif, void* buf, uint32 row, uint16 sample)
{ {
static const char module[] = "TIFFWriteScanline"; static const char module[] = "TIFFWriteScanline";
register TIFFDirectory *td; register TIFFDirectory *td;
int status, imagegrew = 0; int status, imagegrew = 0;
tstrip_t strip; uint32 strip;
if (!WRITECHECKSTRIPS(tif, module)) if (!WRITECHECKSTRIPS(tif, module))
return (-1); return (-1);
@ -62,6 +62,8 @@ TIFFWriteScanline(TIFF* tif, tdata_t buf, uint32 row, tsample_t sample)
*/ */
if (!BUFFERCHECK(tif)) if (!BUFFERCHECK(tif))
return (-1); return (-1);
tif->tif_flags |= TIFF_BUF4WRITE; /* not strictly sure this is right*/
td = &tif->tif_dir; td = &tif->tif_dir;
/* /*
* Extend image length if needed * Extend image length if needed
@ -69,8 +71,8 @@ TIFFWriteScanline(TIFF* tif, tdata_t buf, uint32 row, tsample_t sample)
*/ */
if (row >= td->td_imagelength) { /* extend image */ if (row >= td->td_imagelength) { /* extend image */
if (td->td_planarconfig == PLANARCONFIG_SEPARATE) { if (td->td_planarconfig == PLANARCONFIG_SEPARATE) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"Can not change \"ImageLength\" when using separate planes"); "Can not change \"ImageLength\" when using separate planes");
return (-1); return (-1);
} }
td->td_imagelength = row+1; td->td_imagelength = row+1;
@ -81,9 +83,9 @@ TIFFWriteScanline(TIFF* tif, tdata_t buf, uint32 row, tsample_t sample)
*/ */
if (td->td_planarconfig == PLANARCONFIG_SEPARATE) { if (td->td_planarconfig == PLANARCONFIG_SEPARATE) {
if (sample >= td->td_samplesperpixel) { if (sample >= td->td_samplesperpixel) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"%d: Sample out of range, max %d", "%lu: Sample out of range, max %lu",
sample, td->td_samplesperpixel); (unsigned long) sample, (unsigned long) td->td_samplesperpixel);
return (-1); return (-1);
} }
strip = sample*td->td_stripsperimage + row/td->td_rowsperstrip; strip = sample*td->td_stripsperimage + row/td->td_rowsperstrip;
@ -112,7 +114,7 @@ TIFFWriteScanline(TIFF* tif, tdata_t buf, uint32 row, tsample_t sample)
*/ */
if (strip >= td->td_stripsperimage && imagegrew) if (strip >= td->td_stripsperimage && imagegrew)
td->td_stripsperimage = td->td_stripsperimage =
TIFFhowmany(td->td_imagelength,td->td_rowsperstrip); TIFFhowmany_32(td->td_imagelength,td->td_rowsperstrip);
tif->tif_row = tif->tif_row =
(strip % td->td_stripsperimage) * td->td_rowsperstrip; (strip % td->td_stripsperimage) * td->td_rowsperstrip;
if ((tif->tif_flags & TIFF_CODERSETUP) == 0) { if ((tif->tif_flags & TIFF_CODERSETUP) == 0) {
@ -161,10 +163,10 @@ TIFFWriteScanline(TIFF* tif, tdata_t buf, uint32 row, tsample_t sample)
tif->tif_row = row; tif->tif_row = row;
} }
/* swab if needed - note that source buffer will be altered */ /* swab if needed - note that source buffer will be altered */
tif->tif_postdecode( tif, (tidata_t) buf, tif->tif_scanlinesize ); tif->tif_postdecode( tif, (uint8*) buf, tif->tif_scanlinesize );
status = (*tif->tif_encoderow)(tif, (tidata_t) buf, status = (*tif->tif_encoderow)(tif, (uint8*) buf,
tif->tif_scanlinesize, sample); tif->tif_scanlinesize, sample);
/* we are now poised at the beginning of the next row */ /* we are now poised at the beginning of the next row */
@ -178,15 +180,15 @@ TIFFWriteScanline(TIFF* tif, tdata_t buf, uint32 row, tsample_t sample)
* *
* NB: Image length must be setup before writing. * NB: Image length must be setup before writing.
*/ */
tsize_t tmsize_t
TIFFWriteEncodedStrip(TIFF* tif, tstrip_t strip, tdata_t data, tsize_t cc) TIFFWriteEncodedStrip(TIFF* tif, uint32 strip, void* data, tmsize_t cc)
{ {
static const char module[] = "TIFFWriteEncodedStrip"; static const char module[] = "TIFFWriteEncodedStrip";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
tsample_t sample; uint16 sample;
if (!WRITECHECKSTRIPS(tif, module)) if (!WRITECHECKSTRIPS(tif, module))
return ((tsize_t) -1); return ((tmsize_t) -1);
/* /*
* Check strip array to make sure there's space. * Check strip array to make sure there's space.
* We don't support dynamically growing files that * We don't support dynamically growing files that
@ -198,14 +200,14 @@ TIFFWriteEncodedStrip(TIFF* tif, tstrip_t strip, tdata_t data, tsize_t cc)
*/ */
if (strip >= td->td_nstrips) { if (strip >= td->td_nstrips) {
if (td->td_planarconfig == PLANARCONFIG_SEPARATE) { if (td->td_planarconfig == PLANARCONFIG_SEPARATE) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"Can not grow image by strips when using separate planes"); "Can not grow image by strips when using separate planes");
return ((tsize_t) -1); return ((tmsize_t) -1);
} }
if (!TIFFGrowStrips(tif, 1, module)) if (!TIFFGrowStrips(tif, 1, module))
return ((tsize_t) -1); return ((tmsize_t) -1);
td->td_stripsperimage = td->td_stripsperimage =
TIFFhowmany(td->td_imagelength, td->td_rowsperstrip); TIFFhowmany_32(td->td_imagelength, td->td_rowsperstrip);
} }
/* /*
* Handle delayed allocation of data buffer. This * Handle delayed allocation of data buffer. This
@ -213,19 +215,22 @@ TIFFWriteEncodedStrip(TIFF* tif, tstrip_t strip, tdata_t data, tsize_t cc)
* info. * info.
*/ */
if (!BUFFERCHECK(tif)) if (!BUFFERCHECK(tif))
return ((tsize_t) -1); return ((tmsize_t) -1);
tif->tif_flags |= TIFF_BUF4WRITE;
tif->tif_curstrip = strip; tif->tif_curstrip = strip;
tif->tif_row = (strip % td->td_stripsperimage) * td->td_rowsperstrip; tif->tif_row = (strip % td->td_stripsperimage) * td->td_rowsperstrip;
if ((tif->tif_flags & TIFF_CODERSETUP) == 0) { if ((tif->tif_flags & TIFF_CODERSETUP) == 0) {
if (!(*tif->tif_setupencode)(tif)) if (!(*tif->tif_setupencode)(tif))
return ((tsize_t) -1); return ((tmsize_t) -1);
tif->tif_flags |= TIFF_CODERSETUP; tif->tif_flags |= TIFF_CODERSETUP;
} }
tif->tif_rawcc = 0; tif->tif_rawcc = 0;
tif->tif_rawcp = tif->tif_rawdata; tif->tif_rawcp = tif->tif_rawdata;
if( td->td_stripbytecount[strip] > 0 ) if( td->td_stripbytecount[strip] > 0 )
{ {
/* Force TIFFAppendToStrip() to consider placing data at end /* Force TIFFAppendToStrip() to consider placing data at end
of file. */ of file. */
@ -233,23 +238,23 @@ TIFFWriteEncodedStrip(TIFF* tif, tstrip_t strip, tdata_t data, tsize_t cc)
} }
tif->tif_flags &= ~TIFF_POSTENCODE; tif->tif_flags &= ~TIFF_POSTENCODE;
sample = (tsample_t)(strip / td->td_stripsperimage); sample = (uint16)(strip / td->td_stripsperimage);
if (!(*tif->tif_preencode)(tif, sample)) if (!(*tif->tif_preencode)(tif, sample))
return ((tsize_t) -1); return ((tmsize_t) -1);
/* swab if needed - note that source buffer will be altered */ /* swab if needed - note that source buffer will be altered */
tif->tif_postdecode( tif, (tidata_t) data, cc ); tif->tif_postdecode( tif, (uint8*) data, cc );
if (!(*tif->tif_encodestrip)(tif, (tidata_t) data, cc, sample)) if (!(*tif->tif_encodestrip)(tif, (uint8*) data, cc, sample))
return ((tsize_t) 0); return (0);
if (!(*tif->tif_postencode)(tif)) if (!(*tif->tif_postencode)(tif))
return ((tsize_t) -1); return ((tmsize_t) -1);
if (!isFillOrder(tif, td->td_fillorder) && if (!isFillOrder(tif, td->td_fillorder) &&
(tif->tif_flags & TIFF_NOBITREV) == 0) (tif->tif_flags & TIFF_NOBITREV) == 0)
TIFFReverseBits(tif->tif_rawdata, tif->tif_rawcc); TIFFReverseBits(tif->tif_rawdata, tif->tif_rawcc);
if (tif->tif_rawcc > 0 && if (tif->tif_rawcc > 0 &&
!TIFFAppendToStrip(tif, strip, tif->tif_rawdata, tif->tif_rawcc)) !TIFFAppendToStrip(tif, strip, tif->tif_rawdata, tif->tif_rawcc))
return ((tsize_t) -1); return ((tmsize_t) -1);
tif->tif_rawcc = 0; tif->tif_rawcc = 0;
tif->tif_rawcp = tif->tif_rawdata; tif->tif_rawcp = tif->tif_rawdata;
return (cc); return (cc);
@ -260,14 +265,14 @@ TIFFWriteEncodedStrip(TIFF* tif, tstrip_t strip, tdata_t data, tsize_t cc)
* *
* NB: Image length must be setup before writing. * NB: Image length must be setup before writing.
*/ */
tsize_t tmsize_t
TIFFWriteRawStrip(TIFF* tif, tstrip_t strip, tdata_t data, tsize_t cc) TIFFWriteRawStrip(TIFF* tif, uint32 strip, void* data, tmsize_t cc)
{ {
static const char module[] = "TIFFWriteRawStrip"; static const char module[] = "TIFFWriteRawStrip";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
if (!WRITECHECKSTRIPS(tif, module)) if (!WRITECHECKSTRIPS(tif, module))
return ((tsize_t) -1); return ((tmsize_t) -1);
/* /*
* Check strip array to make sure there's space. * Check strip array to make sure there's space.
* We don't support dynamically growing files that * We don't support dynamically growing files that
@ -279,9 +284,9 @@ TIFFWriteRawStrip(TIFF* tif, tstrip_t strip, tdata_t data, tsize_t cc)
*/ */
if (strip >= td->td_nstrips) { if (strip >= td->td_nstrips) {
if (td->td_planarconfig == PLANARCONFIG_SEPARATE) { if (td->td_planarconfig == PLANARCONFIG_SEPARATE) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, TIFFErrorExt(tif->tif_clientdata, module,
"Can not grow image by strips when using separate planes"); "Can not grow image by strips when using separate planes");
return ((tsize_t) -1); return ((tmsize_t) -1);
} }
/* /*
* Watch out for a growing image. The value of * Watch out for a growing image. The value of
@ -290,26 +295,25 @@ TIFFWriteRawStrip(TIFF* tif, tstrip_t strip, tdata_t data, tsize_t cc)
*/ */
if (strip >= td->td_stripsperimage) if (strip >= td->td_stripsperimage)
td->td_stripsperimage = td->td_stripsperimage =
TIFFhowmany(td->td_imagelength,td->td_rowsperstrip); TIFFhowmany_32(td->td_imagelength,td->td_rowsperstrip);
if (!TIFFGrowStrips(tif, 1, module)) if (!TIFFGrowStrips(tif, 1, module))
return ((tsize_t) -1); return ((tmsize_t) -1);
} }
tif->tif_curstrip = strip; tif->tif_curstrip = strip;
tif->tif_row = (strip % td->td_stripsperimage) * td->td_rowsperstrip; tif->tif_row = (strip % td->td_stripsperimage) * td->td_rowsperstrip;
return (TIFFAppendToStrip(tif, strip, (tidata_t) data, cc) ? return (TIFFAppendToStrip(tif, strip, (uint8*) data, cc) ?
cc : (tsize_t) -1); cc : (tmsize_t) -1);
} }
/* /*
* Write and compress a tile of data. The * Write and compress a tile of data. The
* tile is selected by the (x,y,z,s) coordinates. * tile is selected by the (x,y,z,s) coordinates.
*/ */
tsize_t tmsize_t
TIFFWriteTile(TIFF* tif, TIFFWriteTile(TIFF* tif, void* buf, uint32 x, uint32 y, uint32 z, uint16 s)
tdata_t buf, uint32 x, uint32 y, uint32 z, tsample_t s)
{ {
if (!TIFFCheckTile(tif, x, y, z, s)) if (!TIFFCheckTile(tif, x, y, z, s))
return (-1); return ((tmsize_t)(-1));
/* /*
* NB: A tile size of -1 is used instead of tif_tilesize knowing * NB: A tile size of -1 is used instead of tif_tilesize knowing
* that TIFFWriteEncodedTile will clamp this to the tile size. * that TIFFWriteEncodedTile will clamp this to the tile size.
@ -317,7 +321,7 @@ TIFFWriteTile(TIFF* tif,
* after the output buffer is setup in TIFFWriteBufferSetup. * after the output buffer is setup in TIFFWriteBufferSetup.
*/ */
return (TIFFWriteEncodedTile(tif, return (TIFFWriteEncodedTile(tif,
TIFFComputeTile(tif, x, y, z, s), buf, (tsize_t) -1)); TIFFComputeTile(tif, x, y, z, s), buf, (tmsize_t)(-1)));
} }
/* /*
@ -332,20 +336,20 @@ TIFFWriteTile(TIFF* tif,
* interface does not support automatically growing * interface does not support automatically growing
* the image on each write (as TIFFWriteScanline does). * the image on each write (as TIFFWriteScanline does).
*/ */
tsize_t tmsize_t
TIFFWriteEncodedTile(TIFF* tif, ttile_t tile, tdata_t data, tsize_t cc) TIFFWriteEncodedTile(TIFF* tif, uint32 tile, void* data, tmsize_t cc)
{ {
static const char module[] = "TIFFWriteEncodedTile"; static const char module[] = "TIFFWriteEncodedTile";
TIFFDirectory *td; TIFFDirectory *td;
tsample_t sample; uint16 sample;
if (!WRITECHECKTILES(tif, module)) if (!WRITECHECKTILES(tif, module))
return ((tsize_t) -1); return ((tmsize_t)(-1));
td = &tif->tif_dir; td = &tif->tif_dir;
if (tile >= td->td_nstrips) { if (tile >= td->td_nstrips) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: Tile %lu out of range, max %lu", TIFFErrorExt(tif->tif_clientdata, module, "Tile %lu out of range, max %lu",
tif->tif_name, (unsigned long) tile, (unsigned long) td->td_nstrips); (unsigned long) tile, (unsigned long) td->td_nstrips);
return ((tsize_t) -1); return ((tmsize_t)(-1));
} }
/* /*
* Handle delayed allocation of data buffer. This * Handle delayed allocation of data buffer. This
@ -353,13 +357,15 @@ TIFFWriteEncodedTile(TIFF* tif, ttile_t tile, tdata_t data, tsize_t cc)
* directory information). * directory information).
*/ */
if (!BUFFERCHECK(tif)) if (!BUFFERCHECK(tif))
return ((tsize_t) -1); return ((tmsize_t)(-1));
tif->tif_flags |= TIFF_BUF4WRITE;
tif->tif_curtile = tile; tif->tif_curtile = tile;
tif->tif_rawcc = 0; tif->tif_rawcc = 0;
tif->tif_rawcp = tif->tif_rawdata; tif->tif_rawcp = tif->tif_rawdata;
if( td->td_stripbytecount[tile] > 0 ) if( td->td_stripbytecount[tile] > 0 )
{ {
/* Force TIFFAppendToStrip() to consider placing data at end /* Force TIFFAppendToStrip() to consider placing data at end
of file. */ of file. */
@ -370,20 +376,20 @@ TIFFWriteEncodedTile(TIFF* tif, ttile_t tile, tdata_t data, tsize_t cc)
* Compute tiles per row & per column to compute * Compute tiles per row & per column to compute
* current row and column * current row and column
*/ */
tif->tif_row = (tile % TIFFhowmany(td->td_imagelength, td->td_tilelength)) tif->tif_row = (tile % TIFFhowmany_32(td->td_imagelength, td->td_tilelength))
* td->td_tilelength; * td->td_tilelength;
tif->tif_col = (tile % TIFFhowmany(td->td_imagewidth, td->td_tilewidth)) tif->tif_col = (tile % TIFFhowmany_32(td->td_imagewidth, td->td_tilewidth))
* td->td_tilewidth; * td->td_tilewidth;
if ((tif->tif_flags & TIFF_CODERSETUP) == 0) { if ((tif->tif_flags & TIFF_CODERSETUP) == 0) {
if (!(*tif->tif_setupencode)(tif)) if (!(*tif->tif_setupencode)(tif))
return ((tsize_t) -1); return ((tmsize_t)(-1));
tif->tif_flags |= TIFF_CODERSETUP; tif->tif_flags |= TIFF_CODERSETUP;
} }
tif->tif_flags &= ~TIFF_POSTENCODE; tif->tif_flags &= ~TIFF_POSTENCODE;
sample = (tsample_t)(tile/td->td_stripsperimage); sample = (uint16)(tile/td->td_stripsperimage);
if (!(*tif->tif_preencode)(tif, sample)) if (!(*tif->tif_preencode)(tif, sample))
return ((tsize_t) -1); return ((tmsize_t)(-1));
/* /*
* Clamp write amount to the tile size. This is mostly * Clamp write amount to the tile size. This is mostly
* done so that callers can pass in some large number * done so that callers can pass in some large number
@ -393,18 +399,18 @@ TIFFWriteEncodedTile(TIFF* tif, ttile_t tile, tdata_t data, tsize_t cc)
cc = tif->tif_tilesize; cc = tif->tif_tilesize;
/* swab if needed - note that source buffer will be altered */ /* swab if needed - note that source buffer will be altered */
tif->tif_postdecode( tif, (tidata_t) data, cc ); tif->tif_postdecode( tif, (uint8*) data, cc );
if (!(*tif->tif_encodetile)(tif, (tidata_t) data, cc, sample)) if (!(*tif->tif_encodetile)(tif, (uint8*) data, cc, sample))
return ((tsize_t) 0); return (0);
if (!(*tif->tif_postencode)(tif)) if (!(*tif->tif_postencode)(tif))
return ((tsize_t) -1); return ((tmsize_t)(-1));
if (!isFillOrder(tif, td->td_fillorder) && if (!isFillOrder(tif, td->td_fillorder) &&
(tif->tif_flags & TIFF_NOBITREV) == 0) (tif->tif_flags & TIFF_NOBITREV) == 0)
TIFFReverseBits((unsigned char *)tif->tif_rawdata, tif->tif_rawcc); TIFFReverseBits((uint8*)tif->tif_rawdata, tif->tif_rawcc);
if (tif->tif_rawcc > 0 && !TIFFAppendToStrip(tif, tile, if (tif->tif_rawcc > 0 && !TIFFAppendToStrip(tif, tile,
tif->tif_rawdata, tif->tif_rawcc)) tif->tif_rawdata, tif->tif_rawcc))
return ((tsize_t) -1); return ((tmsize_t)(-1));
tif->tif_rawcc = 0; tif->tif_rawcc = 0;
tif->tif_rawcp = tif->tif_rawdata; tif->tif_rawcp = tif->tif_rawdata;
return (cc); return (cc);
@ -419,21 +425,21 @@ TIFFWriteEncodedTile(TIFF* tif, ttile_t tile, tdata_t data, tsize_t cc)
* interface does not support automatically growing * interface does not support automatically growing
* the image on each write (as TIFFWriteScanline does). * the image on each write (as TIFFWriteScanline does).
*/ */
tsize_t tmsize_t
TIFFWriteRawTile(TIFF* tif, ttile_t tile, tdata_t data, tsize_t cc) TIFFWriteRawTile(TIFF* tif, uint32 tile, void* data, tmsize_t cc)
{ {
static const char module[] = "TIFFWriteRawTile"; static const char module[] = "TIFFWriteRawTile";
if (!WRITECHECKTILES(tif, module)) if (!WRITECHECKTILES(tif, module))
return ((tsize_t) -1); return ((tmsize_t)(-1));
if (tile >= tif->tif_dir.td_nstrips) { if (tile >= tif->tif_dir.td_nstrips) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: Tile %lu out of range, max %lu", TIFFErrorExt(tif->tif_clientdata, module, "Tile %lu out of range, max %lu",
tif->tif_name, (unsigned long) tile, (unsigned long) tile,
(unsigned long) tif->tif_dir.td_nstrips); (unsigned long) tif->tif_dir.td_nstrips);
return ((tsize_t) -1); return ((tmsize_t)(-1));
} }
return (TIFFAppendToStrip(tif, tile, (tidata_t) data, cc) ? return (TIFFAppendToStrip(tif, tile, (uint8*) data, cc) ?
cc : (tsize_t) -1); cc : (tmsize_t)(-1));
} }
#define isUnspecified(tif, f) \ #define isUnspecified(tif, f) \
@ -455,18 +461,18 @@ TIFFSetupStrips(TIFF* tif)
td->td_nstrips = td->td_stripsperimage; td->td_nstrips = td->td_stripsperimage;
if (td->td_planarconfig == PLANARCONFIG_SEPARATE) if (td->td_planarconfig == PLANARCONFIG_SEPARATE)
td->td_stripsperimage /= td->td_samplesperpixel; td->td_stripsperimage /= td->td_samplesperpixel;
td->td_stripoffset = (uint32 *) td->td_stripoffset = (uint64 *)
_TIFFmalloc(td->td_nstrips * sizeof (uint32)); _TIFFmalloc(td->td_nstrips * sizeof (uint64));
td->td_stripbytecount = (uint32 *) td->td_stripbytecount = (uint64 *)
_TIFFmalloc(td->td_nstrips * sizeof (uint32)); _TIFFmalloc(td->td_nstrips * sizeof (uint64));
if (td->td_stripoffset == NULL || td->td_stripbytecount == NULL) if (td->td_stripoffset == NULL || td->td_stripbytecount == NULL)
return (0); return (0);
/* /*
* Place data at the end-of-file * Place data at the end-of-file
* (by setting offsets to zero). * (by setting offsets to zero).
*/ */
_TIFFmemset(td->td_stripoffset, 0, td->td_nstrips*sizeof (uint32)); _TIFFmemset(td->td_stripoffset, 0, td->td_nstrips*sizeof (uint64));
_TIFFmemset(td->td_stripbytecount, 0, td->td_nstrips*sizeof (uint32)); _TIFFmemset(td->td_stripbytecount, 0, td->td_nstrips*sizeof (uint64));
TIFFSetFieldBit(tif, FIELD_STRIPOFFSETS); TIFFSetFieldBit(tif, FIELD_STRIPOFFSETS);
TIFFSetFieldBit(tif, FIELD_STRIPBYTECOUNTS); TIFFSetFieldBit(tif, FIELD_STRIPBYTECOUNTS);
return (1); return (1);
@ -483,16 +489,17 @@ int
TIFFWriteCheck(TIFF* tif, int tiles, const char* module) TIFFWriteCheck(TIFF* tif, int tiles, const char* module)
{ {
if (tif->tif_mode == O_RDONLY) { if (tif->tif_mode == O_RDONLY) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: File not open for writing", TIFFErrorExt(tif->tif_clientdata, module, "File not open for writing");
tif->tif_name);
return (0); return (0);
} }
if (tiles ^ isTiled(tif)) { if (tiles ^ isTiled(tif)) {
TIFFErrorExt(tif->tif_clientdata, tif->tif_name, tiles ? TIFFErrorExt(tif->tif_clientdata, module, tiles ?
"Can not write tiles to a stripped image" : "Can not write tiles to a stripped image" :
"Can not write scanlines to a tiled image"); "Can not write scanlines to a tiled image");
return (0); return (0);
} }
_TIFFFillStriles( tif );
/* /*
* On the first write verify all the required information * On the first write verify all the required information
@ -506,8 +513,7 @@ TIFFWriteCheck(TIFF* tif, int tiles, const char* module)
*/ */
if (!TIFFFieldSet(tif, FIELD_IMAGEDIMENSIONS)) { if (!TIFFFieldSet(tif, FIELD_IMAGEDIMENSIONS)) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"%s: Must set \"ImageWidth\" before writing data", "Must set \"ImageWidth\" before writing data");
tif->tif_name);
return (0); return (0);
} }
if (tif->tif_dir.td_samplesperpixel == 1) { if (tif->tif_dir.td_samplesperpixel == 1) {
@ -522,19 +528,27 @@ TIFFWriteCheck(TIFF* tif, int tiles, const char* module)
} else { } else {
if (!TIFFFieldSet(tif, FIELD_PLANARCONFIG)) { if (!TIFFFieldSet(tif, FIELD_PLANARCONFIG)) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"%s: Must set \"PlanarConfiguration\" before writing data", "Must set \"PlanarConfiguration\" before writing data");
tif->tif_name);
return (0); return (0);
} }
} }
if (tif->tif_dir.td_stripoffset == NULL && !TIFFSetupStrips(tif)) { if (tif->tif_dir.td_stripoffset == NULL && !TIFFSetupStrips(tif)) {
tif->tif_dir.td_nstrips = 0; tif->tif_dir.td_nstrips = 0;
TIFFErrorExt(tif->tif_clientdata, module, "%s: No space for %s arrays", TIFFErrorExt(tif->tif_clientdata, module, "No space for %s arrays",
tif->tif_name, isTiled(tif) ? "tile" : "strip"); isTiled(tif) ? "tile" : "strip");
return (0); return (0);
} }
tif->tif_tilesize = isTiled(tif) ? TIFFTileSize(tif) : (tsize_t) -1; if (isTiled(tif))
{
tif->tif_tilesize = TIFFTileSize(tif);
if (tif->tif_tilesize == 0)
return (0);
}
else
tif->tif_tilesize = (tmsize_t)(-1);
tif->tif_scanlinesize = TIFFScanlineSize(tif); tif->tif_scanlinesize = TIFFScanlineSize(tif);
if (tif->tif_scanlinesize == 0)
return (0);
tif->tif_flags |= TIFF_BEENWRITING; tif->tif_flags |= TIFF_BEENWRITING;
return (1); return (1);
} }
@ -543,7 +557,7 @@ TIFFWriteCheck(TIFF* tif, int tiles, const char* module)
* Setup the raw data buffer used for encoding. * Setup the raw data buffer used for encoding.
*/ */
int int
TIFFWriteBufferSetup(TIFF* tif, tdata_t bp, tsize_t size) TIFFWriteBufferSetup(TIFF* tif, void* bp, tmsize_t size)
{ {
static const char module[] = "TIFFWriteBufferSetup"; static const char module[] = "TIFFWriteBufferSetup";
@ -554,7 +568,7 @@ TIFFWriteBufferSetup(TIFF* tif, tdata_t bp, tsize_t size)
} }
tif->tif_rawdata = NULL; tif->tif_rawdata = NULL;
} }
if (size == (tsize_t) -1) { if (size == (tmsize_t)(-1)) {
size = (isTiled(tif) ? size = (isTiled(tif) ?
tif->tif_tilesize : TIFFStripSize(tif)); tif->tif_tilesize : TIFFStripSize(tif));
/* /*
@ -567,14 +581,13 @@ TIFFWriteBufferSetup(TIFF* tif, tdata_t bp, tsize_t size)
if (bp == NULL) { if (bp == NULL) {
bp = _TIFFmalloc(size); bp = _TIFFmalloc(size);
if (bp == NULL) { if (bp == NULL) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: No space for output buffer", TIFFErrorExt(tif->tif_clientdata, module, "No space for output buffer");
tif->tif_name);
return (0); return (0);
} }
tif->tif_flags |= TIFF_MYBUFFER; tif->tif_flags |= TIFF_MYBUFFER;
} else } else
tif->tif_flags &= ~TIFF_MYBUFFER; tif->tif_flags &= ~TIFF_MYBUFFER;
tif->tif_rawdata = (tidata_t) bp; tif->tif_rawdata = (uint8*) bp;
tif->tif_rawdatasize = size; tif->tif_rawdatasize = size;
tif->tif_rawcc = 0; tif->tif_rawcc = 0;
tif->tif_rawcp = tif->tif_rawdata; tif->tif_rawcp = tif->tif_rawdata;
@ -586,33 +599,35 @@ TIFFWriteBufferSetup(TIFF* tif, tdata_t bp, tsize_t size)
* Grow the strip data structures by delta strips. * Grow the strip data structures by delta strips.
*/ */
static int static int
TIFFGrowStrips(TIFF* tif, int delta, const char* module) TIFFGrowStrips(TIFF* tif, uint32 delta, const char* module)
{ {
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
uint32 *new_stripoffset, *new_stripbytecount; uint64* new_stripoffset;
uint64* new_stripbytecount;
assert(td->td_planarconfig == PLANARCONFIG_CONTIG); assert(td->td_planarconfig == PLANARCONFIG_CONTIG);
new_stripoffset = (uint32*)_TIFFrealloc(td->td_stripoffset, new_stripoffset = (uint64*)_TIFFrealloc(td->td_stripoffset,
(td->td_nstrips + delta) * sizeof (uint32)); (td->td_nstrips + delta) * sizeof (uint64));
new_stripbytecount = (uint32*)_TIFFrealloc(td->td_stripbytecount, new_stripbytecount = (uint64*)_TIFFrealloc(td->td_stripbytecount,
(td->td_nstrips + delta) * sizeof (uint32)); (td->td_nstrips + delta) * sizeof (uint64));
if (new_stripoffset == NULL || new_stripbytecount == NULL) { if (new_stripoffset == NULL || new_stripbytecount == NULL) {
if (new_stripoffset) if (new_stripoffset)
_TIFFfree(new_stripoffset); _TIFFfree(new_stripoffset);
if (new_stripbytecount) if (new_stripbytecount)
_TIFFfree(new_stripbytecount); _TIFFfree(new_stripbytecount);
td->td_nstrips = 0; td->td_nstrips = 0;
TIFFErrorExt(tif->tif_clientdata, module, "%s: No space to expand strip arrays", TIFFErrorExt(tif->tif_clientdata, module, "No space to expand strip arrays");
tif->tif_name);
return (0); return (0);
} }
td->td_stripoffset = new_stripoffset; td->td_stripoffset = new_stripoffset;
td->td_stripbytecount = new_stripbytecount; td->td_stripbytecount = new_stripbytecount;
_TIFFmemset(td->td_stripoffset + td->td_nstrips, _TIFFmemset(td->td_stripoffset + td->td_nstrips,
0, delta*sizeof (uint32)); 0, delta*sizeof (uint64));
_TIFFmemset(td->td_stripbytecount + td->td_nstrips, _TIFFmemset(td->td_stripbytecount + td->td_nstrips,
0, delta*sizeof (uint32)); 0, delta*sizeof (uint64));
td->td_nstrips += delta; td->td_nstrips += delta;
tif->tif_flags |= TIFF_DIRTYDIRECT;
return (1); return (1);
} }
@ -620,21 +635,23 @@ TIFFGrowStrips(TIFF* tif, int delta, const char* module)
* Append the data to the specified strip. * Append the data to the specified strip.
*/ */
static int static int
TIFFAppendToStrip(TIFF* tif, tstrip_t strip, tidata_t data, tsize_t cc) TIFFAppendToStrip(TIFF* tif, uint32 strip, uint8* data, tmsize_t cc)
{ {
static const char module[] = "TIFFAppendToStrip"; static const char module[] = "TIFFAppendToStrip";
TIFFDirectory *td = &tif->tif_dir; TIFFDirectory *td = &tif->tif_dir;
uint64 m;
int64 old_byte_count = -1;
if (td->td_stripoffset[strip] == 0 || tif->tif_curoff == 0) { if (td->td_stripoffset[strip] == 0 || tif->tif_curoff == 0) {
assert(td->td_nstrips > 0); assert(td->td_nstrips > 0);
if( td->td_stripbytecount[strip] != 0 if( td->td_stripbytecount[strip] != 0
&& td->td_stripoffset[strip] != 0 && td->td_stripoffset[strip] != 0
&& td->td_stripbytecount[strip] >= cc ) && td->td_stripbytecount[strip] >= (uint64) cc )
{ {
/* /*
* There is already tile data on disk, and the new tile * There is already tile data on disk, and the new tile
* data we have to will fit in the same space. The only * data we have will fit in the same space. The only
* aspect of this that is risky is that there could be * aspect of this that is risky is that there could be
* more data to append to this strip before we are done * more data to append to this strip before we are done
* depending on how we are getting called. * depending on how we are getting called.
@ -653,6 +670,7 @@ TIFFAppendToStrip(TIFF* tif, tstrip_t strip, tidata_t data, tsize_t cc)
* write this strip. * write this strip.
*/ */
td->td_stripoffset[strip] = TIFFSeekFile(tif, 0, SEEK_END); td->td_stripoffset[strip] = TIFFSeekFile(tif, 0, SEEK_END);
tif->tif_flags |= TIFF_DIRTYSTRIP;
} }
tif->tif_curoff = td->td_stripoffset[strip]; tif->tif_curoff = td->td_stripoffset[strip];
@ -660,16 +678,29 @@ TIFFAppendToStrip(TIFF* tif, tstrip_t strip, tidata_t data, tsize_t cc)
/* /*
* We are starting a fresh strip/tile, so set the size to zero. * We are starting a fresh strip/tile, so set the size to zero.
*/ */
old_byte_count = td->td_stripbytecount[strip];
td->td_stripbytecount[strip] = 0; td->td_stripbytecount[strip] = 0;
} }
m = tif->tif_curoff+cc;
if (!(tif->tif_flags&TIFF_BIGTIFF))
m = (uint32)m;
if ((m<tif->tif_curoff)||(m<(uint64)cc))
{
TIFFErrorExt(tif->tif_clientdata, module, "Maximum TIFF file size exceeded");
return (0);
}
if (!WriteOK(tif, data, cc)) { if (!WriteOK(tif, data, cc)) {
TIFFErrorExt(tif->tif_clientdata, module, "Write error at scanline %lu", TIFFErrorExt(tif->tif_clientdata, module, "Write error at scanline %lu",
(unsigned long) tif->tif_row); (unsigned long) tif->tif_row);
return (0); return (0);
} }
tif->tif_curoff = tif->tif_curoff+cc; tif->tif_curoff = m;
td->td_stripbytecount[strip] += cc; td->td_stripbytecount[strip] += cc;
if( (int64) td->td_stripbytecount[strip] != old_byte_count )
tif->tif_flags |= TIFF_DIRTYSTRIP;
return (1); return (1);
} }
@ -681,10 +712,10 @@ TIFFAppendToStrip(TIFF* tif, tstrip_t strip, tidata_t data, tsize_t cc)
int int
TIFFFlushData1(TIFF* tif) TIFFFlushData1(TIFF* tif)
{ {
if (tif->tif_rawcc > 0) { if (tif->tif_rawcc > 0 && tif->tif_flags & TIFF_BUF4WRITE ) {
if (!isFillOrder(tif, tif->tif_dir.td_fillorder) && if (!isFillOrder(tif, tif->tif_dir.td_fillorder) &&
(tif->tif_flags & TIFF_NOBITREV) == 0) (tif->tif_flags & TIFF_NOBITREV) == 0)
TIFFReverseBits((unsigned char *)tif->tif_rawdata, TIFFReverseBits((uint8*)tif->tif_rawdata,
tif->tif_rawcc); tif->tif_rawcc);
if (!TIFFAppendToStrip(tif, if (!TIFFAppendToStrip(tif,
isTiled(tif) ? tif->tif_curtile : tif->tif_curstrip, isTiled(tif) ? tif->tif_curtile : tif->tif_curstrip,

View File

@ -1,4 +1,4 @@
/* $Id: tif_zip.c,v 1.11.2.4 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Id: tif_zip.c,v 1.31 2011-01-06 16:00:23 fwarmerdam Exp $ */
/* /*
* Copyright (c) 1995-1997 Sam Leffler * Copyright (c) 1995-1997 Sam Leffler
@ -65,41 +65,48 @@
* State block for each open TIFF * State block for each open TIFF
* file using ZIP compression/decompression. * file using ZIP compression/decompression.
*/ */
typedef struct { typedef struct {
TIFFPredictorState predict; TIFFPredictorState predict;
z_stream stream; z_stream stream;
int zipquality; /* compression level */ int zipquality; /* compression level */
int state; /* state flags */ int state; /* state flags */
#define ZSTATE_INIT_DECODE 0x01 #define ZSTATE_INIT_DECODE 0x01
#define ZSTATE_INIT_ENCODE 0x02 #define ZSTATE_INIT_ENCODE 0x02
TIFFVGetMethod vgetparent; /* super-class method */ TIFFVGetMethod vgetparent; /* super-class method */
TIFFVSetMethod vsetparent; /* super-class method */ TIFFVSetMethod vsetparent; /* super-class method */
} ZIPState; } ZIPState;
#define ZState(tif) ((ZIPState*) (tif)->tif_data) #define ZState(tif) ((ZIPState*) (tif)->tif_data)
#define DecoderState(tif) ZState(tif) #define DecoderState(tif) ZState(tif)
#define EncoderState(tif) ZState(tif) #define EncoderState(tif) ZState(tif)
static int ZIPEncode(TIFF*, tidata_t, tsize_t, tsample_t); static int ZIPEncode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s);
static int ZIPDecode(TIFF*, tidata_t, tsize_t, tsample_t); static int ZIPDecode(TIFF* tif, uint8* op, tmsize_t occ, uint16 s);
static int
ZIPFixupTags(TIFF* tif)
{
(void) tif;
return (1);
}
static int static int
ZIPSetupDecode(TIFF* tif) ZIPSetupDecode(TIFF* tif)
{ {
ZIPState* sp = DecoderState(tif);
static const char module[] = "ZIPSetupDecode"; static const char module[] = "ZIPSetupDecode";
ZIPState* sp = DecoderState(tif);
assert(sp != NULL); assert(sp != NULL);
/* if we were last encoding, terminate this mode */ /* if we were last encoding, terminate this mode */
if (sp->state & ZSTATE_INIT_ENCODE) { if (sp->state & ZSTATE_INIT_ENCODE) {
deflateEnd(&sp->stream); deflateEnd(&sp->stream);
sp->state = 0; sp->state = 0;
} }
if (inflateInit(&sp->stream) != Z_OK) { if (inflateInit(&sp->stream) != Z_OK) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: %s", tif->tif_name, sp->stream.msg); TIFFErrorExt(tif->tif_clientdata, module, "%s", sp->stream.msg);
return (0); return (0);
} else { } else {
sp->state |= ZSTATE_INIT_DECODE; sp->state |= ZSTATE_INIT_DECODE;
@ -111,74 +118,100 @@ ZIPSetupDecode(TIFF* tif)
* Setup state for decoding a strip. * Setup state for decoding a strip.
*/ */
static int static int
ZIPPreDecode(TIFF* tif, tsample_t s) ZIPPreDecode(TIFF* tif, uint16 s)
{ {
static const char module[] = "ZIPPreDecode";
ZIPState* sp = DecoderState(tif); ZIPState* sp = DecoderState(tif);
(void) s; (void) s;
assert(sp != NULL); assert(sp != NULL);
if( (sp->state & ZSTATE_INIT_DECODE) == 0 ) if( (sp->state & ZSTATE_INIT_DECODE) == 0 )
tif->tif_setupdecode( tif ); tif->tif_setupdecode( tif );
sp->stream.next_in = tif->tif_rawdata; sp->stream.next_in = tif->tif_rawdata;
sp->stream.avail_in = tif->tif_rawcc; assert(sizeof(sp->stream.avail_in)==4); /* if this assert gets raised,
we need to simplify this code to reflect a ZLib that is likely updated
to deal with 8byte memory sizes, though this code will respond
apropriately even before we simplify it */
sp->stream.avail_in = (uInt) tif->tif_rawcc;
if ((tmsize_t)sp->stream.avail_in != tif->tif_rawcc)
{
TIFFErrorExt(tif->tif_clientdata, module, "ZLib cannot deal with buffers this size");
return (0);
}
return (inflateReset(&sp->stream) == Z_OK); return (inflateReset(&sp->stream) == Z_OK);
} }
static int static int
ZIPDecode(TIFF* tif, tidata_t op, tsize_t occ, tsample_t s) ZIPDecode(TIFF* tif, uint8* op, tmsize_t occ, uint16 s)
{ {
ZIPState* sp = DecoderState(tif);
static const char module[] = "ZIPDecode"; static const char module[] = "ZIPDecode";
ZIPState* sp = DecoderState(tif);
(void) s; (void) s;
assert(sp != NULL); assert(sp != NULL);
assert(sp->state == ZSTATE_INIT_DECODE); assert(sp->state == ZSTATE_INIT_DECODE);
sp->stream.next_in = tif->tif_rawcp;
sp->stream.avail_in = (uInt) tif->tif_rawcc;
sp->stream.next_out = op; sp->stream.next_out = op;
sp->stream.avail_out = occ; assert(sizeof(sp->stream.avail_out)==4); /* if this assert gets raised,
we need to simplify this code to reflect a ZLib that is likely updated
to deal with 8byte memory sizes, though this code will respond
apropriately even before we simplify it */
sp->stream.avail_out = (uInt) occ;
if ((tmsize_t)sp->stream.avail_out != occ)
{
TIFFErrorExt(tif->tif_clientdata, module, "ZLib cannot deal with buffers this size");
return (0);
}
do { do {
int state = inflate(&sp->stream, Z_PARTIAL_FLUSH); int state = inflate(&sp->stream, Z_PARTIAL_FLUSH);
if (state == Z_STREAM_END) if (state == Z_STREAM_END)
break; break;
if (state == Z_DATA_ERROR) { if (state == Z_DATA_ERROR) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"%s: Decoding error at scanline %d, %s", "Decoding error at scanline %lu, %s",
tif->tif_name, tif->tif_row, sp->stream.msg); (unsigned long) tif->tif_row, sp->stream.msg);
if (inflateSync(&sp->stream) != Z_OK) if (inflateSync(&sp->stream) != Z_OK)
return (0); return (0);
continue; continue;
} }
if (state != Z_OK) { if (state != Z_OK) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: zlib error: %s", TIFFErrorExt(tif->tif_clientdata, module, "ZLib error: %s",
tif->tif_name, sp->stream.msg); sp->stream.msg);
return (0); return (0);
} }
} while (sp->stream.avail_out > 0); } while (sp->stream.avail_out > 0);
if (sp->stream.avail_out != 0) { if (sp->stream.avail_out != 0) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"%s: Not enough data at scanline %d (short %d bytes)", "Not enough data at scanline %lu (short " TIFF_UINT64_FORMAT " bytes)",
tif->tif_name, tif->tif_row, sp->stream.avail_out); (unsigned long) tif->tif_row, (TIFF_UINT64_T) sp->stream.avail_out);
return (0); return (0);
} }
tif->tif_rawcp = sp->stream.next_in;
tif->tif_rawcc = sp->stream.avail_in;
return (1); return (1);
} }
static int static int
ZIPSetupEncode(TIFF* tif) ZIPSetupEncode(TIFF* tif)
{ {
ZIPState* sp = EncoderState(tif);
static const char module[] = "ZIPSetupEncode"; static const char module[] = "ZIPSetupEncode";
ZIPState* sp = EncoderState(tif);
assert(sp != NULL); assert(sp != NULL);
if (sp->state & ZSTATE_INIT_DECODE) { if (sp->state & ZSTATE_INIT_DECODE) {
inflateEnd(&sp->stream); inflateEnd(&sp->stream);
sp->state = 0; sp->state = 0;
} }
if (deflateInit(&sp->stream, sp->zipquality) != Z_OK) { if (deflateInit(&sp->stream, sp->zipquality) != Z_OK) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: %s", tif->tif_name, sp->stream.msg); TIFFErrorExt(tif->tif_clientdata, module, "%s", sp->stream.msg);
return (0); return (0);
} else { } else {
sp->state |= ZSTATE_INIT_ENCODE; sp->state |= ZSTATE_INIT_ENCODE;
@ -190,17 +223,27 @@ ZIPSetupEncode(TIFF* tif)
* Reset encoding state at the start of a strip. * Reset encoding state at the start of a strip.
*/ */
static int static int
ZIPPreEncode(TIFF* tif, tsample_t s) ZIPPreEncode(TIFF* tif, uint16 s)
{ {
static const char module[] = "ZIPPreEncode";
ZIPState *sp = EncoderState(tif); ZIPState *sp = EncoderState(tif);
(void) s; (void) s;
assert(sp != NULL); assert(sp != NULL);
if( sp->state != ZSTATE_INIT_ENCODE ) if( sp->state != ZSTATE_INIT_ENCODE )
tif->tif_setupencode( tif ); tif->tif_setupencode( tif );
sp->stream.next_out = tif->tif_rawdata; sp->stream.next_out = tif->tif_rawdata;
assert(sizeof(sp->stream.avail_out)==4); /* if this assert gets raised,
we need to simplify this code to reflect a ZLib that is likely updated
to deal with 8byte memory sizes, though this code will respond
apropriately even before we simplify it */
sp->stream.avail_out = tif->tif_rawdatasize; sp->stream.avail_out = tif->tif_rawdatasize;
if ((tmsize_t)sp->stream.avail_out != tif->tif_rawdatasize)
{
TIFFErrorExt(tif->tif_clientdata, module, "ZLib cannot deal with buffers this size");
return (0);
}
return (deflateReset(&sp->stream) == Z_OK); return (deflateReset(&sp->stream) == Z_OK);
} }
@ -208,28 +251,37 @@ ZIPPreEncode(TIFF* tif, tsample_t s)
* Encode a chunk of pixels. * Encode a chunk of pixels.
*/ */
static int static int
ZIPEncode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s) ZIPEncode(TIFF* tif, uint8* bp, tmsize_t cc, uint16 s)
{ {
ZIPState *sp = EncoderState(tif);
static const char module[] = "ZIPEncode"; static const char module[] = "ZIPEncode";
ZIPState *sp = EncoderState(tif);
assert(sp != NULL); assert(sp != NULL);
assert(sp->state == ZSTATE_INIT_ENCODE); assert(sp->state == ZSTATE_INIT_ENCODE);
(void) s; (void) s;
sp->stream.next_in = bp; sp->stream.next_in = bp;
sp->stream.avail_in = cc; assert(sizeof(sp->stream.avail_in)==4); /* if this assert gets raised,
we need to simplify this code to reflect a ZLib that is likely updated
to deal with 8byte memory sizes, though this code will respond
apropriately even before we simplify it */
sp->stream.avail_in = (uInt) cc;
if ((tmsize_t)sp->stream.avail_in != cc)
{
TIFFErrorExt(tif->tif_clientdata, module, "ZLib cannot deal with buffers this size");
return (0);
}
do { do {
if (deflate(&sp->stream, Z_NO_FLUSH) != Z_OK) { if (deflate(&sp->stream, Z_NO_FLUSH) != Z_OK) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: Encoder error: %s", TIFFErrorExt(tif->tif_clientdata, module, "Encoder error: %s",
tif->tif_name, sp->stream.msg); sp->stream.msg);
return (0); return (0);
} }
if (sp->stream.avail_out == 0) { if (sp->stream.avail_out == 0) {
tif->tif_rawcc = tif->tif_rawdatasize; tif->tif_rawcc = tif->tif_rawdatasize;
TIFFFlushData1(tif); TIFFFlushData1(tif);
sp->stream.next_out = tif->tif_rawdata; sp->stream.next_out = tif->tif_rawdata;
sp->stream.avail_out = tif->tif_rawdatasize; sp->stream.avail_out = (uInt) tif->tif_rawdatasize; /* this is a safe typecast, as check is made already in ZIPPreEncode */
} }
} while (sp->stream.avail_in > 0); } while (sp->stream.avail_in > 0);
return (1); return (1);
@ -242,8 +294,8 @@ ZIPEncode(TIFF* tif, tidata_t bp, tsize_t cc, tsample_t s)
static int static int
ZIPPostEncode(TIFF* tif) ZIPPostEncode(TIFF* tif)
{ {
ZIPState *sp = EncoderState(tif);
static const char module[] = "ZIPPostEncode"; static const char module[] = "ZIPPostEncode";
ZIPState *sp = EncoderState(tif);
int state; int state;
sp->stream.avail_in = 0; sp->stream.avail_in = 0;
@ -252,19 +304,18 @@ ZIPPostEncode(TIFF* tif)
switch (state) { switch (state) {
case Z_STREAM_END: case Z_STREAM_END:
case Z_OK: case Z_OK:
if ((int)sp->stream.avail_out != (int)tif->tif_rawdatasize) if ((tmsize_t)sp->stream.avail_out != tif->tif_rawdatasize)
{ {
tif->tif_rawcc = tif->tif_rawcc = tif->tif_rawdatasize - sp->stream.avail_out;
tif->tif_rawdatasize - sp->stream.avail_out; TIFFFlushData1(tif);
TIFFFlushData1(tif); sp->stream.next_out = tif->tif_rawdata;
sp->stream.next_out = tif->tif_rawdata; sp->stream.avail_out = (uInt) tif->tif_rawdatasize; /* this is a safe typecast, as check is made already in ZIPPreEncode */
sp->stream.avail_out = tif->tif_rawdatasize; }
} break;
break;
default: default:
TIFFErrorExt(tif->tif_clientdata, module, "%s: zlib error: %s", TIFFErrorExt(tif->tif_clientdata, module, "ZLib error: %s",
tif->tif_name, sp->stream.msg); sp->stream.msg);
return (0); return (0);
} }
} while (state != Z_STREAM_END); } while (state != Z_STREAM_END);
return (1); return (1);
@ -283,11 +334,11 @@ ZIPCleanup(TIFF* tif)
tif->tif_tagmethods.vsetfield = sp->vsetparent; tif->tif_tagmethods.vsetfield = sp->vsetparent;
if (sp->state & ZSTATE_INIT_ENCODE) { if (sp->state & ZSTATE_INIT_ENCODE) {
deflateEnd(&sp->stream); deflateEnd(&sp->stream);
sp->state = 0; sp->state = 0;
} else if( sp->state & ZSTATE_INIT_DECODE) { } else if( sp->state & ZSTATE_INIT_DECODE) {
inflateEnd(&sp->stream); inflateEnd(&sp->stream);
sp->state = 0; sp->state = 0;
} }
_TIFFfree(sp); _TIFFfree(sp);
tif->tif_data = NULL; tif->tif_data = NULL;
@ -296,19 +347,19 @@ ZIPCleanup(TIFF* tif)
} }
static int static int
ZIPVSetField(TIFF* tif, ttag_t tag, va_list ap) ZIPVSetField(TIFF* tif, uint32 tag, va_list ap)
{ {
ZIPState* sp = ZState(tif);
static const char module[] = "ZIPVSetField"; static const char module[] = "ZIPVSetField";
ZIPState* sp = ZState(tif);
switch (tag) { switch (tag) {
case TIFFTAG_ZIPQUALITY: case TIFFTAG_ZIPQUALITY:
sp->zipquality = va_arg(ap, int); sp->zipquality = (int) va_arg(ap, int);
if ( sp->state&ZSTATE_INIT_ENCODE ) { if ( sp->state&ZSTATE_INIT_ENCODE ) {
if (deflateParams(&sp->stream, if (deflateParams(&sp->stream,
sp->zipquality, Z_DEFAULT_STRATEGY) != Z_OK) { sp->zipquality, Z_DEFAULT_STRATEGY) != Z_OK) {
TIFFErrorExt(tif->tif_clientdata, module, "%s: zlib error: %s", TIFFErrorExt(tif->tif_clientdata, module, "ZLib error: %s",
tif->tif_name, sp->stream.msg); sp->stream.msg);
return (0); return (0);
} }
} }
@ -320,7 +371,7 @@ ZIPVSetField(TIFF* tif, ttag_t tag, va_list ap)
} }
static int static int
ZIPVGetField(TIFF* tif, ttag_t tag, va_list ap) ZIPVGetField(TIFF* tif, uint32 tag, va_list ap)
{ {
ZIPState* sp = ZState(tif); ZIPState* sp = ZState(tif);
@ -334,9 +385,8 @@ ZIPVGetField(TIFF* tif, ttag_t tag, va_list ap)
return (1); return (1);
} }
static const TIFFFieldInfo zipFieldInfo[] = { static const TIFFField zipFields[] = {
{ TIFFTAG_ZIPQUALITY, 0, 0, TIFF_ANY, FIELD_PSEUDO, { TIFFTAG_ZIPQUALITY, 0, 0, TIFF_ANY, 0, TIFF_SETGET_INT, TIFF_SETGET_UNDEFINED, FIELD_PSEUDO, TRUE, FALSE, "", NULL },
TRUE, FALSE, "" },
}; };
int int
@ -351,8 +401,7 @@ TIFFInitZIP(TIFF* tif, int scheme)
/* /*
* Merge codec-specific tag information. * Merge codec-specific tag information.
*/ */
if (!_TIFFMergeFieldInfo(tif, zipFieldInfo, if (!_TIFFMergeFields(tif, zipFields, TIFFArrayCount(zipFields))) {
TIFFArrayCount(zipFieldInfo))) {
TIFFErrorExt(tif->tif_clientdata, module, TIFFErrorExt(tif->tif_clientdata, module,
"Merging Deflate codec-specific tags failed"); "Merging Deflate codec-specific tags failed");
return 0; return 0;
@ -361,7 +410,7 @@ TIFFInitZIP(TIFF* tif, int scheme)
/* /*
* Allocate state block so tag methods have storage to record values. * Allocate state block so tag methods have storage to record values.
*/ */
tif->tif_data = (tidata_t) _TIFFmalloc(sizeof (ZIPState)); tif->tif_data = (uint8*) _TIFFmalloc(sizeof (ZIPState));
if (tif->tif_data == NULL) if (tif->tif_data == NULL)
goto bad; goto bad;
sp = ZState(tif); sp = ZState(tif);
@ -385,11 +434,12 @@ TIFFInitZIP(TIFF* tif, int scheme)
/* /*
* Install codec methods. * Install codec methods.
*/ */
tif->tif_fixuptags = ZIPFixupTags;
tif->tif_setupdecode = ZIPSetupDecode; tif->tif_setupdecode = ZIPSetupDecode;
tif->tif_predecode = ZIPPreDecode; tif->tif_predecode = ZIPPreDecode;
tif->tif_decoderow = ZIPDecode; tif->tif_decoderow = ZIPDecode;
tif->tif_decodestrip = ZIPDecode; tif->tif_decodestrip = ZIPDecode;
tif->tif_decodetile = ZIPDecode; tif->tif_decodetile = ZIPDecode;
tif->tif_setupencode = ZIPSetupEncode; tif->tif_setupencode = ZIPSetupEncode;
tif->tif_preencode = ZIPPreEncode; tif->tif_preencode = ZIPPreEncode;
tif->tif_postencode = ZIPPostEncode; tif->tif_postencode = ZIPPostEncode;

View File

@ -1,4 +1,4 @@
/* $Id: tiff.h,v 1.43.2.1 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Id: tiff.h,v 1.67 2011-01-24 21:06:32 olivier Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -39,87 +39,75 @@
* Suite 200 * Suite 200
* Seattle, WA 98104 * Seattle, WA 98104
* 206-622-5500 * 206-622-5500
* *
* (http://partners.adobe.com/asn/developer/PDFS/TN/TIFF6.pdf) * (http://partners.adobe.com/asn/developer/PDFS/TN/TIFF6.pdf)
* *
* For Big TIFF design notes see the following link * For BigTIFF design notes see the following links
* http://www.remotesensing.org/libtiff/bigtiffdesign.html * http://www.remotesensing.org/libtiff/bigtiffdesign.html
* http://www.awaresystems.be/imaging/tiff/bigtiff.html
*/ */
#define TIFF_VERSION 42
#define TIFF_BIGTIFF_VERSION 43
#define TIFF_BIGENDIAN 0x4d4d #define TIFF_VERSION_CLASSIC 42
#define TIFF_LITTLEENDIAN 0x4949 #define TIFF_VERSION_BIG 43
#define MDI_LITTLEENDIAN 0x5045
#define MDI_BIGENDIAN 0x4550 #define TIFF_BIGENDIAN 0x4d4d
#define TIFF_LITTLEENDIAN 0x4949
#define MDI_LITTLEENDIAN 0x5045
#define MDI_BIGENDIAN 0x4550
/* /*
* Intrinsic data types required by the file format: * Intrinsic data types required by the file format:
* *
* 8-bit quantities int8/uint8 * 8-bit quantities int8/uint8
* 16-bit quantities int16/uint16 * 16-bit quantities int16/uint16
* 32-bit quantities int32/uint32 * 32-bit quantities int32/uint32
* strings unsigned char* * 64-bit quantities int64/uint64
* strings unsigned char*
*/ */
#ifndef HAVE_INT8 typedef TIFF_INT8_T int8;
typedef signed char int8; /* NB: non-ANSI compilers may not grok */ typedef TIFF_UINT8_T uint8;
#endif
typedef unsigned char uint8;
#ifndef HAVE_INT16
typedef short int16;
#endif
typedef unsigned short uint16; /* sizeof (uint16) must == 2 */
#if SIZEOF_INT == 4
#ifndef HAVE_INT32
typedef int int32;
#endif
typedef unsigned int uint32; /* sizeof (uint32) must == 4 */
#elif SIZEOF_LONG == 4
#ifndef HAVE_INT32
typedef long int32;
#endif
typedef unsigned long uint32; /* sizeof (uint32) must == 4 */
#endif
/* For TIFFReassignTagToIgnore */ typedef TIFF_INT16_T int16;
enum TIFFIgnoreSense /* IGNORE tag table */ typedef TIFF_UINT16_T uint16;
{
TIS_STORE, typedef TIFF_INT32_T int32;
TIS_EXTRACT, typedef TIFF_UINT32_T uint32;
TIS_EMPTY
}; typedef TIFF_INT64_T int64;
typedef TIFF_UINT64_T uint64;
/*
* Some types as promoted in a variable argument list
* We use uint16_vap rather then directly using int, because this way
* we document the type we actually want to pass through, conceptually,
* rather then confusing the issue by merely stating the type it gets
* promoted to
*/
typedef int uint16_vap;
/* /*
* TIFF header. * TIFF header.
*/ */
typedef struct { typedef struct {
uint16 tiff_magic; /* magic number (defines byte order) */ uint16 tiff_magic; /* magic number (defines byte order) */
#define TIFF_MAGIC_SIZE 2 uint16 tiff_version; /* TIFF version number */
uint16 tiff_version; /* TIFF version number */ } TIFFHeaderCommon;
#define TIFF_VERSION_SIZE 2 typedef struct {
uint32 tiff_diroff; /* byte offset to first directory */ uint16 tiff_magic; /* magic number (defines byte order) */
#define TIFF_DIROFFSET_SIZE 4 uint16 tiff_version; /* TIFF version number */
} TIFFHeader; uint32 tiff_diroff; /* byte offset to first directory */
} TIFFHeaderClassic;
typedef struct {
uint16 tiff_magic; /* magic number (defines byte order) */
uint16 tiff_version; /* TIFF version number */
uint16 tiff_offsetsize; /* size of offsets, should be 8 */
uint16 tiff_unused; /* unused word, should be 0 */
uint64 tiff_diroff; /* byte offset to first directory */
} TIFFHeaderBig;
/*
* TIFF Image File Directories are comprised of a table of field
* descriptors of the form shown below. The table is sorted in
* ascending order by tag. The values associated with each entry are
* disjoint and may appear anywhere in the file (so long as they are
* placed on a word boundary).
*
* If the value is 4 bytes or less, then it is placed in the offset
* field to save space. If the value is less than 4 bytes, it is
* left-justified in the offset field.
*/
typedef struct {
uint16 tdir_tag; /* see below */
uint16 tdir_type; /* data type; see below */
uint32 tdir_count; /* number of items; length in spec */
uint32 tdir_offset; /* byte offset to field data */
} TIFFDirEntry;
/* /*
* NB: In the comments below, * NB: In the comments below,
* - items marked with a + are obsoleted by revision 5.0, * - items marked with a + are obsoleted by revision 5.0,
@ -134,21 +122,24 @@ typedef struct {
* *
* Note: RATIONALs are the ratio of two 32-bit integer values. * Note: RATIONALs are the ratio of two 32-bit integer values.
*/ */
typedef enum { typedef enum {
TIFF_NOTYPE = 0, /* placeholder */ TIFF_NOTYPE = 0, /* placeholder */
TIFF_BYTE = 1, /* 8-bit unsigned integer */ TIFF_BYTE = 1, /* 8-bit unsigned integer */
TIFF_ASCII = 2, /* 8-bit bytes w/ last byte null */ TIFF_ASCII = 2, /* 8-bit bytes w/ last byte null */
TIFF_SHORT = 3, /* 16-bit unsigned integer */ TIFF_SHORT = 3, /* 16-bit unsigned integer */
TIFF_LONG = 4, /* 32-bit unsigned integer */ TIFF_LONG = 4, /* 32-bit unsigned integer */
TIFF_RATIONAL = 5, /* 64-bit unsigned fraction */ TIFF_RATIONAL = 5, /* 64-bit unsigned fraction */
TIFF_SBYTE = 6, /* !8-bit signed integer */ TIFF_SBYTE = 6, /* !8-bit signed integer */
TIFF_UNDEFINED = 7, /* !8-bit untyped data */ TIFF_UNDEFINED = 7, /* !8-bit untyped data */
TIFF_SSHORT = 8, /* !16-bit signed integer */ TIFF_SSHORT = 8, /* !16-bit signed integer */
TIFF_SLONG = 9, /* !32-bit signed integer */ TIFF_SLONG = 9, /* !32-bit signed integer */
TIFF_SRATIONAL = 10, /* !64-bit signed fraction */ TIFF_SRATIONAL = 10, /* !64-bit signed fraction */
TIFF_FLOAT = 11, /* !32-bit IEEE floating point */ TIFF_FLOAT = 11, /* !32-bit IEEE floating point */
TIFF_DOUBLE = 12, /* !64-bit IEEE floating point */ TIFF_DOUBLE = 12, /* !64-bit IEEE floating point */
TIFF_IFD = 13 /* %32-bit unsigned integer (offset) */ TIFF_IFD = 13, /* %32-bit unsigned integer (offset) */
TIFF_LONG8 = 16, /* BigTIFF 64-bit unsigned integer */
TIFF_SLONG8 = 17, /* BigTIFF 64-bit signed integer */
TIFF_IFD8 = 18 /* BigTIFF 64-bit unsigned integer (offset) */
} TIFFDataType; } TIFFDataType;
/* /*
@ -196,6 +187,7 @@ typedef enum {
#define COMPRESSION_SGILOG 34676 /* SGI Log Luminance RLE */ #define COMPRESSION_SGILOG 34676 /* SGI Log Luminance RLE */
#define COMPRESSION_SGILOG24 34677 /* SGI Log 24-bit packed */ #define COMPRESSION_SGILOG24 34677 /* SGI Log 24-bit packed */
#define COMPRESSION_JP2000 34712 /* Leadtools JPEG2000 */ #define COMPRESSION_JP2000 34712 /* Leadtools JPEG2000 */
#define COMPRESSION_LZMA 34925 /* LZMA2 */
#define TIFFTAG_PHOTOMETRIC 262 /* photometric interpretation */ #define TIFFTAG_PHOTOMETRIC 262 /* photometric interpretation */
#define PHOTOMETRIC_MINISWHITE 0 /* min value is white */ #define PHOTOMETRIC_MINISWHITE 0 /* min value is white */
#define PHOTOMETRIC_MINISBLACK 1 /* min value is black */ #define PHOTOMETRIC_MINISBLACK 1 /* min value is black */
@ -576,6 +568,10 @@ typedef enum {
#define TIFFTAG_SGILOGENCODE 65561 /* SGILog data encoding control*/ #define TIFFTAG_SGILOGENCODE 65561 /* SGILog data encoding control*/
#define SGILOGENCODE_NODITHER 0 /* do not dither encoded values*/ #define SGILOGENCODE_NODITHER 0 /* do not dither encoded values*/
#define SGILOGENCODE_RANDITHER 1 /* randomly dither encd values */ #define SGILOGENCODE_RANDITHER 1 /* randomly dither encd values */
#define TIFFTAG_LZMAPRESET 65562 /* LZMA2 preset (compression level) */
#define TIFFTAG_PERSAMPLE 65563 /* interface for per sample tags */
#define PERSAMPLE_MERGED 0 /* present as a single value */
#define PERSAMPLE_MULTI 1 /* present as multiple values */
/* /*
* EXIF tags * EXIF tags

79
thirdparty/libtiff/tiffconf.h.cmake.in vendored Normal file
View File

@ -0,0 +1,79 @@
/*
Configuration defines for installed libtiff.
This file maintained for backward compatibility. Do not use definitions
from this file in your programs.
*/
#ifndef _TIFFCONF_
#define _TIFFCONF_
#include "tif_config.h"
#if defined( HAVE_STDINT_H )
#include <stdint.h>
#endif
/* Define as 0 or 1 according to the floating point format suported by the
machine */
#define HAVE_IEEEFP 1
/* Set the native cpu bit order (FILLORDER_LSB2MSB or FILLORDER_MSB2LSB) */
#define HOST_FILLORDER FILLORDER_LSB2MSB
/* Native cpu byte order: 1 if big-endian (Motorola) or 0 if little-endian
(Intel) */
#define HOST_BIGENDIAN 0
/* Support CCITT Group 3 & 4 algorithms */
#define CCITT_SUPPORT 1
/* Support LogLuv high dynamic range encoding */
#define LOGLUV_SUPPORT 1
/* Support LZW algorithm */
#define LZW_SUPPORT 1
/* Support NeXT 2-bit RLE algorithm */
#define NEXT_SUPPORT 1
/* Support Old JPEG compresson (read contrib/ojpeg/README first! Compilation
fails with unpatched IJG JPEG library) */
/* #undef OJPEG_SUPPORT */
/* Support Macintosh PackBits algorithm */
#define PACKBITS_SUPPORT 1
/* Support ThunderScan 4-bit RLE algorithm */
#define THUNDER_SUPPORT 1
/* Support strip chopping (whether or not to convert single-strip uncompressed
images to mutiple strips of ~8Kb to reduce memory usage) */
#define STRIPCHOP_DEFAULT TIFF_STRIPCHOP
/* Enable SubIFD tag (330) support */
#define SUBIFD_SUPPORT 1
/* Treat extra sample as alpha (default enabled). The RGBA interface will
treat a fourth sample with no EXTRASAMPLE_ value as being ASSOCALPHA. Many
packages produce RGBA files but don't mark the alpha properly. */
/*#define DEFAULT_EXTRASAMPLE_AS_ALPHA 1*/
/* Pick up YCbCr subsampling info from the JPEG data stream to support files
lacking the tag (default enabled). */
#define CHECK_JPEG_YCBCR_SUBSAMPLING 1
/* Support MS MDI magic number files as TIFF */
#define MDI_SUPPORT 1
/*
* Feature support definitions.
* XXX: These macros are obsoleted. Don't use them in your apps!
* Macros stays here for backward compatibility and should be always defined.
*/
#define COLORIMETRY_SUPPORT
#define YCBCR_SUPPORT
#define CMYK_SUPPORT
#define ICC_SUPPORT
#define PHOTOSHOP_SUPPORT
#define IPTC_SUPPORT
#endif /* _TIFFCONF_ */

View File

@ -7,100 +7,110 @@
#ifndef _TIFFCONF_ #ifndef _TIFFCONF_
#define _TIFFCONF_ #define _TIFFCONF_
/* Define to 1 if the system has the type `int16'. */ /* Signed 16-bit type */
/* #undef HAVE_INT16 */ #undef TIFF_INT16_T
/* Define to 1 if the system has the type `int32'. */ /* Signed 32-bit type */
/* #undef HAVE_INT32 */ #undef TIFF_INT32_T
/* Define to 1 if the system has the type `int8'. */
/* #undef HAVE_INT8 */
/* The size of a `int', as computed by sizeof. */
#define SIZEOF_INT 4
/* The size of a `long', as computed by sizeof. */
#define SIZEOF_LONG 4
/* Signed 64-bit type formatter */
#define TIFF_INT64_FORMAT "%I64d"
/* Signed 64-bit type */ /* Signed 64-bit type */
#ifdef _MSC_VER #undef TIFF_INT64_T
#define TIFF_INT64_T signed __int64
#else
#define TIFF_INT64_T long long
#endif
/* Unsigned 64-bit type formatter */ /* Signed 8-bit type */
#define TIFF_UINT64_FORMAT "%I64u" #undef TIFF_INT8_T
/* Unsigned 16-bit type */
#undef TIFF_UINT16_T
/* Unsigned 32-bit type */
#undef TIFF_UINT32_T
/* Unsigned 64-bit type */ /* Unsigned 64-bit type */
#ifdef _MSC_VER #undef TIFF_UINT64_T
#define TIFF_UINT64_T unsigned __int64
#else /* Unsigned 8-bit type */
#define TIFF_UINT64_T unsigned long long #undef TIFF_UINT8_T
#endif
/* Signed size type */
#undef TIFF_SSIZE_T
/* Pointer difference type */
#undef TIFF_PTRDIFF_T
/* Define to 1 if the system has the type `int16'. */
#undef HAVE_INT16
/* Define to 1 if the system has the type `int32'. */
#undef HAVE_INT32
/* Define to 1 if the system has the type `int8'. */
#undef HAVE_INT8
/* Compatibility stuff. */ /* Compatibility stuff. */
/* Define as 0 or 1 according to the floating point format suported by the /* Define as 0 or 1 according to the floating point format suported by the
machine */ machine */
#define HAVE_IEEEFP 1 #undef HAVE_IEEEFP
/* Set the native cpu bit order (FILLORDER_LSB2MSB or FILLORDER_MSB2LSB) */ /* Set the native cpu bit order (FILLORDER_LSB2MSB or FILLORDER_MSB2LSB) */
#define HOST_FILLORDER FILLORDER_LSB2MSB #undef HOST_FILLORDER
/* Native cpu byte order: 1 if big-endian (Motorola) or 0 if little-endian /* Native cpu byte order: 1 if big-endian (Motorola) or 0 if little-endian
(Intel) */ (Intel) */
#define HOST_BIGENDIAN 0 #undef HOST_BIGENDIAN
/* Support CCITT Group 3 & 4 algorithms */ /* Support CCITT Group 3 & 4 algorithms */
#define CCITT_SUPPORT 1 #undef CCITT_SUPPORT
/* Support JPEG compression (requires IJG JPEG library) */ /* Support JPEG compression (requires IJG JPEG library) */
/* #undef JPEG_SUPPORT */ #undef JPEG_SUPPORT
/* Support JBIG compression (requires JBIG-KIT library) */
#undef JBIG_SUPPORT
/* Support LogLuv high dynamic range encoding */ /* Support LogLuv high dynamic range encoding */
#define LOGLUV_SUPPORT 1 #undef LOGLUV_SUPPORT
/* Support LZW algorithm */ /* Support LZW algorithm */
#define LZW_SUPPORT 1 #undef LZW_SUPPORT
/* Support NeXT 2-bit RLE algorithm */ /* Support NeXT 2-bit RLE algorithm */
#define NEXT_SUPPORT 1 #undef NEXT_SUPPORT
/* Support Old JPEG compresson (read contrib/ojpeg/README first! Compilation /* Support Old JPEG compresson (read contrib/ojpeg/README first! Compilation
fails with unpatched IJG JPEG library) */ fails with unpatched IJG JPEG library) */
/* #undef OJPEG_SUPPORT */ #undef OJPEG_SUPPORT
/* Support Macintosh PackBits algorithm */ /* Support Macintosh PackBits algorithm */
#define PACKBITS_SUPPORT 1 #undef PACKBITS_SUPPORT
/* Support Pixar log-format algorithm (requires Zlib) */ /* Support Pixar log-format algorithm (requires Zlib) */
/* #undef PIXARLOG_SUPPORT */ #undef PIXARLOG_SUPPORT
/* Support ThunderScan 4-bit RLE algorithm */ /* Support ThunderScan 4-bit RLE algorithm */
#define THUNDER_SUPPORT 1 #undef THUNDER_SUPPORT
/* Support Deflate compression */ /* Support Deflate compression */
/* #undef ZIP_SUPPORT */ #undef ZIP_SUPPORT
/* Support strip chopping (whether or not to convert single-strip uncompressed /* Support strip chopping (whether or not to convert single-strip uncompressed
images to mutiple strips of ~8Kb to reduce memory usage) */ images to mutiple strips of ~8Kb to reduce memory usage) */
#define STRIPCHOP_DEFAULT TIFF_STRIPCHOP #undef STRIPCHOP_DEFAULT
/* Enable SubIFD tag (330) support */ /* Enable SubIFD tag (330) support */
#define SUBIFD_SUPPORT 1 #undef SUBIFD_SUPPORT
/* Treat extra sample as alpha (default enabled). The RGBA interface will /* Treat extra sample as alpha (default enabled). The RGBA interface will
treat a fourth sample with no EXTRASAMPLE_ value as being ASSOCALPHA. Many treat a fourth sample with no EXTRASAMPLE_ value as being ASSOCALPHA. Many
packages produce RGBA files but don't mark the alpha properly. */ packages produce RGBA files but don't mark the alpha properly. */
#define DEFAULT_EXTRASAMPLE_AS_ALPHA 1 #undef DEFAULT_EXTRASAMPLE_AS_ALPHA
/* Pick up YCbCr subsampling info from the JPEG data stream to support files /* Pick up YCbCr subsampling info from the JPEG data stream to support files
lacking the tag (default enabled). */ lacking the tag (default enabled). */
#define CHECK_JPEG_YCBCR_SUBSAMPLING 1 #undef CHECK_JPEG_YCBCR_SUBSAMPLING
/* Support MS MDI magic number files as TIFF */
#undef MDI_SUPPORT
/* /*
* Feature support definitions. * Feature support definitions.
@ -115,10 +125,3 @@
#define IPTC_SUPPORT #define IPTC_SUPPORT
#endif /* _TIFFCONF_ */ #endif /* _TIFFCONF_ */
/*
* Local Variables:
* mode: c
* c-basic-offset: 8
* fill-column: 78
* End:
*/

View File

@ -1,21 +1,21 @@
/* $Id: tiffio.h,v 1.56.2.4 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Id: tiffio.h,v 1.89 2012-02-18 16:20:26 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
* Copyright (c) 1991-1997 Silicon Graphics, Inc. * Copyright (c) 1991-1997 Silicon Graphics, Inc.
* *
* Permission to use, copy, modify, distribute, and sell this software and * Permission to use, copy, modify, distribute, and sell this software and
* its documentation for any purpose is hereby granted without fee, provided * its documentation for any purpose is hereby granted without fee, provided
* that (i) the above copyright notices and this permission notice appear in * that (i) the above copyright notices and this permission notice appear in
* all copies of the software and related documentation, and (ii) the names of * all copies of the software and related documentation, and (ii) the names of
* Sam Leffler and Silicon Graphics may not be used in any advertising or * Sam Leffler and Silicon Graphics may not be used in any advertising or
* publicity relating to the software without the specific, prior written * publicity relating to the software without the specific, prior written
* permission of Sam Leffler and Silicon Graphics. * permission of Sam Leffler and Silicon Graphics.
* *
* THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND, * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,
* EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
* WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
* *
* IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
* ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
* OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
@ -37,7 +37,7 @@
* TIFF is defined as an incomplete type to hide the * TIFF is defined as an incomplete type to hide the
* library's internal data structures from clients. * library's internal data structures from clients.
*/ */
typedef struct tiff TIFF; typedef struct tiff TIFF;
/* /*
* The following typedefs define the intrinsic size of * The following typedefs define the intrinsic size of
@ -55,18 +55,27 @@ typedef struct tiff TIFF;
* NB: tsize_t is int32 and not uint32 because some functions * NB: tsize_t is int32 and not uint32 because some functions
* return -1. * return -1.
* NB: toff_t is not off_t for many reasons; TIFFs max out at * NB: toff_t is not off_t for many reasons; TIFFs max out at
* 32-bit file offsets being the most important, and to ensure * 32-bit file offsets, and BigTIFF maxes out at 64-bit
* that it is unsigned, rather than signed. * offsets being the most important, and to ensure use of
* a consistently unsigned type across architectures.
* Prior to libtiff 4.0, this was an unsigned 32 bit type.
*/ */
/*
* this is the machine addressing size type, only it's signed, so make it
* int32 on 32bit machines, int64 on 64bit machines
*/
typedef TIFF_SSIZE_T tmsize_t;
typedef uint64 toff_t; /* file offset */
/* the following are deprecated and should be replaced by their defining
counterparts */
typedef uint32 ttag_t; /* directory tag */ typedef uint32 ttag_t; /* directory tag */
typedef uint16 tdir_t; /* directory index */ typedef uint16 tdir_t; /* directory index */
typedef uint16 tsample_t; /* sample number */ typedef uint16 tsample_t; /* sample number */
typedef uint32 tstrile_t; /* strip or tile number */ typedef uint32 tstrile_t; /* strip or tile number */
typedef tstrile_t tstrip_t; /* strip number */ typedef tstrile_t tstrip_t; /* strip number */
typedef tstrile_t ttile_t; /* tile number */ typedef tstrile_t ttile_t; /* tile number */
typedef size_t tsize_t; /* i/o size in bytes */ typedef tmsize_t tsize_t; /* i/o size in bytes */
typedef void* tdata_t; /* image data ref */ typedef void* tdata_t; /* image data ref */
typedef uint32 toff_t; /* file offset */
#if !defined(__WIN32__) && (defined(_WIN32) || defined(WIN32)) #if !defined(__WIN32__) && (defined(_WIN32) || defined(WIN32))
#define __WIN32__ #define __WIN32__
@ -89,12 +98,12 @@ typedef uint32 toff_t; /* file offset */
# define VC_EXTRALEAN # define VC_EXTRALEAN
# include <windows.h> # include <windows.h>
# ifdef __WIN32__ # ifdef __WIN32__
DECLARE_HANDLE(thandle_t); /* Win32 file handle */ DECLARE_HANDLE(thandle_t); /* Win32 file handle */
# else # else
typedef HFILE thandle_t; /* client data handle */ typedef HFILE thandle_t; /* client data handle */
# endif /* __WIN32__ */ # endif /* __WIN32__ */
#else #else
typedef void* thandle_t; /* client data handle */ typedef void* thandle_t; /* client data handle */
#endif /* USE_WIN32_FILEIO */ #endif /* USE_WIN32_FILEIO */
/* /*
@ -103,13 +112,13 @@ typedef void* thandle_t; /* client data handle */
* very large. Bit-or these flags to enable printing * very large. Bit-or these flags to enable printing
* multiple items. * multiple items.
*/ */
#define TIFFPRINT_NONE 0x0 /* no extra info */ #define TIFFPRINT_NONE 0x0 /* no extra info */
#define TIFFPRINT_STRIPS 0x1 /* strips/tiles info */ #define TIFFPRINT_STRIPS 0x1 /* strips/tiles info */
#define TIFFPRINT_CURVES 0x2 /* color/gray response curves */ #define TIFFPRINT_CURVES 0x2 /* color/gray response curves */
#define TIFFPRINT_COLORMAP 0x4 /* colormap */ #define TIFFPRINT_COLORMAP 0x4 /* colormap */
#define TIFFPRINT_JPEGQTABLES 0x100 /* JPEG Q matrices */ #define TIFFPRINT_JPEGQTABLES 0x100 /* JPEG Q matrices */
#define TIFFPRINT_JPEGACTABLES 0x200 /* JPEG AC tables */ #define TIFFPRINT_JPEGACTABLES 0x200 /* JPEG AC tables */
#define TIFFPRINT_JPEGDCTABLES 0x200 /* JPEG DC tables */ #define TIFFPRINT_JPEGDCTABLES 0x200 /* JPEG DC tables */
/* /*
* Colour conversion stuff * Colour conversion stuff
@ -126,42 +135,42 @@ typedef void* thandle_t; /* client data handle */
/* Structure for holding information about a display device. */ /* Structure for holding information about a display device. */
typedef unsigned char TIFFRGBValue; /* 8-bit samples */ typedef unsigned char TIFFRGBValue; /* 8-bit samples */
typedef struct { typedef struct {
float d_mat[3][3]; /* XYZ -> luminance matrix */ float d_mat[3][3]; /* XYZ -> luminance matrix */
float d_YCR; /* Light o/p for reference white */ float d_YCR; /* Light o/p for reference white */
float d_YCG; float d_YCG;
float d_YCB; float d_YCB;
uint32 d_Vrwr; /* Pixel values for ref. white */ uint32 d_Vrwr; /* Pixel values for ref. white */
uint32 d_Vrwg; uint32 d_Vrwg;
uint32 d_Vrwb; uint32 d_Vrwb;
float d_Y0R; /* Residual light for black pixel */ float d_Y0R; /* Residual light for black pixel */
float d_Y0G; float d_Y0G;
float d_Y0B; float d_Y0B;
float d_gammaR; /* Gamma values for the three guns */ float d_gammaR; /* Gamma values for the three guns */
float d_gammaG; float d_gammaG;
float d_gammaB; float d_gammaB;
} TIFFDisplay; } TIFFDisplay;
typedef struct { /* YCbCr->RGB support */ typedef struct { /* YCbCr->RGB support */
TIFFRGBValue* clamptab; /* range clamping table */ TIFFRGBValue* clamptab; /* range clamping table */
int* Cr_r_tab; int* Cr_r_tab;
int* Cb_b_tab; int* Cb_b_tab;
int32* Cr_g_tab; int32* Cr_g_tab;
int32* Cb_g_tab; int32* Cb_g_tab;
int32* Y_tab; int32* Y_tab;
} TIFFYCbCrToRGB; } TIFFYCbCrToRGB;
typedef struct { /* CIE Lab 1976->RGB support */ typedef struct { /* CIE Lab 1976->RGB support */
int range; /* Size of conversion table */ int range; /* Size of conversion table */
#define CIELABTORGB_TABLE_RANGE 1500 #define CIELABTORGB_TABLE_RANGE 1500
float rstep, gstep, bstep; float rstep, gstep, bstep;
float X0, Y0, Z0; /* Reference white point */ float X0, Y0, Z0; /* Reference white point */
TIFFDisplay display; TIFFDisplay display;
float Yr2r[CIELABTORGB_TABLE_RANGE + 1]; /* Conversion of Yr to r */ float Yr2r[CIELABTORGB_TABLE_RANGE + 1]; /* Conversion of Yr to r */
float Yg2g[CIELABTORGB_TABLE_RANGE + 1]; /* Conversion of Yg to g */ float Yg2g[CIELABTORGB_TABLE_RANGE + 1]; /* Conversion of Yg to g */
float Yb2b[CIELABTORGB_TABLE_RANGE + 1]; /* Conversion of Yb to b */ float Yb2b[CIELABTORGB_TABLE_RANGE + 1]; /* Conversion of Yb to b */
} TIFFCIELabToRGB; } TIFFCIELabToRGB;
/* /*
@ -216,6 +225,9 @@ struct _TIFFRGBAImage {
TIFFYCbCrToRGB* ycbcr; /* YCbCr conversion state */ TIFFYCbCrToRGB* ycbcr; /* YCbCr conversion state */
TIFFCIELabToRGB* cielab; /* CIE L*a*b conversion state */ TIFFCIELabToRGB* cielab; /* CIE L*a*b conversion state */
uint8* UaToAa; /* Unassociated alpha to associated alpha convertion LUT */
uint8* Bitdepth16To8; /* LUT for conversion from 16bit to 8bit values */
int row_offset; int row_offset;
int col_offset; int col_offset;
}; };
@ -224,10 +236,10 @@ struct _TIFFRGBAImage {
* Macros for extracting components from the * Macros for extracting components from the
* packed ABGR form returned by TIFFReadRGBAImage. * packed ABGR form returned by TIFFReadRGBAImage.
*/ */
#define TIFFGetR(abgr) ((abgr) & 0xff) #define TIFFGetR(abgr) ((abgr) & 0xff)
#define TIFFGetG(abgr) (((abgr) >> 8) & 0xff) #define TIFFGetG(abgr) (((abgr) >> 8) & 0xff)
#define TIFFGetB(abgr) (((abgr) >> 16) & 0xff) #define TIFFGetB(abgr) (((abgr) >> 16) & 0xff)
#define TIFFGetA(abgr) (((abgr) >> 24) & 0xff) #define TIFFGetA(abgr) (((abgr) >> 24) & 0xff)
/* /*
* A CODEC is a software package that implements decoding, * A CODEC is a software package that implements decoding,
@ -236,11 +248,11 @@ struct _TIFFRGBAImage {
* More codecs may be registered through calls to the library * More codecs may be registered through calls to the library
* and/or the builtin implementations may be overridden. * and/or the builtin implementations may be overridden.
*/ */
typedef int (*TIFFInitMethod)(TIFF*, int); typedef int (*TIFFInitMethod)(TIFF*, int);
typedef struct { typedef struct {
char* name; char* name;
uint16 scheme; uint16 scheme;
TIFFInitMethod init; TIFFInitMethod init;
} TIFFCodec; } TIFFCodec;
#include <stdio.h> #include <stdio.h>
@ -248,7 +260,7 @@ typedef struct {
/* share internal LogLuv conversion routines? */ /* share internal LogLuv conversion routines? */
#ifndef LOGLUV_PUBLIC #ifndef LOGLUV_PUBLIC
#define LOGLUV_PUBLIC 1 #define LOGLUV_PUBLIC 1
#endif #endif
#if !defined(__GNUC__) && !defined(__attribute__) #if !defined(__GNUC__) && !defined(__attribute__)
@ -258,48 +270,254 @@ typedef struct {
#if defined(c_plusplus) || defined(__cplusplus) #if defined(c_plusplus) || defined(__cplusplus)
extern "C" { extern "C" {
#endif #endif
typedef void (*TIFFErrorHandler)(const char*, const char*, va_list); typedef void (*TIFFErrorHandler)(const char*, const char*, va_list);
typedef void (*TIFFErrorHandlerExt)(thandle_t, const char*, const char*, va_list); typedef void (*TIFFErrorHandlerExt)(thandle_t, const char*, const char*, va_list);
typedef tsize_t (*TIFFReadWriteProc)(thandle_t, tdata_t, tsize_t); typedef tmsize_t (*TIFFReadWriteProc)(thandle_t, void*, tmsize_t);
typedef toff_t (*TIFFSeekProc)(thandle_t, toff_t, int); typedef toff_t (*TIFFSeekProc)(thandle_t, toff_t, int);
typedef int (*TIFFCloseProc)(thandle_t); typedef int (*TIFFCloseProc)(thandle_t);
typedef toff_t (*TIFFSizeProc)(thandle_t); typedef toff_t (*TIFFSizeProc)(thandle_t);
typedef int (*TIFFMapFileProc)(thandle_t, tdata_t*, toff_t*); typedef int (*TIFFMapFileProc)(thandle_t, void** base, toff_t* size);
typedef void (*TIFFUnmapFileProc)(thandle_t, tdata_t, toff_t); typedef void (*TIFFUnmapFileProc)(thandle_t, void* base, toff_t size);
typedef void (*TIFFExtendProc)(TIFF*); typedef void (*TIFFExtendProc)(TIFF*);
extern const char* TIFFGetVersion(void); extern const char* TIFFGetVersion(void);
extern const TIFFCodec* TIFFFindCODEC(uint16); extern const TIFFCodec* TIFFFindCODEC(uint16);
extern TIFFCodec* TIFFRegisterCODEC(uint16, const char*, TIFFInitMethod); extern TIFFCodec* TIFFRegisterCODEC(uint16, const char*, TIFFInitMethod);
extern void TIFFUnRegisterCODEC(TIFFCodec*); extern void TIFFUnRegisterCODEC(TIFFCodec*);
extern int TIFFIsCODECConfigured(uint16); extern int TIFFIsCODECConfigured(uint16);
extern TIFFCodec* TIFFGetConfiguredCODECs(void); extern TIFFCodec* TIFFGetConfiguredCODECs(void);
/* /*
* Auxiliary functions. * Auxiliary functions.
*/ */
extern tdata_t _TIFFmalloc(tsize_t); extern void* _TIFFmalloc(tmsize_t s);
extern tdata_t _TIFFrealloc(tdata_t, tsize_t); extern void* _TIFFrealloc(void* p, tmsize_t s);
extern void _TIFFmemset(tdata_t, int, tsize_t); extern void _TIFFmemset(void* p, int v, tmsize_t c);
extern void _TIFFmemcpy(tdata_t, const tdata_t, tsize_t); extern void _TIFFmemcpy(void* d, const void* s, tmsize_t c);
extern int _TIFFmemcmp(const tdata_t, const tdata_t, tsize_t); extern int _TIFFmemcmp(const void* p1, const void* p2, tmsize_t c);
extern void _TIFFfree(tdata_t); extern void _TIFFfree(void* p);
/* /*
** Stuff, related to tag handling and creating custom tags. ** Stuff, related to tag handling and creating custom tags.
*/ */
extern int TIFFGetTagListCount( TIFF * ); extern int TIFFGetTagListCount( TIFF * );
extern ttag_t TIFFGetTagListEntry( TIFF *, int tag_index ); extern uint32 TIFFGetTagListEntry( TIFF *, int tag_index );
#define TIFF_ANY TIFF_NOTYPE /* for field descriptor searching */ #define TIFF_ANY TIFF_NOTYPE /* for field descriptor searching */
#define TIFF_VARIABLE -1 /* marker for variable length tags */ #define TIFF_VARIABLE -1 /* marker for variable length tags */
#define TIFF_SPP -2 /* marker for SamplesPerPixel tags */ #define TIFF_SPP -2 /* marker for SamplesPerPixel tags */
#define TIFF_VARIABLE2 -3 /* marker for uint32 var-length tags */ #define TIFF_VARIABLE2 -3 /* marker for uint32 var-length tags */
#define FIELD_CUSTOM 65 #define FIELD_CUSTOM 65
typedef struct _TIFFField TIFFField;
typedef struct _TIFFFieldArray TIFFFieldArray;
extern const TIFFField* TIFFFindField(TIFF *, uint32, TIFFDataType);
extern const TIFFField* TIFFFieldWithTag(TIFF*, uint32);
extern const TIFFField* TIFFFieldWithName(TIFF*, const char *);
typedef int (*TIFFVSetMethod)(TIFF*, uint32, va_list);
typedef int (*TIFFVGetMethod)(TIFF*, uint32, va_list);
typedef void (*TIFFPrintMethod)(TIFF*, FILE*, long);
typedef struct {
TIFFVSetMethod vsetfield; /* tag set routine */
TIFFVGetMethod vgetfield; /* tag get routine */
TIFFPrintMethod printdir; /* directory print routine */
} TIFFTagMethods;
extern TIFFTagMethods *TIFFAccessTagMethods(TIFF *);
extern void *TIFFGetClientInfo(TIFF *, const char *);
extern void TIFFSetClientInfo(TIFF *, void *, const char *);
extern void TIFFCleanup(TIFF* tif);
extern void TIFFClose(TIFF* tif);
extern int TIFFFlush(TIFF* tif);
extern int TIFFFlushData(TIFF* tif);
extern int TIFFGetField(TIFF* tif, uint32 tag, ...);
extern int TIFFVGetField(TIFF* tif, uint32 tag, va_list ap);
extern int TIFFGetFieldDefaulted(TIFF* tif, uint32 tag, ...);
extern int TIFFVGetFieldDefaulted(TIFF* tif, uint32 tag, va_list ap);
extern int TIFFReadDirectory(TIFF* tif);
extern int TIFFReadCustomDirectory(TIFF* tif, toff_t diroff, const TIFFFieldArray* infoarray);
extern int TIFFReadEXIFDirectory(TIFF* tif, toff_t diroff);
extern uint64 TIFFScanlineSize64(TIFF* tif);
extern tmsize_t TIFFScanlineSize(TIFF* tif);
extern uint64 TIFFRasterScanlineSize64(TIFF* tif);
extern tmsize_t TIFFRasterScanlineSize(TIFF* tif);
extern uint64 TIFFStripSize64(TIFF* tif);
extern tmsize_t TIFFStripSize(TIFF* tif);
extern uint64 TIFFRawStripSize64(TIFF* tif, uint32 strip);
extern tmsize_t TIFFRawStripSize(TIFF* tif, uint32 strip);
extern uint64 TIFFVStripSize64(TIFF* tif, uint32 nrows);
extern tmsize_t TIFFVStripSize(TIFF* tif, uint32 nrows);
extern uint64 TIFFTileRowSize64(TIFF* tif);
extern tmsize_t TIFFTileRowSize(TIFF* tif);
extern uint64 TIFFTileSize64(TIFF* tif);
extern tmsize_t TIFFTileSize(TIFF* tif);
extern uint64 TIFFVTileSize64(TIFF* tif, uint32 nrows);
extern tmsize_t TIFFVTileSize(TIFF* tif, uint32 nrows);
extern uint32 TIFFDefaultStripSize(TIFF* tif, uint32 request);
extern void TIFFDefaultTileSize(TIFF*, uint32*, uint32*);
extern int TIFFFileno(TIFF*);
extern int TIFFSetFileno(TIFF*, int);
extern thandle_t TIFFClientdata(TIFF*);
extern thandle_t TIFFSetClientdata(TIFF*, thandle_t);
extern int TIFFGetMode(TIFF*);
extern int TIFFSetMode(TIFF*, int);
extern int TIFFIsTiled(TIFF*);
extern int TIFFIsByteSwapped(TIFF*);
extern int TIFFIsUpSampled(TIFF*);
extern int TIFFIsMSB2LSB(TIFF*);
extern int TIFFIsBigEndian(TIFF*);
extern TIFFReadWriteProc TIFFGetReadProc(TIFF*);
extern TIFFReadWriteProc TIFFGetWriteProc(TIFF*);
extern TIFFSeekProc TIFFGetSeekProc(TIFF*);
extern TIFFCloseProc TIFFGetCloseProc(TIFF*);
extern TIFFSizeProc TIFFGetSizeProc(TIFF*);
extern TIFFMapFileProc TIFFGetMapFileProc(TIFF*);
extern TIFFUnmapFileProc TIFFGetUnmapFileProc(TIFF*);
extern uint32 TIFFCurrentRow(TIFF*);
extern uint16 TIFFCurrentDirectory(TIFF*);
extern uint16 TIFFNumberOfDirectories(TIFF*);
extern uint64 TIFFCurrentDirOffset(TIFF*);
extern uint32 TIFFCurrentStrip(TIFF*);
extern uint32 TIFFCurrentTile(TIFF* tif);
extern int TIFFReadBufferSetup(TIFF* tif, void* bp, tmsize_t size);
extern int TIFFWriteBufferSetup(TIFF* tif, void* bp, tmsize_t size);
extern int TIFFSetupStrips(TIFF *);
extern int TIFFWriteCheck(TIFF*, int, const char *);
extern void TIFFFreeDirectory(TIFF*);
extern int TIFFCreateDirectory(TIFF*);
extern int TIFFLastDirectory(TIFF*);
extern int TIFFSetDirectory(TIFF*, uint16);
extern int TIFFSetSubDirectory(TIFF*, uint64);
extern int TIFFUnlinkDirectory(TIFF*, uint16);
extern int TIFFSetField(TIFF*, uint32, ...);
extern int TIFFVSetField(TIFF*, uint32, va_list);
extern int TIFFUnsetField(TIFF*, uint32);
extern int TIFFWriteDirectory(TIFF *);
extern int TIFFCheckpointDirectory(TIFF *);
extern int TIFFRewriteDirectory(TIFF *);
#if defined(c_plusplus) || defined(__cplusplus)
extern void TIFFPrintDirectory(TIFF*, FILE*, long = 0);
extern int TIFFReadScanline(TIFF* tif, void* buf, uint32 row, uint16 sample = 0);
extern int TIFFWriteScanline(TIFF* tif, void* buf, uint32 row, uint16 sample = 0);
extern int TIFFReadRGBAImage(TIFF*, uint32, uint32, uint32*, int = 0);
extern int TIFFReadRGBAImageOriented(TIFF*, uint32, uint32, uint32*,
int = ORIENTATION_BOTLEFT, int = 0);
#else
extern void TIFFPrintDirectory(TIFF*, FILE*, long);
extern int TIFFReadScanline(TIFF* tif, void* buf, uint32 row, uint16 sample);
extern int TIFFWriteScanline(TIFF* tif, void* buf, uint32 row, uint16 sample);
extern int TIFFReadRGBAImage(TIFF*, uint32, uint32, uint32*, int);
extern int TIFFReadRGBAImageOriented(TIFF*, uint32, uint32, uint32*, int, int);
#endif
extern int TIFFReadRGBAStrip(TIFF*, uint32, uint32 * );
extern int TIFFReadRGBATile(TIFF*, uint32, uint32, uint32 * );
extern int TIFFRGBAImageOK(TIFF*, char [1024]);
extern int TIFFRGBAImageBegin(TIFFRGBAImage*, TIFF*, int, char [1024]);
extern int TIFFRGBAImageGet(TIFFRGBAImage*, uint32*, uint32, uint32);
extern void TIFFRGBAImageEnd(TIFFRGBAImage*);
extern TIFF* TIFFOpen(const char*, const char*);
# ifdef __WIN32__
extern TIFF* TIFFOpenW(const wchar_t*, const char*);
# endif /* __WIN32__ */
extern TIFF* TIFFFdOpen(int, const char*, const char*);
extern TIFF* TIFFClientOpen(const char*, const char*,
thandle_t,
TIFFReadWriteProc, TIFFReadWriteProc,
TIFFSeekProc, TIFFCloseProc,
TIFFSizeProc,
TIFFMapFileProc, TIFFUnmapFileProc);
extern const char* TIFFFileName(TIFF*);
extern const char* TIFFSetFileName(TIFF*, const char *);
extern void TIFFError(const char*, const char*, ...) __attribute__((__format__ (__printf__,2,3)));
extern void TIFFErrorExt(thandle_t, const char*, const char*, ...) __attribute__((__format__ (__printf__,3,4)));
extern void TIFFWarning(const char*, const char*, ...) __attribute__((__format__ (__printf__,2,3)));
extern void TIFFWarningExt(thandle_t, const char*, const char*, ...) __attribute__((__format__ (__printf__,3,4)));
extern TIFFErrorHandler TIFFSetErrorHandler(TIFFErrorHandler);
extern TIFFErrorHandlerExt TIFFSetErrorHandlerExt(TIFFErrorHandlerExt);
extern TIFFErrorHandler TIFFSetWarningHandler(TIFFErrorHandler);
extern TIFFErrorHandlerExt TIFFSetWarningHandlerExt(TIFFErrorHandlerExt);
extern TIFFExtendProc TIFFSetTagExtender(TIFFExtendProc);
extern uint32 TIFFComputeTile(TIFF* tif, uint32 x, uint32 y, uint32 z, uint16 s);
extern int TIFFCheckTile(TIFF* tif, uint32 x, uint32 y, uint32 z, uint16 s);
extern uint32 TIFFNumberOfTiles(TIFF*);
extern tmsize_t TIFFReadTile(TIFF* tif, void* buf, uint32 x, uint32 y, uint32 z, uint16 s);
extern tmsize_t TIFFWriteTile(TIFF* tif, void* buf, uint32 x, uint32 y, uint32 z, uint16 s);
extern uint32 TIFFComputeStrip(TIFF*, uint32, uint16);
extern uint32 TIFFNumberOfStrips(TIFF*);
extern tmsize_t TIFFReadEncodedStrip(TIFF* tif, uint32 strip, void* buf, tmsize_t size);
extern tmsize_t TIFFReadRawStrip(TIFF* tif, uint32 strip, void* buf, tmsize_t size);
extern tmsize_t TIFFReadEncodedTile(TIFF* tif, uint32 tile, void* buf, tmsize_t size);
extern tmsize_t TIFFReadRawTile(TIFF* tif, uint32 tile, void* buf, tmsize_t size);
extern tmsize_t TIFFWriteEncodedStrip(TIFF* tif, uint32 strip, void* data, tmsize_t cc);
extern tmsize_t TIFFWriteRawStrip(TIFF* tif, uint32 strip, void* data, tmsize_t cc);
extern tmsize_t TIFFWriteEncodedTile(TIFF* tif, uint32 tile, void* data, tmsize_t cc);
extern tmsize_t TIFFWriteRawTile(TIFF* tif, uint32 tile, void* data, tmsize_t cc);
extern int TIFFDataWidth(TIFFDataType); /* table of tag datatype widths */
extern void TIFFSetWriteOffset(TIFF* tif, toff_t off);
extern void TIFFSwabShort(uint16*);
extern void TIFFSwabLong(uint32*);
extern void TIFFSwabLong8(uint64*);
extern void TIFFSwabFloat(float*);
extern void TIFFSwabDouble(double*);
extern void TIFFSwabArrayOfShort(uint16* wp, tmsize_t n);
extern void TIFFSwabArrayOfTriples(uint8* tp, tmsize_t n);
extern void TIFFSwabArrayOfLong(uint32* lp, tmsize_t n);
extern void TIFFSwabArrayOfLong8(uint64* lp, tmsize_t n);
extern void TIFFSwabArrayOfFloat(float* fp, tmsize_t n);
extern void TIFFSwabArrayOfDouble(double* dp, tmsize_t n);
extern void TIFFReverseBits(uint8* cp, tmsize_t n);
extern const unsigned char* TIFFGetBitRevTable(int);
#ifdef LOGLUV_PUBLIC
#define U_NEU 0.210526316
#define V_NEU 0.473684211
#define UVSCALE 410.
extern double LogL16toY(int);
extern double LogL10toY(int);
extern void XYZtoRGB24(float*, uint8*);
extern int uv_decode(double*, double*, int);
extern void LogLuv24toXYZ(uint32, float*);
extern void LogLuv32toXYZ(uint32, float*);
#if defined(c_plusplus) || defined(__cplusplus)
extern int LogL16fromY(double, int = SGILOGENCODE_NODITHER);
extern int LogL10fromY(double, int = SGILOGENCODE_NODITHER);
extern int uv_encode(double, double, int = SGILOGENCODE_NODITHER);
extern uint32 LogLuv24fromXYZ(float*, int = SGILOGENCODE_NODITHER);
extern uint32 LogLuv32fromXYZ(float*, int = SGILOGENCODE_NODITHER);
#else
extern int LogL16fromY(double, int);
extern int LogL10fromY(double, int);
extern int uv_encode(double, double, int);
extern uint32 LogLuv24fromXYZ(float*, int);
extern uint32 LogLuv32fromXYZ(float*, int);
#endif
#endif /* LOGLUV_PUBLIC */
extern int TIFFCIELabToRGBInit(TIFFCIELabToRGB*, const TIFFDisplay *, float*);
extern void TIFFCIELabToXYZ(TIFFCIELabToRGB *, uint32, int32, int32,
float *, float *, float *);
extern void TIFFXYZToRGB(TIFFCIELabToRGB *, float, float, float,
uint32 *, uint32 *, uint32 *);
extern int TIFFYCbCrToRGBInit(TIFFYCbCrToRGB*, float*, float*);
extern void TIFFYCbCrtoRGB(TIFFYCbCrToRGB *, uint32, int32, int32,
uint32 *, uint32 *, uint32 *);
/****************************************************************************
* O B S O L E T E D I N T E R F A C E S
*
* Don't use this stuff in your applications, it may be removed in the future
* libtiff versions.
****************************************************************************/
typedef struct { typedef struct {
ttag_t field_tag; /* field's tag */ ttag_t field_tag; /* field's tag */
short field_readcount; /* read count/TIFF_VARIABLE/TIFF_SPP */ short field_readcount; /* read count/TIFF_VARIABLE/TIFF_SPP */
@ -311,205 +529,8 @@ typedef struct {
char *field_name; /* ASCII name */ char *field_name; /* ASCII name */
} TIFFFieldInfo; } TIFFFieldInfo;
typedef struct _TIFFTagValue { extern int TIFFMergeFieldInfo(TIFF*, const TIFFFieldInfo[], uint32);
const TIFFFieldInfo *info;
int count;
void *value;
} TIFFTagValue;
extern void TIFFMergeFieldInfo(TIFF*, const TIFFFieldInfo[], int);
extern const TIFFFieldInfo* TIFFFindFieldInfo(TIFF*, ttag_t, TIFFDataType);
extern const TIFFFieldInfo* TIFFFindFieldInfoByName(TIFF* , const char *,
TIFFDataType);
extern const TIFFFieldInfo* TIFFFieldWithTag(TIFF*, ttag_t);
extern const TIFFFieldInfo* TIFFFieldWithName(TIFF*, const char *);
typedef int (*TIFFVSetMethod)(TIFF*, ttag_t, va_list);
typedef int (*TIFFVGetMethod)(TIFF*, ttag_t, va_list);
typedef void (*TIFFPrintMethod)(TIFF*, FILE*, long);
typedef struct {
TIFFVSetMethod vsetfield; /* tag set routine */
TIFFVGetMethod vgetfield; /* tag get routine */
TIFFPrintMethod printdir; /* directory print routine */
} TIFFTagMethods;
extern TIFFTagMethods *TIFFAccessTagMethods( TIFF * );
extern void *TIFFGetClientInfo( TIFF *, const char * );
extern void TIFFSetClientInfo( TIFF *, void *, const char * );
extern void TIFFCleanup(TIFF*);
extern void TIFFClose(TIFF*);
extern int TIFFFlush(TIFF*);
extern int TIFFFlushData(TIFF*);
extern int TIFFGetField(TIFF*, ttag_t, ...);
extern int TIFFVGetField(TIFF*, ttag_t, va_list);
extern int TIFFGetFieldDefaulted(TIFF*, ttag_t, ...);
extern int TIFFVGetFieldDefaulted(TIFF*, ttag_t, va_list);
extern int TIFFReadDirectory(TIFF*);
extern int TIFFReadCustomDirectory(TIFF*, toff_t, const TIFFFieldInfo[],
size_t);
extern int TIFFReadEXIFDirectory(TIFF*, toff_t);
extern tsize_t TIFFScanlineSize(TIFF*);
extern tsize_t TIFFOldScanlineSize(TIFF*);
extern tsize_t TIFFNewScanlineSize(TIFF*);
extern tsize_t TIFFRasterScanlineSize(TIFF*);
extern tsize_t TIFFStripSize(TIFF*);
extern tsize_t TIFFRawStripSize(TIFF*, tstrip_t);
extern tsize_t TIFFVStripSize(TIFF*, uint32);
extern tsize_t TIFFTileRowSize(TIFF*);
extern tsize_t TIFFTileSize(TIFF*);
extern tsize_t TIFFVTileSize(TIFF*, uint32);
extern uint32 TIFFDefaultStripSize(TIFF*, uint32);
extern void TIFFDefaultTileSize(TIFF*, uint32*, uint32*);
extern int TIFFFileno(TIFF*);
extern int TIFFSetFileno(TIFF*, int);
extern thandle_t TIFFClientdata(TIFF*);
extern thandle_t TIFFSetClientdata(TIFF*, thandle_t);
extern int TIFFGetMode(TIFF*);
extern int TIFFSetMode(TIFF*, int);
extern int TIFFIsTiled(TIFF*);
extern int TIFFIsByteSwapped(TIFF*);
extern int TIFFIsUpSampled(TIFF*);
extern int TIFFIsMSB2LSB(TIFF*);
extern int TIFFIsBigEndian(TIFF*);
extern TIFFReadWriteProc TIFFGetReadProc(TIFF*);
extern TIFFReadWriteProc TIFFGetWriteProc(TIFF*);
extern TIFFSeekProc TIFFGetSeekProc(TIFF*);
extern TIFFCloseProc TIFFGetCloseProc(TIFF*);
extern TIFFSizeProc TIFFGetSizeProc(TIFF*);
extern TIFFMapFileProc TIFFGetMapFileProc(TIFF*);
extern TIFFUnmapFileProc TIFFGetUnmapFileProc(TIFF*);
extern uint32 TIFFCurrentRow(TIFF*);
extern tdir_t TIFFCurrentDirectory(TIFF*);
extern tdir_t TIFFNumberOfDirectories(TIFF*);
extern uint32 TIFFCurrentDirOffset(TIFF*);
extern tstrip_t TIFFCurrentStrip(TIFF*);
extern ttile_t TIFFCurrentTile(TIFF*);
extern int TIFFReadBufferSetup(TIFF*, tdata_t, tsize_t);
extern int TIFFWriteBufferSetup(TIFF*, tdata_t, tsize_t);
extern int TIFFSetupStrips(TIFF *);
extern int TIFFWriteCheck(TIFF*, int, const char *);
extern void TIFFFreeDirectory(TIFF*);
extern int TIFFCreateDirectory(TIFF*);
extern int TIFFLastDirectory(TIFF*);
extern int TIFFSetDirectory(TIFF*, tdir_t);
extern int TIFFSetSubDirectory(TIFF*, uint32);
extern int TIFFUnlinkDirectory(TIFF*, tdir_t);
extern int TIFFSetField(TIFF*, ttag_t, ...);
extern int TIFFVSetField(TIFF*, ttag_t, va_list);
extern int TIFFWriteDirectory(TIFF *);
extern int TIFFCheckpointDirectory(TIFF *);
extern int TIFFRewriteDirectory(TIFF *);
extern int TIFFReassignTagToIgnore(enum TIFFIgnoreSense, int);
#if defined(c_plusplus) || defined(__cplusplus)
extern void TIFFPrintDirectory(TIFF*, FILE*, long = 0);
extern int TIFFReadScanline(TIFF*, tdata_t, uint32, tsample_t = 0);
extern int TIFFWriteScanline(TIFF*, tdata_t, uint32, tsample_t = 0);
extern int TIFFReadRGBAImage(TIFF*, uint32, uint32, uint32*, int = 0);
extern int TIFFReadRGBAImageOriented(TIFF*, uint32, uint32, uint32*,
int = ORIENTATION_BOTLEFT, int = 0);
#else
extern void TIFFPrintDirectory(TIFF*, FILE*, long);
extern int TIFFReadScanline(TIFF*, tdata_t, uint32, tsample_t);
extern int TIFFWriteScanline(TIFF*, tdata_t, uint32, tsample_t);
extern int TIFFReadRGBAImage(TIFF*, uint32, uint32, uint32*, int);
extern int TIFFReadRGBAImageOriented(TIFF*, uint32, uint32, uint32*, int, int);
#endif
extern int TIFFReadRGBAStrip(TIFF*, tstrip_t, uint32 * );
extern int TIFFReadRGBATile(TIFF*, uint32, uint32, uint32 * );
extern int TIFFRGBAImageOK(TIFF*, char [1024]);
extern int TIFFRGBAImageBegin(TIFFRGBAImage*, TIFF*, int, char [1024]);
extern int TIFFRGBAImageGet(TIFFRGBAImage*, uint32*, uint32, uint32);
extern void TIFFRGBAImageEnd(TIFFRGBAImage*);
extern TIFF* TIFFOpen(const char*, const char*);
# ifdef __WIN32__
extern TIFF* TIFFOpenW(const wchar_t*, const char*);
# endif /* __WIN32__ */
extern TIFF* TIFFFdOpen(int, const char*, const char*);
extern TIFF* TIFFClientOpen(const char*, const char*,
thandle_t,
TIFFReadWriteProc, TIFFReadWriteProc,
TIFFSeekProc, TIFFCloseProc,
TIFFSizeProc,
TIFFMapFileProc, TIFFUnmapFileProc);
extern const char* TIFFFileName(TIFF*);
extern const char* TIFFSetFileName(TIFF*, const char *);
extern void TIFFError(const char*, const char*, ...) __attribute__((format (printf,2,3)));
extern void TIFFErrorExt(thandle_t, const char*, const char*, ...) __attribute__((format (printf,3,4)));
extern void TIFFWarning(const char*, const char*, ...) __attribute__((format (printf,2,3)));
extern void TIFFWarningExt(thandle_t, const char*, const char*, ...) __attribute__((format (printf,3,4)));
extern TIFFErrorHandler TIFFSetErrorHandler(TIFFErrorHandler);
extern TIFFErrorHandlerExt TIFFSetErrorHandlerExt(TIFFErrorHandlerExt);
extern TIFFErrorHandler TIFFSetWarningHandler(TIFFErrorHandler);
extern TIFFErrorHandlerExt TIFFSetWarningHandlerExt(TIFFErrorHandlerExt);
extern TIFFExtendProc TIFFSetTagExtender(TIFFExtendProc);
extern ttile_t TIFFComputeTile(TIFF*, uint32, uint32, uint32, tsample_t);
extern int TIFFCheckTile(TIFF*, uint32, uint32, uint32, tsample_t);
extern ttile_t TIFFNumberOfTiles(TIFF*);
extern tsize_t TIFFReadTile(TIFF*,
tdata_t, uint32, uint32, uint32, tsample_t);
extern tsize_t TIFFWriteTile(TIFF*,
tdata_t, uint32, uint32, uint32, tsample_t);
extern tstrip_t TIFFComputeStrip(TIFF*, uint32, tsample_t);
extern tstrip_t TIFFNumberOfStrips(TIFF*);
extern tsize_t TIFFReadEncodedStrip(TIFF*, tstrip_t, tdata_t, tsize_t);
extern tsize_t TIFFReadRawStrip(TIFF*, tstrip_t, tdata_t, tsize_t);
extern tsize_t TIFFReadEncodedTile(TIFF*, ttile_t, tdata_t, tsize_t);
extern tsize_t TIFFReadRawTile(TIFF*, ttile_t, tdata_t, tsize_t);
extern tsize_t TIFFWriteEncodedStrip(TIFF*, tstrip_t, tdata_t, tsize_t);
extern tsize_t TIFFWriteRawStrip(TIFF*, tstrip_t, tdata_t, tsize_t);
extern tsize_t TIFFWriteEncodedTile(TIFF*, ttile_t, tdata_t, tsize_t);
extern tsize_t TIFFWriteRawTile(TIFF*, ttile_t, tdata_t, tsize_t);
extern int TIFFDataWidth(TIFFDataType); /* table of tag datatype widths */
extern void TIFFSetWriteOffset(TIFF*, toff_t);
extern void TIFFSwabShort(uint16*);
extern void TIFFSwabLong(uint32*);
extern void TIFFSwabDouble(double*);
extern void TIFFSwabArrayOfShort(uint16*, unsigned long);
extern void TIFFSwabArrayOfTriples(uint8*, unsigned long);
extern void TIFFSwabArrayOfLong(uint32*, unsigned long);
extern void TIFFSwabArrayOfDouble(double*, unsigned long);
extern void TIFFReverseBits(unsigned char *, unsigned long);
extern const unsigned char* TIFFGetBitRevTable(int);
#ifdef LOGLUV_PUBLIC
#define U_NEU 0.210526316
#define V_NEU 0.473684211
#define UVSCALE 410.
extern double LogL16toY(int);
extern double LogL10toY(int);
extern void XYZtoRGB24(float*, uint8*);
extern int uv_decode(double*, double*, int);
extern void LogLuv24toXYZ(uint32, float*);
extern void LogLuv32toXYZ(uint32, float*);
#if defined(c_plusplus) || defined(__cplusplus)
extern int LogL16fromY(double, int = SGILOGENCODE_NODITHER);
extern int LogL10fromY(double, int = SGILOGENCODE_NODITHER);
extern int uv_encode(double, double, int = SGILOGENCODE_NODITHER);
extern uint32 LogLuv24fromXYZ(float*, int = SGILOGENCODE_NODITHER);
extern uint32 LogLuv32fromXYZ(float*, int = SGILOGENCODE_NODITHER);
#else
extern int LogL16fromY(double, int);
extern int LogL10fromY(double, int);
extern int uv_encode(double, double, int);
extern uint32 LogLuv24fromXYZ(float*, int);
extern uint32 LogLuv32fromXYZ(float*, int);
#endif
#endif /* LOGLUV_PUBLIC */
extern int TIFFCIELabToRGBInit(TIFFCIELabToRGB*, TIFFDisplay *, float*);
extern void TIFFCIELabToXYZ(TIFFCIELabToRGB *, uint32, int32, int32,
float *, float *, float *);
extern void TIFFXYZToRGB(TIFFCIELabToRGB *, float, float, float,
uint32 *, uint32 *, uint32 *);
extern int TIFFYCbCrToRGBInit(TIFFYCbCrToRGB*, float*, float*);
extern void TIFFYCbCrtoRGB(TIFFYCbCrToRGB *, uint32, int32, int32,
uint32 *, uint32 *, uint32 *);
#if defined(c_plusplus) || defined(__cplusplus) #if defined(c_plusplus) || defined(__cplusplus)
} }
#endif #endif

View File

@ -1,4 +1,4 @@
/* $Id: tiffio.hxx,v 1.1.2.1 2010-06-08 18:50:43 bfriesen Exp $ */ /* $Id: tiffio.hxx,v 1.3 2010-06-08 18:55:15 bfriesen Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -34,8 +34,8 @@
#include <iostream> #include <iostream>
#include "tiff.h" #include "tiff.h"
extern TIFF* TIFFStreamOpen(const char*, std::ostream *); extern TIFF* TIFFStreamOpen(const char*, std::ostream *);
extern TIFF* TIFFStreamOpen(const char*, std::istream *); extern TIFF* TIFFStreamOpen(const char*, std::istream *);
#endif /* _TIFFIO_HXX_ */ #endif /* _TIFFIO_HXX_ */

View File

@ -1,4 +1,4 @@
/* $Id: tiffiop.h,v 1.51.2.6 2010-06-12 02:55:16 bfriesen Exp $ */ /* $Id: tiffiop.h,v 1.82 2011-02-18 20:53:05 fwarmerdam Exp $ */
/* /*
* Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1988-1997 Sam Leffler
@ -57,14 +57,8 @@ extern void *lfind(const void *, const void *, size_t *, size_t,
int (*)(const void *, const void *)); int (*)(const void *, const void *));
#endif #endif
/*
Libtiff itself does not require a 64-bit type, but bundled TIFF
utilities may use it.
*/
typedef TIFF_INT64_T int64;
typedef TIFF_UINT64_T uint64;
#include "tiffio.h" #include "tiffio.h"
#include "tif_dir.h" #include "tif_dir.h"
#ifndef STRIP_SIZE_DEFAULT #ifndef STRIP_SIZE_DEFAULT
@ -80,167 +74,180 @@ typedef TIFF_UINT64_T uint64;
typedef struct client_info { typedef struct client_info {
struct client_info *next; struct client_info *next;
void *data; void *data;
char *name; char *name;
} TIFFClientInfoLink; } TIFFClientInfoLink;
/* /*
* Typedefs for ``method pointers'' used internally. * Typedefs for ``method pointers'' used internally.
* these are depriciated and provided only for backwards compatibility
*/ */
typedef unsigned char tidataval_t; /* internal image data value type */ typedef unsigned char tidataval_t; /* internal image data value type */
typedef tidataval_t* tidata_t; /* reference to internal image data */ typedef tidataval_t* tidata_t; /* reference to internal image data */
typedef void (*TIFFVoidMethod)(TIFF*); typedef void (*TIFFVoidMethod)(TIFF*);
typedef int (*TIFFBoolMethod)(TIFF*); typedef int (*TIFFBoolMethod)(TIFF*);
typedef int (*TIFFPreMethod)(TIFF*, tsample_t); typedef int (*TIFFPreMethod)(TIFF*, uint16);
typedef int (*TIFFCodeMethod)(TIFF*, tidata_t, tsize_t, tsample_t); typedef int (*TIFFCodeMethod)(TIFF* tif, uint8* buf, tmsize_t size, uint16 sample);
typedef int (*TIFFSeekMethod)(TIFF*, uint32); typedef int (*TIFFSeekMethod)(TIFF*, uint32);
typedef void (*TIFFPostMethod)(TIFF*, tidata_t, tsize_t); typedef void (*TIFFPostMethod)(TIFF* tif, uint8* buf, tmsize_t size);
typedef uint32 (*TIFFStripMethod)(TIFF*, uint32); typedef uint32 (*TIFFStripMethod)(TIFF*, uint32);
typedef void (*TIFFTileMethod)(TIFF*, uint32*, uint32*); typedef void (*TIFFTileMethod)(TIFF*, uint32*, uint32*);
struct tiff { struct tiff {
char* tif_name; /* name of open file */ char* tif_name; /* name of open file */
int tif_fd; /* open file descriptor */ int tif_fd; /* open file descriptor */
int tif_mode; /* open mode (O_*) */ int tif_mode; /* open mode (O_*) */
uint32 tif_flags; uint32 tif_flags;
#define TIFF_FILLORDER 0x00003 /* natural bit fill order for machine */ #define TIFF_FILLORDER 0x00003 /* natural bit fill order for machine */
#define TIFF_DIRTYHEADER 0x00004 /* header must be written on close */ #define TIFF_DIRTYHEADER 0x00004 /* header must be written on close */
#define TIFF_DIRTYDIRECT 0x00008 /* current directory must be written */ #define TIFF_DIRTYDIRECT 0x00008 /* current directory must be written */
#define TIFF_BUFFERSETUP 0x00010 /* data buffers setup */ #define TIFF_BUFFERSETUP 0x00010 /* data buffers setup */
#define TIFF_CODERSETUP 0x00020 /* encoder/decoder setup done */ #define TIFF_CODERSETUP 0x00020 /* encoder/decoder setup done */
#define TIFF_BEENWRITING 0x00040 /* written 1+ scanlines to file */ #define TIFF_BEENWRITING 0x00040 /* written 1+ scanlines to file */
#define TIFF_SWAB 0x00080 /* byte swap file information */ #define TIFF_SWAB 0x00080 /* byte swap file information */
#define TIFF_NOBITREV 0x00100 /* inhibit bit reversal logic */ #define TIFF_NOBITREV 0x00100 /* inhibit bit reversal logic */
#define TIFF_MYBUFFER 0x00200 /* my raw data buffer; free on close */ #define TIFF_MYBUFFER 0x00200 /* my raw data buffer; free on close */
#define TIFF_ISTILED 0x00400 /* file is tile, not strip- based */ #define TIFF_ISTILED 0x00400 /* file is tile, not strip- based */
#define TIFF_MAPPED 0x00800 /* file is mapped into memory */ #define TIFF_MAPPED 0x00800 /* file is mapped into memory */
#define TIFF_POSTENCODE 0x01000 /* need call to postencode routine */ #define TIFF_POSTENCODE 0x01000 /* need call to postencode routine */
#define TIFF_INSUBIFD 0x02000 /* currently writing a subifd */ #define TIFF_INSUBIFD 0x02000 /* currently writing a subifd */
#define TIFF_UPSAMPLED 0x04000 /* library is doing data up-sampling */ #define TIFF_UPSAMPLED 0x04000 /* library is doing data up-sampling */
#define TIFF_STRIPCHOP 0x08000 /* enable strip chopping support */ #define TIFF_STRIPCHOP 0x08000 /* enable strip chopping support */
#define TIFF_HEADERONLY 0x10000 /* read header only, do not process */ #define TIFF_HEADERONLY 0x10000 /* read header only, do not process the first directory */
/* the first directory */ #define TIFF_NOREADRAW 0x20000 /* skip reading of raw uncompressed image data */
#define TIFF_NOREADRAW 0x20000 /* skip reading of raw uncompressed */ #define TIFF_INCUSTOMIFD 0x40000 /* currently writing a custom IFD */
/* image data */ #define TIFF_BIGTIFF 0x80000 /* read/write bigtiff */
#define TIFF_INCUSTOMIFD 0x40000 /* currently writing a custom IFD */ #define TIFF_BUF4WRITE 0x100000 /* rawcc bytes are for writing */
toff_t tif_diroff; /* file offset of current directory */ #define TIFF_DIRTYSTRIP 0x200000 /* stripoffsets/stripbytecount dirty*/
toff_t tif_nextdiroff; /* file offset of following directory */ #define TIFF_PERSAMPLE 0x400000 /* get/set per sample tags as arrays */
toff_t* tif_dirlist; /* list of offsets to already seen */ uint64 tif_diroff; /* file offset of current directory */
/* directories to prevent IFD looping */ uint64 tif_nextdiroff; /* file offset of following directory */
tsize_t tif_dirlistsize;/* number of entires in offset list */ uint64* tif_dirlist; /* list of offsets to already seen directories to prevent IFD looping */
uint16 tif_dirnumber; /* number of already seen directories */ uint16 tif_dirlistsize; /* number of entires in offset list */
TIFFDirectory tif_dir; /* internal rep of current directory */ uint16 tif_dirnumber; /* number of already seen directories */
TIFFDirectory tif_customdir; /* custom IFDs are separated from TIFFDirectory tif_dir; /* internal rep of current directory */
the main ones */ TIFFDirectory tif_customdir; /* custom IFDs are separated from the main ones */
TIFFHeader tif_header; /* file's header block */ union {
const int* tif_typeshift; /* data type shift counts */ TIFFHeaderCommon common;
const long* tif_typemask; /* data type masks */ TIFFHeaderClassic classic;
uint32 tif_row; /* current scanline */ TIFFHeaderBig big;
tdir_t tif_curdir; /* current directory (index) */ } tif_header;
tstrip_t tif_curstrip; /* current strip for read/write */ uint16 tif_header_size; /* file's header block and its length */
toff_t tif_curoff; /* current offset for read/write */ uint32 tif_row; /* current scanline */
toff_t tif_dataoff; /* current offset for writing dir */ uint16 tif_curdir; /* current directory (index) */
/* SubIFD support */ uint32 tif_curstrip; /* current strip for read/write */
uint16 tif_nsubifd; /* remaining subifds to write */ uint64 tif_curoff; /* current offset for read/write */
toff_t tif_subifdoff; /* offset for patching SubIFD link */ uint64 tif_dataoff; /* current offset for writing dir */
/* tiling support */ /* SubIFD support */
uint32 tif_col; /* current column (offset by row too) */ uint16 tif_nsubifd; /* remaining subifds to write */
ttile_t tif_curtile; /* current tile for read/write */ uint64 tif_subifdoff; /* offset for patching SubIFD link */
tsize_t tif_tilesize; /* # of bytes in a tile */ /* tiling support */
/* compression scheme hooks */ uint32 tif_col; /* current column (offset by row too) */
int tif_decodestatus; uint32 tif_curtile; /* current tile for read/write */
TIFFBoolMethod tif_setupdecode;/* called once before predecode */ tmsize_t tif_tilesize; /* # of bytes in a tile */
TIFFPreMethod tif_predecode; /* pre- row/strip/tile decoding */ /* compression scheme hooks */
TIFFBoolMethod tif_setupencode;/* called once before preencode */ int tif_decodestatus;
int tif_encodestatus; TIFFBoolMethod tif_fixuptags; /* called in TIFFReadDirectory */
TIFFPreMethod tif_preencode; /* pre- row/strip/tile encoding */ TIFFBoolMethod tif_setupdecode; /* called once before predecode */
TIFFBoolMethod tif_postencode; /* post- row/strip/tile encoding */ TIFFPreMethod tif_predecode; /* pre- row/strip/tile decoding */
TIFFCodeMethod tif_decoderow; /* scanline decoding routine */ TIFFBoolMethod tif_setupencode; /* called once before preencode */
TIFFCodeMethod tif_encoderow; /* scanline encoding routine */ int tif_encodestatus;
TIFFCodeMethod tif_decodestrip;/* strip decoding routine */ TIFFPreMethod tif_preencode; /* pre- row/strip/tile encoding */
TIFFCodeMethod tif_encodestrip;/* strip encoding routine */ TIFFBoolMethod tif_postencode; /* post- row/strip/tile encoding */
TIFFCodeMethod tif_decodetile; /* tile decoding routine */ TIFFCodeMethod tif_decoderow; /* scanline decoding routine */
TIFFCodeMethod tif_encodetile; /* tile encoding routine */ TIFFCodeMethod tif_encoderow; /* scanline encoding routine */
TIFFVoidMethod tif_close; /* cleanup-on-close routine */ TIFFCodeMethod tif_decodestrip; /* strip decoding routine */
TIFFSeekMethod tif_seek; /* position within a strip routine */ TIFFCodeMethod tif_encodestrip; /* strip encoding routine */
TIFFVoidMethod tif_cleanup; /* cleanup state routine */ TIFFCodeMethod tif_decodetile; /* tile decoding routine */
TIFFStripMethod tif_defstripsize;/* calculate/constrain strip size */ TIFFCodeMethod tif_encodetile; /* tile encoding routine */
TIFFTileMethod tif_deftilesize;/* calculate/constrain tile size */ TIFFVoidMethod tif_close; /* cleanup-on-close routine */
tidata_t tif_data; /* compression scheme private data */ TIFFSeekMethod tif_seek; /* position within a strip routine */
/* input/output buffering */ TIFFVoidMethod tif_cleanup; /* cleanup state routine */
tsize_t tif_scanlinesize;/* # of bytes in a scanline */ TIFFStripMethod tif_defstripsize; /* calculate/constrain strip size */
tsize_t tif_scanlineskew;/* scanline skew for reading strips */ TIFFTileMethod tif_deftilesize; /* calculate/constrain tile size */
tidata_t tif_rawdata; /* raw data buffer */ uint8* tif_data; /* compression scheme private data */
tsize_t tif_rawdatasize;/* # of bytes in raw data buffer */ /* input/output buffering */
tidata_t tif_rawcp; /* current spot in raw buffer */ tmsize_t tif_scanlinesize; /* # of bytes in a scanline */
tsize_t tif_rawcc; /* bytes unread from raw buffer */ tmsize_t tif_scanlineskew; /* scanline skew for reading strips */
/* memory-mapped file support */ uint8* tif_rawdata; /* raw data buffer */
tidata_t tif_base; /* base of mapped file */ tmsize_t tif_rawdatasize; /* # of bytes in raw data buffer */
toff_t tif_size; /* size of mapped file region (bytes) tmsize_t tif_rawdataoff; /* rawdata offset within strip */
FIXME: it should be tsize_t */ tmsize_t tif_rawdataloaded;/* amount of data in rawdata */
TIFFMapFileProc tif_mapproc; /* map file method */ uint8* tif_rawcp; /* current spot in raw buffer */
TIFFUnmapFileProc tif_unmapproc;/* unmap file method */ tmsize_t tif_rawcc; /* bytes unread from raw buffer */
/* input/output callback methods */ /* memory-mapped file support */
thandle_t tif_clientdata; /* callback parameter */ uint8* tif_base; /* base of mapped file */
TIFFReadWriteProc tif_readproc; /* read method */ tmsize_t tif_size; /* size of mapped file region (bytes, thus tmsize_t) */
TIFFReadWriteProc tif_writeproc;/* write method */ TIFFMapFileProc tif_mapproc; /* map file method */
TIFFSeekProc tif_seekproc; /* lseek method */ TIFFUnmapFileProc tif_unmapproc; /* unmap file method */
TIFFCloseProc tif_closeproc; /* close method */ /* input/output callback methods */
TIFFSizeProc tif_sizeproc; /* filesize method */ thandle_t tif_clientdata; /* callback parameter */
/* post-decoding support */ TIFFReadWriteProc tif_readproc; /* read method */
TIFFPostMethod tif_postdecode; /* post decoding routine */ TIFFReadWriteProc tif_writeproc; /* write method */
/* tag support */ TIFFSeekProc tif_seekproc; /* lseek method */
TIFFFieldInfo** tif_fieldinfo; /* sorted table of registered tags */ TIFFCloseProc tif_closeproc; /* close method */
size_t tif_nfields; /* # entries in registered tag table */ TIFFSizeProc tif_sizeproc; /* filesize method */
const TIFFFieldInfo *tif_foundfield;/* cached pointer to already found tag */ /* post-decoding support */
TIFFTagMethods tif_tagmethods; /* tag get/set/print routines */ TIFFPostMethod tif_postdecode; /* post decoding routine */
TIFFClientInfoLink *tif_clientinfo; /* extra client information. */ /* tag support */
TIFFField** tif_fields; /* sorted table of registered tags */
size_t tif_nfields; /* # entries in registered tag table */
const TIFFField* tif_foundfield; /* cached pointer to already found tag */
TIFFTagMethods tif_tagmethods; /* tag get/set/print routines */
TIFFClientInfoLink* tif_clientinfo; /* extra client information. */
/* Backward compatibility stuff. We need these two fields for
* setting up an old tag extension scheme. */
TIFFFieldArray* tif_fieldscompat;
size_t tif_nfieldscompat;
}; };
#define isPseudoTag(t) (t > 0xffff) /* is tag value normal or pseudo */ #define isPseudoTag(t) (t > 0xffff) /* is tag value normal or pseudo */
#define isTiled(tif) (((tif)->tif_flags & TIFF_ISTILED) != 0) #define isTiled(tif) (((tif)->tif_flags & TIFF_ISTILED) != 0)
#define isMapped(tif) (((tif)->tif_flags & TIFF_MAPPED) != 0) #define isMapped(tif) (((tif)->tif_flags & TIFF_MAPPED) != 0)
#define isFillOrder(tif, o) (((tif)->tif_flags & (o)) != 0) #define isFillOrder(tif, o) (((tif)->tif_flags & (o)) != 0)
#define isUpSampled(tif) (((tif)->tif_flags & TIFF_UPSAMPLED) != 0) #define isUpSampled(tif) (((tif)->tif_flags & TIFF_UPSAMPLED) != 0)
#define TIFFReadFile(tif, buf, size) \ #define TIFFReadFile(tif, buf, size) \
((*(tif)->tif_readproc)((tif)->tif_clientdata,buf,size)) ((*(tif)->tif_readproc)((tif)->tif_clientdata,(buf),(size)))
#define TIFFWriteFile(tif, buf, size) \ #define TIFFWriteFile(tif, buf, size) \
((*(tif)->tif_writeproc)((tif)->tif_clientdata,buf,size)) ((*(tif)->tif_writeproc)((tif)->tif_clientdata,(buf),(size)))
#define TIFFSeekFile(tif, off, whence) \ #define TIFFSeekFile(tif, off, whence) \
((*(tif)->tif_seekproc)((tif)->tif_clientdata,(toff_t)(off),whence)) ((*(tif)->tif_seekproc)((tif)->tif_clientdata,(off),(whence)))
#define TIFFCloseFile(tif) \ #define TIFFCloseFile(tif) \
((*(tif)->tif_closeproc)((tif)->tif_clientdata)) ((*(tif)->tif_closeproc)((tif)->tif_clientdata))
#define TIFFGetFileSize(tif) \ #define TIFFGetFileSize(tif) \
((*(tif)->tif_sizeproc)((tif)->tif_clientdata)) ((*(tif)->tif_sizeproc)((tif)->tif_clientdata))
#define TIFFMapFileContents(tif, paddr, psize) \ #define TIFFMapFileContents(tif, paddr, psize) \
((*(tif)->tif_mapproc)((tif)->tif_clientdata,paddr,psize)) ((*(tif)->tif_mapproc)((tif)->tif_clientdata,(paddr),(psize)))
#define TIFFUnmapFileContents(tif, addr, size) \ #define TIFFUnmapFileContents(tif, addr, size) \
((*(tif)->tif_unmapproc)((tif)->tif_clientdata,addr,size)) ((*(tif)->tif_unmapproc)((tif)->tif_clientdata,(addr),(size)))
/* /*
* Default Read/Seek/Write definitions. * Default Read/Seek/Write definitions.
*/ */
#ifndef ReadOK #ifndef ReadOK
#define ReadOK(tif, buf, size) \ #define ReadOK(tif, buf, size) \
(TIFFReadFile(tif, (tdata_t) buf, (tsize_t)(size)) == (tsize_t)(size)) (TIFFReadFile((tif),(buf),(size))==(size))
#endif #endif
#ifndef SeekOK #ifndef SeekOK
#define SeekOK(tif, off) \ #define SeekOK(tif, off) \
(TIFFSeekFile(tif, (toff_t) off, SEEK_SET) == (toff_t) off) (TIFFSeekFile((tif),(off),SEEK_SET)==(off))
#endif #endif
#ifndef WriteOK #ifndef WriteOK
#define WriteOK(tif, buf, size) \ #define WriteOK(tif, buf, size) \
(TIFFWriteFile(tif, (tdata_t) buf, (tsize_t) size) == (tsize_t) size) (TIFFWriteFile((tif),(buf),(size))==(size))
#endif #endif
/* NB: the uint32 casts are to silence certain ANSI-C compilers */ /* NB: the uint32 casts are to silence certain ANSI-C compilers */
#define TIFFhowmany(x, y) (((uint32)x < (0xffffffff - (uint32)(y-1))) ? \ #define TIFFhowmany_32(x, y) (((uint32)x < (0xffffffff - (uint32)(y-1))) ? \
((((uint32)(x))+(((uint32)(y))-1))/((uint32)(y))) : \ ((((uint32)(x))+(((uint32)(y))-1))/((uint32)(y))) : \
0U) 0U)
#define TIFFhowmany8(x) (((x)&0x07)?((uint32)(x)>>3)+1:(uint32)(x)>>3) #define TIFFhowmany8_32(x) (((x)&0x07)?((uint32)(x)>>3)+1:(uint32)(x)>>3)
#define TIFFroundup(x, y) (TIFFhowmany(x,y)*(y)) #define TIFFroundup_32(x, y) (TIFFhowmany_32(x,y)*(y))
#define TIFFhowmany_64(x, y) ((((uint64)(x))+(((uint64)(y))-1))/((uint64)(y)))
#define TIFFhowmany8_64(x) (((x)&0x07)?((uint64)(x)>>3)+1:(uint64)(x)>>3)
#define TIFFroundup_64(x, y) (TIFFhowmany_64(x,y)*(y))
/* Safe multiply which returns zero if there is an integer overflow */ /* Safe multiply which returns zero if there is an integer overflow */
#define TIFFSafeMultiply(t,v,m) ((((t)m != (t)0) && (((t)((v*m)/m)) == (t)v)) ? (t)(v*m) : (t)0) #define TIFFSafeMultiply(t,v,m) ((((t)m != (t)0) && (((t)((v*m)/m)) == (t)v)) ? (t)(v*m) : (t)0)
@ -253,86 +260,95 @@ struct tiff {
#if defined(__cplusplus) #if defined(__cplusplus)
extern "C" { extern "C" {
#endif #endif
extern int _TIFFgetMode(const char*, const char*); extern int _TIFFgetMode(const char* mode, const char* module);
extern int _TIFFNoRowEncode(TIFF*, tidata_t, tsize_t, tsample_t); extern int _TIFFNoRowEncode(TIFF* tif, uint8* pp, tmsize_t cc, uint16 s);
extern int _TIFFNoStripEncode(TIFF*, tidata_t, tsize_t, tsample_t); extern int _TIFFNoStripEncode(TIFF* tif, uint8* pp, tmsize_t cc, uint16 s);
extern int _TIFFNoTileEncode(TIFF*, tidata_t, tsize_t, tsample_t); extern int _TIFFNoTileEncode(TIFF*, uint8* pp, tmsize_t cc, uint16 s);
extern int _TIFFNoRowDecode(TIFF*, tidata_t, tsize_t, tsample_t); extern int _TIFFNoRowDecode(TIFF* tif, uint8* pp, tmsize_t cc, uint16 s);
extern int _TIFFNoStripDecode(TIFF*, tidata_t, tsize_t, tsample_t); extern int _TIFFNoStripDecode(TIFF* tif, uint8* pp, tmsize_t cc, uint16 s);
extern int _TIFFNoTileDecode(TIFF*, tidata_t, tsize_t, tsample_t); extern int _TIFFNoTileDecode(TIFF*, uint8* pp, tmsize_t cc, uint16 s);
extern void _TIFFNoPostDecode(TIFF*, tidata_t, tsize_t); extern void _TIFFNoPostDecode(TIFF* tif, uint8* buf, tmsize_t cc);
extern int _TIFFNoPreCode (TIFF*, tsample_t); extern int _TIFFNoPreCode(TIFF* tif, uint16 s);
extern int _TIFFNoSeek(TIFF*, uint32); extern int _TIFFNoSeek(TIFF* tif, uint32 off);
extern void _TIFFSwab16BitData(TIFF*, tidata_t, tsize_t); extern void _TIFFSwab16BitData(TIFF* tif, uint8* buf, tmsize_t cc);
extern void _TIFFSwab24BitData(TIFF*, tidata_t, tsize_t); extern void _TIFFSwab24BitData(TIFF* tif, uint8* buf, tmsize_t cc);
extern void _TIFFSwab32BitData(TIFF*, tidata_t, tsize_t); extern void _TIFFSwab32BitData(TIFF* tif, uint8* buf, tmsize_t cc);
extern void _TIFFSwab64BitData(TIFF*, tidata_t, tsize_t); extern void _TIFFSwab64BitData(TIFF* tif, uint8* buf, tmsize_t cc);
extern int TIFFFlushData1(TIFF*); extern int TIFFFlushData1(TIFF* tif);
extern int TIFFDefaultDirectory(TIFF*); extern int TIFFDefaultDirectory(TIFF* tif);
extern void _TIFFSetDefaultCompressionState(TIFF*); extern void _TIFFSetDefaultCompressionState(TIFF* tif);
extern int TIFFSetCompressionScheme(TIFF*, int); extern int _TIFFRewriteField(TIFF *, uint16, TIFFDataType, tmsize_t, void *);
extern int TIFFSetDefaultCompressionState(TIFF*); extern int TIFFSetCompressionScheme(TIFF* tif, int scheme);
extern uint32 _TIFFDefaultStripSize(TIFF*, uint32); extern int TIFFSetDefaultCompressionState(TIFF* tif);
extern void _TIFFDefaultTileSize(TIFF*, uint32*, uint32*); extern uint32 _TIFFDefaultStripSize(TIFF* tif, uint32 s);
extern int _TIFFDataSize(TIFFDataType); extern void _TIFFDefaultTileSize(TIFF* tif, uint32* tw, uint32* th);
extern int _TIFFDataSize(TIFFDataType type);
extern void _TIFFsetByteArray(void**, void*, uint32); extern void _TIFFsetByteArray(void**, void*, uint32);
extern void _TIFFsetString(char**, char*); extern void _TIFFsetString(char**, char*);
extern void _TIFFsetShortArray(uint16**, uint16*, uint32); extern void _TIFFsetShortArray(uint16**, uint16*, uint32);
extern void _TIFFsetLongArray(uint32**, uint32*, uint32); extern void _TIFFsetLongArray(uint32**, uint32*, uint32);
extern void _TIFFsetFloatArray(float**, float*, uint32); extern void _TIFFsetFloatArray(float**, float*, uint32);
extern void _TIFFsetDoubleArray(double**, double*, uint32); extern void _TIFFsetDoubleArray(double**, double*, uint32);
extern void _TIFFprintAscii(FILE*, const char*); extern void _TIFFprintAscii(FILE*, const char*);
extern void _TIFFprintAsciiTag(FILE*, const char*, const char*); extern void _TIFFprintAsciiTag(FILE*, const char*, const char*);
extern TIFFErrorHandler _TIFFwarningHandler; extern TIFFErrorHandler _TIFFwarningHandler;
extern TIFFErrorHandler _TIFFerrorHandler; extern TIFFErrorHandler _TIFFerrorHandler;
extern TIFFErrorHandlerExt _TIFFwarningHandlerExt; extern TIFFErrorHandlerExt _TIFFwarningHandlerExt;
extern TIFFErrorHandlerExt _TIFFerrorHandlerExt; extern TIFFErrorHandlerExt _TIFFerrorHandlerExt;
extern tdata_t _TIFFCheckMalloc(TIFF*, size_t, size_t, const char*); extern uint32 _TIFFMultiply32(TIFF*, uint32, uint32, const char*);
extern tdata_t _TIFFCheckRealloc(TIFF*, tdata_t, size_t, size_t, const char*); extern uint64 _TIFFMultiply64(TIFF*, uint64, uint64, const char*);
extern void* _TIFFCheckMalloc(TIFF*, tmsize_t, tmsize_t, const char*);
extern void* _TIFFCheckRealloc(TIFF*, void*, tmsize_t, tmsize_t, const char*);
extern int TIFFInitDumpMode(TIFF*, int); extern double _TIFFUInt64ToDouble(uint64);
extern float _TIFFUInt64ToFloat(uint64);
extern int TIFFInitDumpMode(TIFF*, int);
#ifdef PACKBITS_SUPPORT #ifdef PACKBITS_SUPPORT
extern int TIFFInitPackBits(TIFF*, int); extern int TIFFInitPackBits(TIFF*, int);
#endif #endif
#ifdef CCITT_SUPPORT #ifdef CCITT_SUPPORT
extern int TIFFInitCCITTRLE(TIFF*, int), TIFFInitCCITTRLEW(TIFF*, int); extern int TIFFInitCCITTRLE(TIFF*, int), TIFFInitCCITTRLEW(TIFF*, int);
extern int TIFFInitCCITTFax3(TIFF*, int), TIFFInitCCITTFax4(TIFF*, int); extern int TIFFInitCCITTFax3(TIFF*, int), TIFFInitCCITTFax4(TIFF*, int);
#endif #endif
#ifdef THUNDER_SUPPORT #ifdef THUNDER_SUPPORT
extern int TIFFInitThunderScan(TIFF*, int); extern int TIFFInitThunderScan(TIFF*, int);
#endif #endif
#ifdef NEXT_SUPPORT #ifdef NEXT_SUPPORT
extern int TIFFInitNeXT(TIFF*, int); extern int TIFFInitNeXT(TIFF*, int);
#endif #endif
#ifdef LZW_SUPPORT #ifdef LZW_SUPPORT
extern int TIFFInitLZW(TIFF*, int); extern int TIFFInitLZW(TIFF*, int);
#endif #endif
#ifdef OJPEG_SUPPORT #ifdef OJPEG_SUPPORT
extern int TIFFInitOJPEG(TIFF*, int); extern int TIFFInitOJPEG(TIFF*, int);
#endif #endif
#ifdef JPEG_SUPPORT #ifdef JPEG_SUPPORT
extern int TIFFInitJPEG(TIFF*, int); extern int TIFFInitJPEG(TIFF*, int);
#endif #endif
#ifdef JBIG_SUPPORT #ifdef JBIG_SUPPORT
extern int TIFFInitJBIG(TIFF*, int); extern int TIFFInitJBIG(TIFF*, int);
#endif #endif
#ifdef ZIP_SUPPORT #ifdef ZIP_SUPPORT
extern int TIFFInitZIP(TIFF*, int); extern int TIFFInitZIP(TIFF*, int);
#endif #endif
#ifdef PIXARLOG_SUPPORT #ifdef PIXARLOG_SUPPORT
extern int TIFFInitPixarLog(TIFF*, int); extern int TIFFInitPixarLog(TIFF*, int);
#endif #endif
#ifdef LOGLUV_SUPPORT #ifdef LOGLUV_SUPPORT
extern int TIFFInitSGILog(TIFF*, int); extern int TIFFInitSGILog(TIFF*, int);
#endif
#ifdef LZMA_SUPPORT
extern int TIFFInitLZMA(TIFF*, int);
#endif #endif
#ifdef VMS #ifdef VMS
extern const TIFFCodec _TIFFBuiltinCODECS[]; extern const TIFFCodec _TIFFBuiltinCODECS[];
#else #else
extern TIFFCodec _TIFFBuiltinCODECS[]; extern TIFFCodec _TIFFBuiltinCODECS[];
#endif #endif
#if defined(__cplusplus) #if defined(__cplusplus)

View File

@ -1,4 +1,4 @@
#define TIFFLIB_VERSION_STR "LIBTIFF, Version 3.9.4\nCopyright (c) 1988-1996 Sam Leffler\nCopyright (c) 1991-1996 Silicon Graphics, Inc." #define TIFFLIB_VERSION_STR "LIBTIFF, Version 4.0.1\nCopyright (c) 1988-1996 Sam Leffler\nCopyright (c) 1991-1996 Silicon Graphics, Inc."
/* /*
* This define can be used in code that requires * This define can be used in code that requires
* compilation-related definitions specific to a * compilation-related definitions specific to a
@ -6,4 +6,4 @@
* version checking should be done based on the * version checking should be done based on the
* string returned by TIFFGetVersion. * string returned by TIFFGetVersion.
*/ */
#define TIFFLIB_VERSION 20100615 #define TIFFLIB_VERSION 20120218