Fixed aliasing bug in Windows platform layer (thanks, Dennis!).

This commit is contained in:
Ryan C. Gordon 2008-03-12 21:22:22 +00:00
parent bdb7e2a795
commit 53a9169400
3 changed files with 29 additions and 13 deletions

View File

@ -2,6 +2,7 @@
* CHANGELOG. * CHANGELOG.
*/ */
03122008 - Fixed aliasing bug in Windows platform layer (thanks, Dennis!).
03102008 - Changed some text files from ISO-8859-1 to UTF-8. Replaced all the 03102008 - Changed some text files from ISO-8859-1 to UTF-8. Replaced all the
translations with UTF-8 encoded equivalents. translations with UTF-8 encoded equivalents.
03082008 - Fixed compiler warnings in Windows platform layer (thanks, Dennis!). 03082008 - Fixed compiler warnings in Windows platform layer (thanks, Dennis!).

View File

@ -33,6 +33,13 @@
extern "C" { extern "C" {
#endif #endif
#ifdef __GNUC__
#define PHYSFS_MINIMUM_GCC_VER(major, minor) \
( ((__GNUC__ << 16) + __GNUC_MINOR__) >= (((major) << 16) + (minor)) )
#else
#define PHYSFS_MINIMUM_GCC_VER(major, minor) (0)
#endif
/* /*
* Interface for small allocations. If you need a little scratch space for * Interface for small allocations. If you need a little scratch space for
* a throwaway buffer or string, use this. It will make small allocations * a throwaway buffer or string, use this. It will make small allocations
@ -1020,6 +1027,7 @@ void __PHYSFS_sort(void *entries, PHYSFS_uint32 max,
#define __PHYSFS_UI64(x) x #define __PHYSFS_UI64(x) x
#endif #endif
/* /*
* Check if a ui64 will fit in the platform's address space. * Check if a ui64 will fit in the platform's address space.
* The initial sizeof check will optimize this macro out entirely on * The initial sizeof check will optimize this macro out entirely on
@ -1032,6 +1040,7 @@ void __PHYSFS_sort(void *entries, PHYSFS_uint32 max,
((s) > (__PHYSFS_UI64(0xFFFFFFFFFFFFFFFF) >> (64-(sizeof(size_t)*8)))) \ ((s) > (__PHYSFS_UI64(0xFFFFFFFFFFFFFFFF) >> (64-(sizeof(size_t)*8)))) \
) )
/* /*
* This is a strcasecmp() or stricmp() replacement that expects both strings * This is a strcasecmp() or stricmp() replacement that expects both strings
* to be in UTF-8 encoding. It will do "case folding" to decide if the * to be in UTF-8 encoding. It will do "case folding" to decide if the

View File

@ -256,10 +256,21 @@ static HANDLE WINAPI fallbackCreateFileW(LPCWSTR fname,
} /* fallbackCreateFileW */ } /* fallbackCreateFileW */
/* A blatant abuse of pointer casting... */ #if (PHYSFS_MINIMUM_GCC_VERSION(3,3))
static int symLookup(HMODULE dll, void **addr, const char *sym) typedef FARPROC __attribute__((__may_alias__)) PHYSFS_FARPROC;
#else
typedef FARPROC PHYSFS_FARPROC;
#endif
static void symLookup(HMODULE dll, PHYSFS_FARPROC *addr, const char *sym,
int reallyLook, PHYSFS_FARPROC fallback)
{ {
return( (*addr = GetProcAddress(dll, sym)) != NULL ); PHYSFS_FARPROC proc;
proc = (PHYSFS_FARPROC) ((reallyLook) ? GetProcAddress(dll, sym) : NULL);
if (proc == NULL)
proc = fallback; /* may also be NULL. */
*addr = proc;
} /* symLookup */ } /* symLookup */
@ -267,17 +278,12 @@ static int findApiSymbols(void)
{ {
HMODULE dll = NULL; HMODULE dll = NULL;
#define LOOKUP_NOFALLBACK(x, reallyLook) { \ #define LOOKUP_NOFALLBACK(x, reallyLook) \
if (reallyLook) \ symLookup(dll, (PHYSFS_FARPROC *) &p##x, #x, reallyLook, NULL)
symLookup(dll, (void **) &p##x, #x); \
else \
p##x = NULL; \
}
#define LOOKUP(x, reallyLook) { \ #define LOOKUP(x, reallyLook) \
if ((!reallyLook) || (!symLookup(dll, (void **) &p##x, #x))) \ symLookup(dll, (PHYSFS_FARPROC *) &p##x, #x, \
p##x = fallback##x; \ reallyLook, (PHYSFS_FARPROC) fallback##x)
}
/* Apparently Win9x HAS the Unicode entry points, they just don't WORK. */ /* Apparently Win9x HAS the Unicode entry points, they just don't WORK. */
/* ...so don't look them up unless we're on NT+. (see osHasUnicode.) */ /* ...so don't look them up unless we're on NT+. (see osHasUnicode.) */