Index: third_party/zlib/contrib/minizip/ioapi.c |
=================================================================== |
--- third_party/zlib/contrib/minizip/ioapi.c (revision 113739) |
+++ third_party/zlib/contrib/minizip/ioapi.c (working copy) |
@@ -1,77 +1,104 @@ |
-/* ioapi.c -- IO base function header for compress/uncompress .zip |
- files using zlib + zip or unzip API |
+/* ioapi.h -- IO base function header for compress/uncompress .zip |
+ 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 |
+ |
*/ |
-#include <stdio.h> |
-#include <stdlib.h> |
-#include <string.h> |
- |
-#if defined(USE_SYSTEM_ZLIB) |
-#include <zlib.h> |
-#else |
-#include "third_party/zlib/zlib.h" |
+#if (defined(_WIN32)) |
+ #define _CRT_SECURE_NO_WARNINGS |
#endif |
#include "ioapi.h" |
-/* I've found an old Unix (a SunOS 4.1.3_U1) without all SEEK_* defined.... */ |
+voidpf call_zopen64 (const zlib_filefunc64_32_def* pfilefunc,const void*filename,int mode) |
+{ |
+ if (pfilefunc->zfile_func64.zopen64_file != NULL) |
+ return (*(pfilefunc->zfile_func64.zopen64_file)) (pfilefunc->zfile_func64.opaque,filename,mode); |
+ else |
+ { |
+ return (*(pfilefunc->zopen32_file))(pfilefunc->zfile_func64.opaque,(const char*)filename,mode); |
+ } |
+} |
-#ifndef SEEK_CUR |
-#define SEEK_CUR 1 |
-#endif |
+long call_zseek64 (const zlib_filefunc64_32_def* pfilefunc,voidpf filestream, ZPOS64_T offset, int origin) |
+{ |
+ if (pfilefunc->zfile_func64.zseek64_file != NULL) |
+ return (*(pfilefunc->zfile_func64.zseek64_file)) (pfilefunc->zfile_func64.opaque,filestream,offset,origin); |
+ else |
+ { |
+ uLong offsetTruncated = (uLong)offset; |
+ if (offsetTruncated != offset) |
+ return -1; |
+ else |
+ return (*(pfilefunc->zseek32_file))(pfilefunc->zfile_func64.opaque,filestream,offsetTruncated,origin); |
+ } |
+} |
-#ifndef SEEK_END |
-#define SEEK_END 2 |
-#endif |
+ZPOS64_T call_ztell64 (const zlib_filefunc64_32_def* pfilefunc,voidpf filestream) |
+{ |
+ if (pfilefunc->zfile_func64.zseek64_file != NULL) |
+ return (*(pfilefunc->zfile_func64.ztell64_file)) (pfilefunc->zfile_func64.opaque,filestream); |
+ else |
+ { |
+ uLong tell_uLong = (*(pfilefunc->ztell32_file))(pfilefunc->zfile_func64.opaque,filestream); |
+ if ((tell_uLong) == ((uLong)-1)) |
+ return (ZPOS64_T)-1; |
+ else |
+ return tell_uLong; |
+ } |
+} |
-#ifndef SEEK_SET |
-#define SEEK_SET 0 |
-#endif |
+void fill_zlib_filefunc64_32_def_from_filefunc32(zlib_filefunc64_32_def* p_filefunc64_32,const zlib_filefunc_def* p_filefunc32) |
+{ |
+ p_filefunc64_32->zfile_func64.zopen64_file = NULL; |
+ p_filefunc64_32->zopen32_file = p_filefunc32->zopen_file; |
+ p_filefunc64_32->zfile_func64.zerror_file = p_filefunc32->zerror_file; |
+ p_filefunc64_32->zfile_func64.zread_file = p_filefunc32->zread_file; |
+ p_filefunc64_32->zfile_func64.zwrite_file = p_filefunc32->zwrite_file; |
+ p_filefunc64_32->zfile_func64.ztell64_file = NULL; |
+ p_filefunc64_32->zfile_func64.zseek64_file = NULL; |
+ p_filefunc64_32->zfile_func64.zclose_file = p_filefunc32->zclose_file; |
+ p_filefunc64_32->zfile_func64.zerror_file = p_filefunc32->zerror_file; |
+ p_filefunc64_32->zfile_func64.opaque = p_filefunc32->opaque; |
+ p_filefunc64_32->zseek32_file = p_filefunc32->zseek_file; |
+ p_filefunc64_32->ztell32_file = p_filefunc32->ztell_file; |
+} |
-voidpf ZCALLBACK fopen_file_func OF(( |
- voidpf opaque, |
- const char* filename, |
- int mode)); |
-uLong ZCALLBACK fread_file_func OF(( |
- voidpf opaque, |
- voidpf stream, |
- void* buf, |
- uLong size)); |
-uLong ZCALLBACK fwrite_file_func OF(( |
- voidpf opaque, |
- voidpf stream, |
- const void* buf, |
- uLong size)); |
+static voidpf ZCALLBACK fopen_file_func OF((voidpf opaque, const char* filename, int mode)); |
+static uLong ZCALLBACK fread_file_func OF((voidpf opaque, voidpf stream, void* buf, uLong size)); |
+static uLong ZCALLBACK fwrite_file_func OF((voidpf opaque, voidpf stream, const void* buf,uLong size)); |
+static ZPOS64_T ZCALLBACK ftell64_file_func OF((voidpf opaque, voidpf stream)); |
+static long ZCALLBACK fseek64_file_func OF((voidpf opaque, voidpf stream, ZPOS64_T offset, int origin)); |
+static int ZCALLBACK fclose_file_func OF((voidpf opaque, voidpf stream)); |
+static int ZCALLBACK ferror_file_func OF((voidpf opaque, voidpf stream)); |
-long ZCALLBACK ftell_file_func OF(( |
- voidpf opaque, |
- voidpf stream)); |
+static voidpf ZCALLBACK fopen_file_func (voidpf opaque, const char* filename, int mode) |
+{ |
+ FILE* file = NULL; |
+ const char* mode_fopen = NULL; |
+ if ((mode & ZLIB_FILEFUNC_MODE_READWRITEFILTER)==ZLIB_FILEFUNC_MODE_READ) |
+ mode_fopen = "rb"; |
+ else |
+ if (mode & ZLIB_FILEFUNC_MODE_EXISTING) |
+ mode_fopen = "r+b"; |
+ else |
+ if (mode & ZLIB_FILEFUNC_MODE_CREATE) |
+ mode_fopen = "wb"; |
-long ZCALLBACK fseek_file_func OF(( |
- voidpf opaque, |
- voidpf stream, |
- uLong offset, |
- int origin)); |
+ if ((filename!=NULL) && (mode_fopen != NULL)) |
+ file = fopen(filename, mode_fopen); |
+ return file; |
+} |
-int ZCALLBACK fclose_file_func OF(( |
- voidpf opaque, |
- voidpf stream)); |
- |
-int ZCALLBACK ferror_file_func OF(( |
- voidpf opaque, |
- voidpf stream)); |
- |
- |
-voidpf ZCALLBACK fopen_file_func (opaque, filename, mode) |
- voidpf opaque; |
- const char* filename; |
- int mode; |
+static voidpf ZCALLBACK fopen64_file_func (voidpf opaque, const void* filename, int mode) |
{ |
FILE* file = NULL; |
const char* mode_fopen = NULL; |
@@ -85,49 +112,42 @@ |
mode_fopen = "wb"; |
if ((filename!=NULL) && (mode_fopen != NULL)) |
- file = fopen(filename, mode_fopen); |
+ file = fopen64((const char*)filename, mode_fopen); |
return file; |
} |
-uLong ZCALLBACK fread_file_func (opaque, stream, buf, size) |
- voidpf opaque; |
- voidpf stream; |
- void* buf; |
- uLong size; |
+static uLong ZCALLBACK fread_file_func (voidpf opaque, voidpf stream, void* buf, uLong size) |
{ |
uLong ret; |
ret = (uLong)fread(buf, 1, (size_t)size, (FILE *)stream); |
return ret; |
} |
- |
-uLong ZCALLBACK fwrite_file_func (opaque, stream, buf, size) |
- voidpf opaque; |
- voidpf stream; |
- const void* buf; |
- uLong size; |
+static uLong ZCALLBACK fwrite_file_func (voidpf opaque, voidpf stream, const void* buf, uLong size) |
{ |
uLong ret; |
ret = (uLong)fwrite(buf, 1, (size_t)size, (FILE *)stream); |
return ret; |
} |
-long ZCALLBACK ftell_file_func (opaque, stream) |
- voidpf opaque; |
- voidpf stream; |
+static long ZCALLBACK ftell_file_func (voidpf opaque, voidpf stream) |
{ |
long ret; |
ret = ftell((FILE *)stream); |
return ret; |
} |
-long ZCALLBACK fseek_file_func (opaque, stream, offset, origin) |
- voidpf opaque; |
- voidpf stream; |
- uLong offset; |
- int origin; |
+ |
+static ZPOS64_T ZCALLBACK ftell64_file_func (voidpf opaque, voidpf stream) |
{ |
+ ZPOS64_T ret; |
+ ret = ftello64((FILE *)stream); |
+ return ret; |
+} |
+ |
+static long ZCALLBACK fseek_file_func (voidpf opaque, voidpf stream, uLong offset, int origin) |
+{ |
int fseek_origin=0; |
long ret; |
switch (origin) |
@@ -144,22 +164,45 @@ |
default: return -1; |
} |
ret = 0; |
- fseek((FILE *)stream, offset, fseek_origin); |
+ if (fseek((FILE *)stream, offset, fseek_origin) != 0) |
+ ret = -1; |
return ret; |
} |
-int ZCALLBACK fclose_file_func (opaque, stream) |
- voidpf opaque; |
- voidpf stream; |
+static long ZCALLBACK fseek64_file_func (voidpf opaque, voidpf stream, ZPOS64_T offset, int origin) |
{ |
+ int fseek_origin=0; |
+ long ret; |
+ switch (origin) |
+ { |
+ case ZLIB_FILEFUNC_SEEK_CUR : |
+ fseek_origin = SEEK_CUR; |
+ break; |
+ case ZLIB_FILEFUNC_SEEK_END : |
+ fseek_origin = SEEK_END; |
+ break; |
+ case ZLIB_FILEFUNC_SEEK_SET : |
+ fseek_origin = SEEK_SET; |
+ break; |
+ default: return -1; |
+ } |
+ ret = 0; |
+ |
+ if(fseeko64((FILE *)stream, offset, fseek_origin) != 0) |
+ ret = -1; |
+ |
+ return ret; |
+} |
+ |
+ |
+static int ZCALLBACK fclose_file_func (voidpf opaque, voidpf stream) |
+{ |
int ret; |
ret = fclose((FILE *)stream); |
return ret; |
} |
-int ZCALLBACK ferror_file_func (opaque, stream) |
- voidpf opaque; |
- voidpf stream; |
+static int ZCALLBACK ferror_file_func (voidpf opaque, voidpf stream) |
{ |
int ret; |
ret = ferror((FILE *)stream); |
@@ -178,3 +221,15 @@ |
pzlib_filefunc_def->zerror_file = ferror_file_func; |
pzlib_filefunc_def->opaque = NULL; |
} |
+ |
+void fill_fopen64_filefunc (zlib_filefunc64_def* pzlib_filefunc_def) |
+{ |
+ pzlib_filefunc_def->zopen64_file = fopen64_file_func; |
+ pzlib_filefunc_def->zread_file = fread_file_func; |
+ pzlib_filefunc_def->zwrite_file = fwrite_file_func; |
+ pzlib_filefunc_def->ztell64_file = ftell64_file_func; |
+ pzlib_filefunc_def->zseek64_file = fseek64_file_func; |
+ pzlib_filefunc_def->zclose_file = fclose_file_func; |
+ pzlib_filefunc_def->zerror_file = ferror_file_func; |
+ pzlib_filefunc_def->opaque = NULL; |
+} |