mirror of
				https://github.com/vcmi/vcmi.git
				synced 2025-10-31 00:07:39 +02:00 
			
		
		
		
	Final compilation fix suggested by AVS.
This commit is contained in:
		| @@ -9,6 +9,200 @@ | ||||
|  | ||||
| #include <cstdio> | ||||
|  | ||||
| ///copied from ioapi.c due to linker issues on MSVS | ||||
|  | ||||
| #include "../minizip/ioapi.h" | ||||
|  | ||||
| #if defined(__APPLE__) || defined(IOAPI_NO_64) | ||||
| // In darwin and perhaps other BSD variants off_t is a 64 bit value, hence no need for specific 64 bit functions | ||||
| #define FOPEN_FUNC(filename, mode) fopen(filename, mode) | ||||
| #define FTELLO_FUNC(stream) ftello(stream) | ||||
| #define FSEEKO_FUNC(stream, offset, origin) fseeko(stream, offset, origin) | ||||
| #else | ||||
| #define FOPEN_FUNC(filename, mode) fopen64(filename, mode) | ||||
| #define FTELLO_FUNC(stream) ftello64(stream) | ||||
| #define FSEEKO_FUNC(stream, offset, origin) fseeko64(stream, offset, origin) | ||||
| #endif | ||||
|  | ||||
| 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); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| 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); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| 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) == MAXU32) | ||||
| 			return (ZPOS64_T)-1; | ||||
| 		else | ||||
| 			return tell_uLong; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| 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)); | ||||
|  | ||||
| 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"; | ||||
|  | ||||
| 	if ((filename != NULL) && (mode_fopen != NULL)) | ||||
| 		file = fopen(filename, mode_fopen); | ||||
| 	return file; | ||||
| } | ||||
|  | ||||
| static voidpf ZCALLBACK fopen64_file_func(voidpf opaque, const void* 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"; | ||||
|  | ||||
| 	if ((filename != NULL) && (mode_fopen != NULL)) | ||||
| 		file = FOPEN_FUNC((const char*)filename, mode_fopen); | ||||
| 	return file; | ||||
| } | ||||
|  | ||||
|  | ||||
| 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; | ||||
| } | ||||
|  | ||||
| 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; | ||||
| } | ||||
|  | ||||
| static long ZCALLBACK ftell_file_func(voidpf opaque, voidpf stream) | ||||
| { | ||||
| 	long ret; | ||||
| 	ret = ftell((FILE *)stream); | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
|  | ||||
| static ZPOS64_T ZCALLBACK ftell64_file_func(voidpf opaque, voidpf stream) | ||||
| { | ||||
| 	ZPOS64_T ret; | ||||
| 	ret = FTELLO_FUNC((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) | ||||
| 	{ | ||||
| 	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 (fseek((FILE *)stream, offset, fseek_origin) != 0) | ||||
| 		ret = -1; | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
| 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 (FSEEKO_FUNC((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; | ||||
| } | ||||
|  | ||||
| static int ZCALLBACK ferror_file_func(voidpf opaque, voidpf stream) | ||||
| { | ||||
| 	int ret; | ||||
| 	ret = ferror((FILE *)stream); | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
| ///end of ioapi.c | ||||
|  | ||||
| //extern MINIZIP_EXPORT void fill_fopen64_filefunc(zlib_filefunc64_def*  pzlib_filefunc_def); | ||||
|  | ||||
| #ifdef VCMI_WINDOWS | ||||
| 	#ifndef _CRT_SECURE_NO_WARNINGS | ||||
| 		#define _CRT_SECURE_NO_WARNINGS | ||||
| @@ -51,6 +245,20 @@ voidpf ZCALLBACK MinizipOpenFunc(voidpf opaque, const void* filename, int mode) | ||||
| 		return nullptr; | ||||
| } | ||||
|  | ||||
|  | ||||
| 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; | ||||
| } | ||||
|  | ||||
|  | ||||
| zlib_filefunc64_def* FileStream::GetMinizipFilefunc() | ||||
| { | ||||
| 	static zlib_filefunc64_def MinizipFilefunc; | ||||
|   | ||||
| @@ -221,7 +221,7 @@ static int ZCALLBACK ferror_file_func (voidpf opaque, voidpf stream) | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| ZEXPORT void fill_fopen_filefunc(pzlib_filefunc_def) | ||||
| void fill_fopen_filefunc(pzlib_filefunc_def) | ||||
|   zlib_filefunc_def* pzlib_filefunc_def; | ||||
| { | ||||
|     pzlib_filefunc_def->zopen_file = fopen_file_func; | ||||
| @@ -234,7 +234,7 @@ ZEXPORT void fill_fopen_filefunc(pzlib_filefunc_def) | ||||
|     pzlib_filefunc_def->opaque = NULL; | ||||
| } | ||||
|  | ||||
| ZEXPORT void fill_fopen64_filefunc(zlib_filefunc64_def*  pzlib_filefunc_def) | ||||
| 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; | ||||
|   | ||||
| @@ -198,8 +198,8 @@ typedef struct zlib_filefunc64_def_s | ||||
|     voidpf              opaque; | ||||
| } zlib_filefunc64_def; | ||||
|  | ||||
| ZEXPORT void fill_fopen64_filefunc OF((zlib_filefunc64_def* pzlib_filefunc_def)); | ||||
| ZEXPORT void fill_fopen_filefunc OF((zlib_filefunc_def* pzlib_filefunc_def)); | ||||
| void fill_fopen64_filefunc OF((zlib_filefunc64_def* pzlib_filefunc_def)); | ||||
| void fill_fopen_filefunc OF((zlib_filefunc_def* pzlib_filefunc_def)); | ||||
|  | ||||
| /* now internal definition, only for zip.c and unzip.h */ | ||||
| typedef struct zlib_filefunc64_32_def_s | ||||
|   | ||||
		Reference in New Issue
	
	Block a user