Fixed aliasing bug in Windows platform layer (thanks, Dennis!).
This commit is contained in:
parent
bdb7e2a795
commit
53a9169400
|
@ -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!).
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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.) */
|
||||||
|
|
Loading…
Reference in New Issue