diff --git a/CHANGELOG b/CHANGELOG index b142580..45c961a 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -2,6 +2,10 @@ * CHANGELOG. */ +09182005 - API BREAKAGE: PHYSFS_enumerateFilesCallback() now passes the + original directory name back to the app in the callback. This + API was only in 1.1.0, and wasn't promised to be stable at this + point. Please update your apps. 09092005 - Some tweaks to PHYSFS_Allocator. Apparently configure.in doesn't work like I thought for version bumps, so it thinks 1.1.0 isn't binary compatible with 1.0...fixed, I think. diff --git a/archivers/dir.c b/archivers/dir.c index 9c460f1..f2e57fe 100644 --- a/archivers/dir.c +++ b/archivers/dir.c @@ -104,13 +104,14 @@ static void *DIR_openArchive(const char *name, int forWriting) static void DIR_enumerateFiles(dvoid *opaque, const char *dname, - int omitSymLinks, PHYSFS_StringCallback cb, - void *callbackdata) + int omitSymLinks, PHYSFS_EnumFilesCallback cb, + const char *origdir, void *callbackdata) { char *d = __PHYSFS_platformCvtToDependent((char *)opaque, dname, NULL); if (d != NULL) { - __PHYSFS_platformEnumerateFiles(d, omitSymLinks, cb, callbackdata); + __PHYSFS_platformEnumerateFiles(d, omitSymLinks, cb, + origdir, callbackdata); allocator.Free(d); } /* if */ } /* DIR_enumerateFiles */ diff --git a/archivers/grp.c b/archivers/grp.c index 47d73b9..7e334f9 100644 --- a/archivers/grp.c +++ b/archivers/grp.c @@ -295,8 +295,8 @@ GRP_openArchive_failed: static void GRP_enumerateFiles(dvoid *opaque, const char *dname, - int omitSymLinks, PHYSFS_StringCallback cb, - void *callbackdata) + int omitSymLinks, PHYSFS_EnumFilesCallback cb, + const char *origdir, void *callbackdata) { /* no directories in GRP files. */ if (*dname != '\0') @@ -307,7 +307,7 @@ static void GRP_enumerateFiles(dvoid *opaque, const char *dname, PHYSFS_uint32 i; for (i = 0; i < max; i++, entry++) - cb(callbackdata, entry->name); + cb(callbackdata, origdir, entry->name); } /* if */ } /* GRP_enumerateFiles */ diff --git a/archivers/hog.c b/archivers/hog.c index 415d7d4..9abdeb6 100644 --- a/archivers/hog.c +++ b/archivers/hog.c @@ -334,8 +334,8 @@ HOG_openArchive_failed: static void HOG_enumerateFiles(dvoid *opaque, const char *dname, - int omitSymLinks, PHYSFS_StringCallback cb, - void *callbackdata) + int omitSymLinks, PHYSFS_EnumFilesCallback cb, + const char *origdir, void *callbackdata) { /* no directories in HOG files. */ if (*dname != '\0') @@ -346,7 +346,7 @@ static void HOG_enumerateFiles(dvoid *opaque, const char *dname, PHYSFS_uint32 i; for (i = 0; i < max; i++, entry++) - cb(callbackdata, entry->name); + cb(callbackdata, origdir, entry->name); } /* if */ } /* HOG_enumerateFiles */ diff --git a/archivers/mix.c b/archivers/mix.c index 57edfde..7033aa8 100644 --- a/archivers/mix.c +++ b/archivers/mix.c @@ -288,8 +288,8 @@ MIX_openArchive_failed: static void MIX_enumerateFiles(dvoid *opaque, const char *dname, - int omitSymLinks, PHYSFS_StringCallback cb, - void *callbackdata) + int omitSymLinks, PHYSFS_EnumFilesCallback cb, + const char *origdir, void *callbackdata) { /* no directories in MIX files. */ if (*dirname != '\0') @@ -302,7 +302,7 @@ static void MIX_enumerateFiles(dvoid *opaque, const char *dname, for (i = 0; i < info->header.num_files; i++, entry++) { sprintf(buffer, "%X", entry->hash); - cb(callbackdata, buffer); + cb(callbackdata, origdir, buffer); } /* for */ } /* if */ } /* MIX_enumerateFiles */ diff --git a/archivers/mvl.c b/archivers/mvl.c index 1eacd7a..6bbebe3 100644 --- a/archivers/mvl.c +++ b/archivers/mvl.c @@ -291,8 +291,8 @@ MVL_openArchive_failed: static void MVL_enumerateFiles(dvoid *opaque, const char *dname, - int omitSymLinks, PHYSFS_StringCallback cb, - void *callbackdata) + int omitSymLinks, PHYSFS_EnumFilesCallback cb, + const char *origdir, void *callbackdata) { /* no directories in MVL files. */ if (*dname != '\0') @@ -303,7 +303,7 @@ static void MVL_enumerateFiles(dvoid *opaque, const char *dname, PHYSFS_uint32 i; for (i = 0; i < max; i++, entry++) - cb(callbackdata, entry->name); + cb(callbackdata, origdir, entry->name); } /* if */ } /* MVL_enumerateFiles */ diff --git a/archivers/qpak.c b/archivers/qpak.c index 05e7a1f..bf60c57 100644 --- a/archivers/qpak.c +++ b/archivers/qpak.c @@ -379,8 +379,8 @@ static PHYSFS_sint32 qpak_find_start_of_dir(QPAKinfo *info, const char *path, * Moved to seperate function so we can use alloca then immediately throw * away the allocated stack space... */ -static void doEnumCallback(PHYSFS_StringCallback cb, void *callbackdata, - const char *str, PHYSFS_sint32 ln) +static void doEnumCallback(PHYSFS_EnumFilesCallback cb, void *callbackdata, + const char *odir, const char *str, PHYSFS_sint32 ln) { char *newstr = alloca(ln + 1); if (newstr == NULL) @@ -388,13 +388,13 @@ static void doEnumCallback(PHYSFS_StringCallback cb, void *callbackdata, memcpy(newstr, str, ln); newstr[ln] = '\0'; - cb(callbackdata, newstr); + cb(callbackdata, odir, newstr); } /* doEnumCallback */ static void QPAK_enumerateFiles(dvoid *opaque, const char *dname, - int omitSymLinks, PHYSFS_StringCallback cb, - void *callbackdata) + int omitSymLinks, PHYSFS_EnumFilesCallback cb, + const char *origdir, void *callbackdata) { QPAKinfo *info = ((QPAKinfo *) opaque); PHYSFS_sint32 dlen, dlen_inc, max, i; @@ -421,7 +421,7 @@ static void QPAK_enumerateFiles(dvoid *opaque, const char *dname, add = e + dlen_inc; ptr = strchr(add, '/'); ln = (PHYSFS_sint32) ((ptr) ? ptr-add : strlen(add)); - doEnumCallback(cb, callbackdata, add, ln); + doEnumCallback(cb, callbackdata, origdir, add, ln); ln += dlen_inc; /* point past entry to children... */ /* increment counter and skip children of subdirs... */ diff --git a/archivers/wad.c b/archivers/wad.c index 9109551..6ec1b88 100644 --- a/archivers/wad.c +++ b/archivers/wad.c @@ -322,8 +322,8 @@ WAD_openArchive_failed: static void WAD_enumerateFiles(dvoid *opaque, const char *dname, - int omitSymLinks, PHYSFS_StringCallback cb, - void *callbackdata) + int omitSymLinks, PHYSFS_EnumFilesCallback cb, + const char *origdir, void *callbackdata) { WADinfo *info = ((WADinfo *) opaque); WADentry *entry = info->entries; @@ -338,7 +338,7 @@ static void WAD_enumerateFiles(dvoid *opaque, const char *dname, { name = entry->name; if (strchr(name, '/') == NULL) - cb(callbackdata, name); + cb(callbackdata, origdir, name); } /* for */ } /* if */ else diff --git a/archivers/zip.c b/archivers/zip.c index 6902efe..e6539e5 100644 --- a/archivers/zip.c +++ b/archivers/zip.c @@ -1178,8 +1178,8 @@ static PHYSFS_sint32 zip_find_start_of_dir(ZIPinfo *info, const char *path, * Moved to seperate function so we can use alloca then immediately throw * away the allocated stack space... */ -static void doEnumCallback(PHYSFS_StringCallback cb, void *callbackdata, - const char *str, PHYSFS_sint32 ln) +static void doEnumCallback(PHYSFS_EnumFilesCallback cb, void *callbackdata, + const char *odir, const char *str, PHYSFS_sint32 ln) { char *newstr = alloca(ln + 1); if (newstr == NULL) @@ -1187,13 +1187,13 @@ static void doEnumCallback(PHYSFS_StringCallback cb, void *callbackdata, memcpy(newstr, str, ln); newstr[ln] = '\0'; - cb(callbackdata, newstr); + cb(callbackdata, odir, newstr); } /* doEnumCallback */ static void ZIP_enumerateFiles(dvoid *opaque, const char *dname, - int omitSymLinks, PHYSFS_StringCallback cb, - void *callbackdata) + int omitSymLinks, PHYSFS_EnumFilesCallback cb, + const char *origdir, void *callbackdata) { ZIPinfo *info = ((ZIPinfo *) opaque); PHYSFS_sint32 dlen, dlen_inc, max, i; @@ -1221,7 +1221,7 @@ static void ZIP_enumerateFiles(dvoid *opaque, const char *dname, char *add = e + dlen_inc; char *ptr = strchr(add, '/'); PHYSFS_sint32 ln = (PHYSFS_sint32) ((ptr) ? ptr-add : strlen(add)); - doEnumCallback(cb, callbackdata, add, ln); + doEnumCallback(cb, callbackdata, origdir, add, ln); ln += dlen_inc; /* point past entry to children... */ /* increment counter and skip children of subdirs... */ diff --git a/physfs.c b/physfs.c index 93156a9..8f12f82 100644 --- a/physfs.c +++ b/physfs.c @@ -1494,7 +1494,7 @@ static int locateInStringList(const char *str, } /* locateInStringList */ -static void enumFilesCallback(void *data, const char *str) +static void enumFilesCallback(void *data, const char *origdir, const char *str) { PHYSFS_uint32 pos; void *ptr; @@ -1546,7 +1546,7 @@ char **PHYSFS_enumerateFiles(const char *path) void PHYSFS_enumerateFilesCallback(const char *_fname, - PHYSFS_StringCallback callback, + PHYSFS_EnumFilesCallback callback, void *data) { DirHandle *i; @@ -1570,13 +1570,14 @@ void PHYSFS_enumerateFilesCallback(const char *_fname, char *end = strchr(ptr, '/'); assert(end); /* should always find a terminating '/'. */ *end = '\0'; /* !!! FIXME: not safe in a callback... */ - callback(data, ptr); + callback(data, _fname, ptr); *end = '/'; /* !!! FIXME: not safe in a callback... */ } /* if */ else if (verifyPath(i, &arcfname, 0)) { - i->funcs->enumerateFiles(i->opaque,arcfname,noSyms,callback,data); + i->funcs->enumerateFiles(i->opaque, arcfname, noSyms, + callback, _fname, data); } /* else if */ } /* for */ __PHYSFS_platformReleaseMutex(stateLock); diff --git a/physfs.h b/physfs.h index 4d9ee45..e6d0892 100644 --- a/physfs.h +++ b/physfs.h @@ -1978,14 +1978,15 @@ __EXPORT__ const char *PHYSFS_getMountPoint(const char *dir); * be holding non recursive mutexes. */ /* !!! FIXME: comment! */ -typedef void (*PHYSFS_StringCallback)(void *data, const char *); +typedef void (*PHYSFS_StringCallback)(void *, const char *); +typedef void (*PHYSFS_EnumFilesCallback)(void *, const char *, const char *); __EXPORT__ void PHYSFS_getCdRomDirsCallback(PHYSFS_StringCallback c, void *d); __EXPORT__ void PHYSFS_getSearchPathCallback(PHYSFS_StringCallback c, void *d); __EXPORT__ void PHYSFS_enumerateFilesCallback(const char *dir, - PHYSFS_StringCallback c, + PHYSFS_EnumFilesCallback c, void *d); diff --git a/physfs_internal.h b/physfs_internal.h index dc70205..d77ce32 100644 --- a/physfs_internal.h +++ b/physfs_internal.h @@ -995,7 +995,8 @@ typedef struct void (*enumerateFiles)(dvoid *opaque, const char *dirname, int omitSymLinks, - PHYSFS_StringCallback callback, + PHYSFS_EnumFilesCallback callback, + const char *origdir, void *callbackdata); /* @@ -1568,7 +1569,8 @@ void __PHYSFS_platformTimeslice(void); */ void __PHYSFS_platformEnumerateFiles(const char *dirname, int omitSymLinks, - PHYSFS_StringCallback callback, + PHYSFS_EnumFilesCallback callback, + const char *origdir, void *callbackdata); diff --git a/platform/macclassic.c b/platform/macclassic.c index 3470805..e2669a2 100644 --- a/platform/macclassic.c +++ b/platform/macclassic.c @@ -563,7 +563,8 @@ void __PHYSFS_platformTimeslice(void) /* returns int so we can use BAIL*MACRO... */ static int macClassicEnumerateFiles(const char *dirname, int omitSymLinks, - PHYSFS_StringCallback callback, + PHYSFS_EnumFilesCallback callback, + const char *origdir, void *callbackdata) { UInt16 i; @@ -618,7 +619,7 @@ static int macClassicEnumerateFiles(const char *dirname, size = (size_t) str255[0]; /* (convert to ASCIZ string...) */ memmove(&str255[0], &str255[1], size); str255[size] = '\0'; - callback(callbackdata, (const char *) str255); + callback(callbackdata, origdir, (const char *) str255); } /* for */ return(1); @@ -627,10 +628,12 @@ static int macClassicEnumerateFiles(const char *dirname, void __PHYSFS_platformEnumerateFiles(const char *dirname, int omitSymLinks, - PHYSFS_StringCallback callback, + PHYSFS_EnumFilesCallback callback, + const char *origdir, void *callbackdata) { - macClassicEnumerateFiles(dirname, omitSymLinks, callback, callbackdata); + macClassicEnumerateFiles(dirname, omitSymLinks, callback, + origdir, callbackdata); } /* __PHYSFS_platformEnumerateFiles */ diff --git a/platform/os2.c b/platform/os2.c index 58f635a..f479621 100644 --- a/platform/os2.c +++ b/platform/os2.c @@ -398,7 +398,8 @@ char *__PHYSFS_platformCvtToDependent(const char *prepend, void __PHYSFS_platformEnumerateFiles(const char *dirname, int omitSymLinks, - PHYSFS_StringCallback callback, + PHYSFS_EnumFilesCallback callback, + const char *origdir, void *callbackdata) { char spec[CCHMAXPATH]; @@ -427,7 +428,7 @@ void __PHYSFS_platformEnumerateFiles(const char *dirname, while (count == 1) { if ((strcmp(fb.achName, ".") != 0) && (strcmp(fb.achName, "..") != 0)) - callback(callbackdata, fb.achName); + callback(callbackdata, origdir, fb.achName); DosFindNext(hdir, &fb, sizeof (fb), &count); } /* while */ diff --git a/platform/pocketpc.c b/platform/pocketpc.c index 0284ab0..556dec9 100644 --- a/platform/pocketpc.c +++ b/platform/pocketpc.c @@ -296,7 +296,8 @@ void __PHYSFS_platformTimeslice(void) void __PHYSFS_platformEnumerateFiles(const char *dirname, int omitSymLinks, - PHYSFS_StringCallback callback, + PHYSFS_EnumFilesCallback callback, + const char *origdir, void *callbackdata) { HANDLE dir; @@ -346,7 +347,7 @@ void __PHYSFS_platformEnumerateFiles(const char *dirname, if (str == NULL) break; - callback(callbackdata, str); + callback(callbackdata, origdir, str); allocator.Free(str); } while (FindNextFile(dir, &ent) != 0); diff --git a/platform/posix.c b/platform/posix.c index dc9cbad..7f10577 100644 --- a/platform/posix.c +++ b/platform/posix.c @@ -227,7 +227,8 @@ char *__PHYSFS_platformCvtToDependent(const char *prepend, void __PHYSFS_platformEnumerateFiles(const char *dirname, int omitSymLinks, - PHYSFS_StringCallback callback, + PHYSFS_EnumFilesCallback callback, + const char *origdir, void *callbackdata) { DIR *dir; @@ -286,7 +287,7 @@ void __PHYSFS_platformEnumerateFiles(const char *dirname, continue; } /* if */ - callback(callbackdata, ent->d_name); + callback(callbackdata, origdir, ent->d_name); } /* while */ if (buf != NULL) diff --git a/platform/skeleton.c b/platform/skeleton.c index 372aa35..9c0d4dc 100644 --- a/platform/skeleton.c +++ b/platform/skeleton.c @@ -106,7 +106,8 @@ void __PHYSFS_platformTimeslice(void) void __PHYSFS_platformEnumerateFiles(const char *dirname, int omitSymLinks, - PHYSFS_StringCallback callback, + PHYSFS_EnumFilesCallback callback, + const char *origdir, void *callbackdata) { } /* __PHYSFS_platformEnumerateFiles */ diff --git a/platform/win32.c b/platform/win32.c index c24c5ca..a5f6f9a 100644 --- a/platform/win32.c +++ b/platform/win32.c @@ -440,7 +440,8 @@ void __PHYSFS_platformTimeslice(void) void __PHYSFS_platformEnumerateFiles(const char *dirname, int omitSymLinks, - PHYSFS_StringCallback callback, + PHYSFS_EnumFilesCallback callback, + const char *origdir, void *callbackdata) { HANDLE dir; @@ -478,7 +479,7 @@ void __PHYSFS_platformEnumerateFiles(const char *dirname, if (strcmp(ent.cFileName, "..") == 0) continue; - callback(callbackdata, ent.cFileName); + callback(callbackdata, origdir, ent.cFileName); } while (FindNextFile(dir, &ent) != 0); FindClose(dir);