X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7c74e7fe1de14f32dcd6f3c9cdd727de540bbd0e..4004f41e3ce1655f9fa05c55a697ac0f8677c23a:/src/common/unzip.c diff --git a/src/common/unzip.c b/src/common/unzip.c index 1cc334155f..20d33af180 100644 --- a/src/common/unzip.c +++ b/src/common/unzip.c @@ -1,15 +1,17 @@ +/* + +This file was altered for needs of wxWindows. +$Id$ + +*/ + /* unzip.c -- IO on .zip files using zlib Version 0.15 beta, Mar 19th, 1998, Read unzip.h for more info + */ -#if 0 -for what compiler ? -#if !defined(__VISAGECPP__) -# pragma warning(disable:4001) /* non standard extension used: single line comment */ -#endif -#endif #include "wx/setup.h" @@ -360,23 +362,23 @@ wxUnix2MacFilename (char *s) { if ( *s == '.' ) { - // relative path , since it goes on with slash which is translated to a : + /* relative path , since it goes on with slash which is translated to a : */ memmove( s , s+1 ,strlen( s ) ) ; } else if ( *s == '/' ) { - // absolute path -> on mac just start with the drive name + /* absolute path -> on mac just start with the drive name */ memmove( s , s+1 ,strlen( s ) ) ; } else { -// wxASSERT_MSG( 1 , "unkown path beginning" ) ; +/* wxASSERT_MSG( 1 , "unkown path beginning" ) ; */ } while (*s) { if (*s == '/' || *s == '\\') { - // convert any back-directory situations + /* convert any back-directory situations */ if ( *(s+1) == '.' && *(s+2) == '.' && ( (*(s+3) == '/' || *(s+3) == '\\') ) ) { *s = ':'; @@ -824,12 +826,18 @@ extern int ZEXPORT unzLocateFile (file, szFileName, iCaseSensitivity) { unz_s* s; int err; - - + const char *c; + char *c2; + char szFileName2[UNZ_MAXFILENAMEINZIP+1]; + uLong num_fileSaved; uLong pos_in_central_dirSaved; - + for (c = szFileName, c2 = szFileName2; *c != '\0'; c++, c2++) + if (*c == '\\') *c2 = '/'; + else *c2 = *c; + *c2 = '\0'; + if (file==NULL) return UNZ_PARAMERROR; @@ -851,8 +859,9 @@ extern int ZEXPORT unzLocateFile (file, szFileName, iCaseSensitivity) unzGetCurrentFileInfo(file,NULL, szCurrentFileName,sizeof(szCurrentFileName)-1, NULL,0,NULL,0); + for (c2 = szCurrentFileName; *c2 != '\0'; c2++) if (*c2 == '\\') *c2 = '/'; if (unzStringFileNameCompare(szCurrentFileName, - szFileName,iCaseSensitivity)==0) + szFileName2,iCaseSensitivity)==0) return UNZ_OK; err = unzGoToNextFile(file); }