diff options
Diffstat (limited to 'plugins/AdvaImg/src/FreeImage/ZLibInterface.cpp')
-rw-r--r-- | plugins/AdvaImg/src/FreeImage/ZLibInterface.cpp | 223 |
1 files changed, 0 insertions, 223 deletions
diff --git a/plugins/AdvaImg/src/FreeImage/ZLibInterface.cpp b/plugins/AdvaImg/src/FreeImage/ZLibInterface.cpp deleted file mode 100644 index 39c7ac0ecc..0000000000 --- a/plugins/AdvaImg/src/FreeImage/ZLibInterface.cpp +++ /dev/null @@ -1,223 +0,0 @@ -// ========================================================== -// ZLib library interface -// -// Design and implementation by -// - Floris van den Berg (flvdberg@wxs.nl) -// -// This file is part of FreeImage 3 -// -// COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTY -// OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, WARRANTIES -// THAT THE COVERED CODE IS FREE OF DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE -// OR NON-INFRINGING. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED -// CODE IS WITH YOU. SHOULD ANY COVERED CODE PROVE DEFECTIVE IN ANY RESPECT, YOU (NOT -// THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE COST OF ANY NECESSARY -// SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL -// PART OF THIS LICENSE. NO USE OF ANY COVERED CODE IS AUTHORIZED HEREUNDER EXCEPT UNDER -// THIS DISCLAIMER. -// -// Use at your own risk! -// ========================================================== - -#include "zlib.h" -#include "FreeImage.h" -#include "Utilities.h" -#include "zutil.h" /* must be the last header because of error C3163 in VS2008 (_vsnprintf defined in stdio.h) */ - -/** -Compresses a source buffer into a target buffer, using the ZLib library. -Upon entry, target_size is the total size of the destination buffer, -which must be at least 0.1% larger than source_size plus 12 bytes. - -@param target Destination buffer -@param target_size Size of the destination buffer, in bytes -@param source Source buffer -@param source_size Size of the source buffer, in bytes -@return Returns the actual size of the compressed buffer, returns 0 if an error occured -@see FreeImage_ZLibUncompress -*/ -DWORD DLL_CALLCONV -FreeImage_ZLibCompress(BYTE *target, DWORD target_size, BYTE *source, DWORD source_size) { - uLongf dest_len = (uLongf)target_size; - - int zerr = compress(target, &dest_len, source, source_size); - switch(zerr) { - case Z_MEM_ERROR: // not enough memory - case Z_BUF_ERROR: // not enough room in the output buffer - FreeImage_OutputMessageProc(FIF_UNKNOWN, "Zlib error : %s", zError(zerr)); - return 0; - case Z_OK: - return dest_len; - } - - return 0; -} - -/** -Decompresses a source buffer into a target buffer, using the ZLib library. -Upon entry, target_size is the total size of the destination buffer, -which must be large enough to hold the entire uncompressed data. -The size of the uncompressed data must have been saved previously by the compressor -and transmitted to the decompressor by some mechanism outside the scope of this -compression library. - -@param target Destination buffer -@param target_size Size of the destination buffer, in bytes -@param source Source buffer -@param source_size Size of the source buffer, in bytes -@return Returns the actual size of the uncompressed buffer, returns 0 if an error occured -@see FreeImage_ZLibCompress -*/ -DWORD DLL_CALLCONV -FreeImage_ZLibUncompress(BYTE *target, DWORD target_size, BYTE *source, DWORD source_size) { - uLongf dest_len = (uLongf)target_size; - - int zerr = uncompress(target, &dest_len, source, source_size); - switch(zerr) { - case Z_MEM_ERROR: // not enough memory - case Z_BUF_ERROR: // not enough room in the output buffer - case Z_DATA_ERROR: // input data was corrupted - FreeImage_OutputMessageProc(FIF_UNKNOWN, "Zlib error : %s", zError(zerr)); - return 0; - case Z_OK: - return dest_len; - } - - return 0; -} - -/** -Compresses a source buffer into a target buffer, using the ZLib library. -On success, the target buffer contains a GZIP compatible layout. -Upon entry, target_size is the total size of the destination buffer, -which must be at least 0.1% larger than source_size plus 24 bytes. - -@param target Destination buffer -@param target_size Size of the destination buffer, in bytes -@param source Source buffer -@param source_size Size of the source buffer, in bytes -@return Returns the actual size of the compressed buffer, returns 0 if an error occured -@see FreeImage_ZLibCompress -*/ -DWORD DLL_CALLCONV -FreeImage_ZLibGZip(BYTE *target, DWORD target_size, BYTE *source, DWORD source_size) { - uLongf dest_len = (uLongf)target_size - 12; - DWORD crc = crc32(0L, NULL, 0); - - // set up header (stolen from zlib/gzio.c) - sprintf((char *)target, "%c%c%c%c%c%c%c%c", 0x1f, 0x8b, - Z_DEFLATED, 0 /*flags*/, 0,0,0,0 /*time*/); - int zerr = compress2(target + 8, &dest_len, source, source_size, Z_BEST_COMPRESSION); - switch(zerr) { - case Z_MEM_ERROR: // not enough memory - case Z_BUF_ERROR: // not enough room in the output buffer - FreeImage_OutputMessageProc(FIF_UNKNOWN, "Zlib error : %s", zError(zerr)); - return 0; - case Z_OK: { - // patch header, setup crc and length (stolen from mod_trace_output) - BYTE *p = target + 8; *p++ = 2; *p = OS_CODE; // xflags, os_code - crc = crc32(crc, source, source_size); - memcpy(target + 4 + dest_len, &crc, 4); - memcpy(target + 8 + dest_len, &source_size, 4); - return dest_len + 12; - } - } - return 0; -} - -/** -Decompresses a gzipped source buffer into a target buffer, using the ZLib library. -Upon entry, target_size is the total size of the destination buffer, -which must be large enough to hold the entire uncompressed data. -The size of the uncompressed data must have been saved previously by the compressor -and transmitted to the decompressor by some mechanism outside the scope of this -compression library. - -@param target Destination buffer -@param target_size Size of the destination buffer, in bytes -@param source Source buffer -@param source_size Size of the source buffer, in bytes -@return Returns the actual size of the uncompressed buffer, returns 0 if an error occured -@see FreeImage_ZLibGZip -*/ - -static int get_byte(z_stream *stream) { - if (stream->avail_in <= 0) return EOF; - stream->avail_in--; - return *(stream->next_in)++; -} - -static int checkheader(z_stream *stream) { - int flags, c; - DWORD len; - - if (get_byte(stream) != 0x1f || get_byte(stream) != 0x8b) - return Z_DATA_ERROR; - if (get_byte(stream) != Z_DEFLATED || ((flags = get_byte(stream)) & 0xE0) != 0) - return Z_DATA_ERROR; - for (len = 0; len < 6; len++) (void)get_byte(stream); - - if ((flags & 0x04) != 0) { /* skip the extra field */ - len = (DWORD)get_byte(stream); - len += ((DWORD)get_byte(stream)) << 8; - /* len is garbage if EOF but the loop below will quit anyway */ - while (len-- != 0 && get_byte(stream) != EOF) ; - } - if ((flags & 0x08) != 0) { /* skip the original file name */ - while ((c = get_byte(stream)) != 0 && c != EOF) ; - } - if ((flags & 0x10) != 0) { /* skip the .gz file comment */ - while ((c = get_byte(stream)) != 0 && c != EOF) ; - } - if ((flags & 0x02) != 0) { /* skip the header crc */ - for (len = 0; len < 2; len++) (void)get_byte(stream); - } - return Z_OK; -} - -DWORD DLL_CALLCONV -FreeImage_ZLibGUnzip(BYTE *target, DWORD target_size, BYTE *source, DWORD source_size) { - DWORD src_len = source_size; - DWORD dest_len = target_size; - int zerr = Z_DATA_ERROR; - - if (src_len > 0) { - z_stream stream; - memset(&stream, 0, sizeof (stream)); - if ((zerr = inflateInit2(&stream, -MAX_WBITS)) == Z_OK) { - stream.next_in = source; - stream.avail_in = source_size; - - stream.next_out = target; - stream.avail_out = target_size; - - if ((zerr = checkheader(&stream)) == Z_OK) { - zerr = inflate (&stream, Z_NO_FLUSH); - dest_len = target_size - stream.avail_out; - - if (zerr == Z_OK || zerr == Z_STREAM_END) - inflateEnd(&stream); - } - } - } - if (zerr != Z_OK && zerr != Z_STREAM_END) { - FreeImage_OutputMessageProc(FIF_UNKNOWN, "Zlib error : %s", zError(zerr)); - return 0; - } - return dest_len; -} - -/** -Update a running crc from source and return the updated crc, using the ZLib library. -If source is NULL, this function returns the required initial value for the crc. - -@param crc Running crc value -@param source Source buffer -@param source_size Size of the source buffer, in bytes -@return Returns the new crc value -*/ -DWORD DLL_CALLCONV -FreeImage_ZLibCRC32(DWORD crc, BYTE *source, DWORD source_size) { - - return crc32(crc, source, source_size); -} |