| Index: third_party/zlib/contrib/minizip/ioapi.h
|
| ===================================================================
|
| --- third_party/zlib/contrib/minizip/ioapi.h (revision 113739)
|
| +++ third_party/zlib/contrib/minizip/ioapi.h (working copy)
|
| @@ -1,15 +1,110 @@
|
| /* ioapi.h -- IO base function header for compress/uncompress .zip
|
| - files using zlib + zip or unzip API
|
| + part of the MiniZip project - ( http://www.winimage.com/zLibDll/minizip.html )
|
|
|
| - Version 1.01e, February 12th, 2005
|
| + Copyright (C) 1998-2010 Gilles Vollant (minizip) ( http://www.winimage.com/zLibDll/minizip.html )
|
|
|
| - Copyright (C) 1998-2005 Gilles Vollant
|
| + Modifications for Zip64 support
|
| + Copyright (C) 2009-2010 Mathias Svensson ( http://result42.com )
|
| +
|
| + For more info read MiniZip_info.txt
|
| +
|
| + Changes
|
| +
|
| + Oct-2009 - Defined ZPOS64_T to fpos_t on windows and u_int64_t on linux. (might need to find a better why for this)
|
| + Oct-2009 - Change to fseeko64, ftello64 and fopen64 so large files would work on linux.
|
| + More if/def section may be needed to support other platforms
|
| + Oct-2009 - Defined fxxxx64 calls to normal fopen/ftell/fseek so they would compile on windows.
|
| + (but you should use iowin32.c for windows instead)
|
| +
|
| */
|
|
|
| -#ifndef _ZLIBIOAPI_H
|
| -#define _ZLIBIOAPI_H
|
| +#ifndef _ZLIBIOAPI64_H
|
| +#define _ZLIBIOAPI64_H
|
|
|
| +#if (!defined(_WIN32)) && (!defined(WIN32))
|
|
|
| + // Linux needs this to support file operation on files larger then 4+GB
|
| + // But might need better if/def to select just the platforms that needs them.
|
| +
|
| + #ifndef __USE_FILE_OFFSET64
|
| + #define __USE_FILE_OFFSET64
|
| + #endif
|
| + #ifndef __USE_LARGEFILE64
|
| + #define __USE_LARGEFILE64
|
| + #endif
|
| + #ifndef _LARGEFILE64_SOURCE
|
| + #define _LARGEFILE64_SOURCE
|
| + #endif
|
| + #ifndef _FILE_OFFSET_BIT
|
| + #define _FILE_OFFSET_BIT 64
|
| + #endif
|
| +#endif
|
| +
|
| +#include <stdio.h>
|
| +#include <stdlib.h>
|
| +#if defined(USE_SYSTEM_ZLIB)
|
| +#include <zlib.h>
|
| +#else
|
| +#include "third_party/zlib/zlib.h"
|
| +#endif
|
| +
|
| +#if defined(USE_FILE32API)
|
| +#define fopen64 fopen
|
| +#define ftello64 ftell
|
| +#define fseeko64 fseek
|
| +#else
|
| +#ifdef _MSC_VER
|
| + #define fopen64 fopen
|
| + #if (_MSC_VER >= 1400) && (!(defined(NO_MSCVER_FILE64_FUNC)))
|
| + #define ftello64 _ftelli64
|
| + #define fseeko64 _fseeki64
|
| + #else // old MSC
|
| + #define ftello64 ftell
|
| + #define fseeko64 fseek
|
| + #endif
|
| +#endif
|
| +#endif
|
| +
|
| +/*
|
| +#ifndef ZPOS64_T
|
| + #ifdef _WIN32
|
| + #define ZPOS64_T fpos_t
|
| + #else
|
| + #include <stdint.h>
|
| + #define ZPOS64_T uint64_t
|
| + #endif
|
| +#endif
|
| +*/
|
| +
|
| +#ifdef HAVE_MINIZIP64_CONF_H
|
| +#include "mz64conf.h"
|
| +#endif
|
| +
|
| +/* a type choosen by DEFINE */
|
| +#ifdef HAVE_64BIT_INT_CUSTOM
|
| +typedef 64BIT_INT_CUSTOM_TYPE ZPOS64_T;
|
| +#else
|
| +#ifdef HAS_STDINT_H
|
| +#include "stdint.h"
|
| +typedef uint64_t ZPOS64_T;
|
| +#else
|
| +
|
| +
|
| +#if defined(_MSC_VER) || defined(__BORLANDC__)
|
| +typedef unsigned __int64 ZPOS64_T;
|
| +#else
|
| +typedef unsigned long long int ZPOS64_T;
|
| +#endif
|
| +#endif
|
| +#endif
|
| +
|
| +
|
| +
|
| +#ifdef __cplusplus
|
| +extern "C" {
|
| +#endif
|
| +
|
| +
|
| #define ZLIB_FILEFUNC_SEEK_CUR (1)
|
| #define ZLIB_FILEFUNC_SEEK_END (2)
|
| #define ZLIB_FILEFUNC_SEEK_SET (0)
|
| @@ -23,26 +118,27 @@
|
|
|
|
|
| #ifndef ZCALLBACK
|
| -
|
| -#if (defined(WIN32) || defined (WINDOWS) || defined (_WINDOWS)) && defined(CALLBACK) && defined (USEWINDOWS_CALLBACK)
|
| -#define ZCALLBACK CALLBACK
|
| -#else
|
| -#define ZCALLBACK
|
| + #if (defined(WIN32) || defined(_WIN32) || defined (WINDOWS) || defined (_WINDOWS)) && defined(CALLBACK) && defined (USEWINDOWS_CALLBACK)
|
| + #define ZCALLBACK CALLBACK
|
| + #else
|
| + #define ZCALLBACK
|
| + #endif
|
| #endif
|
| -#endif
|
|
|
| -#ifdef __cplusplus
|
| -extern "C" {
|
| -#endif
|
|
|
| -typedef voidpf (ZCALLBACK *open_file_func) OF((voidpf opaque, const char* filename, int mode));
|
| -typedef uLong (ZCALLBACK *read_file_func) OF((voidpf opaque, voidpf stream, void* buf, uLong size));
|
| -typedef uLong (ZCALLBACK *write_file_func) OF((voidpf opaque, voidpf stream, const void* buf, uLong size));
|
| -typedef long (ZCALLBACK *tell_file_func) OF((voidpf opaque, voidpf stream));
|
| -typedef long (ZCALLBACK *seek_file_func) OF((voidpf opaque, voidpf stream, uLong offset, int origin));
|
| -typedef int (ZCALLBACK *close_file_func) OF((voidpf opaque, voidpf stream));
|
| -typedef int (ZCALLBACK *testerror_file_func) OF((voidpf opaque, voidpf stream));
|
|
|
| +
|
| +typedef voidpf (ZCALLBACK *open_file_func) OF((voidpf opaque, const char* filename, int mode));
|
| +typedef uLong (ZCALLBACK *read_file_func) OF((voidpf opaque, voidpf stream, void* buf, uLong size));
|
| +typedef uLong (ZCALLBACK *write_file_func) OF((voidpf opaque, voidpf stream, const void* buf, uLong size));
|
| +typedef int (ZCALLBACK *close_file_func) OF((voidpf opaque, voidpf stream));
|
| +typedef int (ZCALLBACK *testerror_file_func) OF((voidpf opaque, voidpf stream));
|
| +
|
| +typedef long (ZCALLBACK *tell_file_func) OF((voidpf opaque, voidpf stream));
|
| +typedef long (ZCALLBACK *seek_file_func) OF((voidpf opaque, voidpf stream, uLong offset, int origin));
|
| +
|
| +
|
| +/* here is the "old" 32 bits structure structure */
|
| typedef struct zlib_filefunc_def_s
|
| {
|
| open_file_func zopen_file;
|
| @@ -55,21 +151,54 @@
|
| voidpf opaque;
|
| } zlib_filefunc_def;
|
|
|
| +typedef ZPOS64_T (ZCALLBACK *tell64_file_func) OF((voidpf opaque, voidpf stream));
|
| +typedef long (ZCALLBACK *seek64_file_func) OF((voidpf opaque, voidpf stream, ZPOS64_T offset, int origin));
|
| +typedef voidpf (ZCALLBACK *open64_file_func) OF((voidpf opaque, const void* filename, int mode));
|
|
|
| +typedef struct zlib_filefunc64_def_s
|
| +{
|
| + open64_file_func zopen64_file;
|
| + read_file_func zread_file;
|
| + write_file_func zwrite_file;
|
| + tell64_file_func ztell64_file;
|
| + seek64_file_func zseek64_file;
|
| + close_file_func zclose_file;
|
| + testerror_file_func zerror_file;
|
| + voidpf opaque;
|
| +} zlib_filefunc64_def;
|
|
|
| +void fill_fopen64_filefunc OF((zlib_filefunc64_def* pzlib_filefunc_def));
|
| void fill_fopen_filefunc OF((zlib_filefunc_def* pzlib_filefunc_def));
|
|
|
| -#define ZREAD(filefunc,filestream,buf,size) ((*((filefunc).zread_file))((filefunc).opaque,filestream,buf,size))
|
| -#define ZWRITE(filefunc,filestream,buf,size) ((*((filefunc).zwrite_file))((filefunc).opaque,filestream,buf,size))
|
| -#define ZTELL(filefunc,filestream) ((*((filefunc).ztell_file))((filefunc).opaque,filestream))
|
| -#define ZSEEK(filefunc,filestream,pos,mode) ((*((filefunc).zseek_file))((filefunc).opaque,filestream,pos,mode))
|
| -#define ZCLOSE(filefunc,filestream) ((*((filefunc).zclose_file))((filefunc).opaque,filestream))
|
| -#define ZERROR(filefunc,filestream) ((*((filefunc).zerror_file))((filefunc).opaque,filestream))
|
| +/* now internal definition, only for zip.c and unzip.h */
|
| +typedef struct zlib_filefunc64_32_def_s
|
| +{
|
| + zlib_filefunc64_def zfile_func64;
|
| + open_file_func zopen32_file;
|
| + tell_file_func ztell32_file;
|
| + seek_file_func zseek32_file;
|
| +} zlib_filefunc64_32_def;
|
|
|
|
|
| +#define ZREAD64(filefunc,filestream,buf,size) ((*((filefunc).zfile_func64.zread_file)) ((filefunc).zfile_func64.opaque,filestream,buf,size))
|
| +#define ZWRITE64(filefunc,filestream,buf,size) ((*((filefunc).zfile_func64.zwrite_file)) ((filefunc).zfile_func64.opaque,filestream,buf,size))
|
| +//#define ZTELL64(filefunc,filestream) ((*((filefunc).ztell64_file)) ((filefunc).opaque,filestream))
|
| +//#define ZSEEK64(filefunc,filestream,pos,mode) ((*((filefunc).zseek64_file)) ((filefunc).opaque,filestream,pos,mode))
|
| +#define ZCLOSE64(filefunc,filestream) ((*((filefunc).zfile_func64.zclose_file)) ((filefunc).zfile_func64.opaque,filestream))
|
| +#define ZERROR64(filefunc,filestream) ((*((filefunc).zfile_func64.zerror_file)) ((filefunc).zfile_func64.opaque,filestream))
|
| +
|
| +voidpf call_zopen64 OF((const zlib_filefunc64_32_def* pfilefunc,const void*filename,int mode));
|
| +long call_zseek64 OF((const zlib_filefunc64_32_def* pfilefunc,voidpf filestream, ZPOS64_T offset, int origin));
|
| +ZPOS64_T call_ztell64 OF((const zlib_filefunc64_32_def* pfilefunc,voidpf filestream));
|
| +
|
| +void fill_zlib_filefunc64_32_def_from_filefunc32(zlib_filefunc64_32_def* p_filefunc64_32,const zlib_filefunc_def* p_filefunc32);
|
| +
|
| +#define ZOPEN64(filefunc,filename,mode) (call_zopen64((&(filefunc)),(filename),(mode)))
|
| +#define ZTELL64(filefunc,filestream) (call_ztell64((&(filefunc)),(filestream)))
|
| +#define ZSEEK64(filefunc,filestream,pos,mode) (call_zseek64((&(filefunc)),(filestream),(pos),(mode)))
|
| +
|
| #ifdef __cplusplus
|
| }
|
| #endif
|
|
|
| #endif
|
| -
|
|
|