mirror of
https://github.com/ZDoom/Raze.git
synced 2025-01-23 00:41:03 +00:00
dac94ce284
This includes a complete Windows header and library refresh, including the addition of 64-bit compiled libs: *libogg 1.3.0 *libvorbis 1.3.3 *zlib 1.2.7 *libpng 1.5.13 *libvpx 9a3de881c0e681ba1a79a166a86308bbc84b4acd *SDL_mixer 1.2.12 (for RENDERTYPE=SDL) *DirectX import libraries: dsound and dxguid (now included) To build in 64-bit, you essentially need MinGW's MSYS (but not MinGW itself) and MinGW-w64 at the top of your PATH. The target is automatically detected using `$(CC) -dumpmachine`. The EDukeWiki will get detailed instrucitons. All compiler and linker warnings when building in 64-bit mode have been fixed. Remaining 64-bit to-do: - The ebacktrace dll does not build under 64-bit. It uses code specific to the format of 32-bit executables and will have to be ported to work with 64-bit executables. A future 64-bit version will be named ebacktrace1-64.dll. - RENDERTYPE=SDL crashes in SDL_mixer's Mix_Linked_Version(). - DirectInput gives an error and does not function. This only affects joysticks, and the error never happens without any plugged in. - Port the classic renderer ASM to 64-bit. (Just kidding, this is way out of my league.) This commit includes a fair bit of Makefile development spanning all platforms, including simplifying the SDLCONFIG code, fixing build on Mac OS X (thanks rhoenie!), globally factoring Apple brew/port inclusion, enforcing that all -L come before all -l, and ensuring that $(shell ) is always :='d. In addition, I have resurrected the old GCC_MAJOR and GCC_MINOR detection using `$(CC) -dumpversion`, but I have made it failsafe in case the command fails or the version is manually specified. I have applied this new fine-grained detection where applicable, including allowing LTO, and restraining -W's to versions that support them. git-svn-id: https://svn.eduke32.com/eduke32@3278 1a8010ca-5511-0410-912e-c29ae57300e0
28 lines
632 B
C
28 lines
632 B
C
|
|
// MinGW-w64 headers are deficient.
|
|
// Here, account for CINTERFACE because they don't.
|
|
#ifdef REFGUID
|
|
# undef REFGUID
|
|
#endif
|
|
#ifdef REFIID
|
|
# undef REFIID
|
|
#endif
|
|
#ifdef REFCLSID
|
|
# undef REFCLSID
|
|
#endif
|
|
#ifdef REFFMTID
|
|
# undef REFFMTID
|
|
#endif
|
|
|
|
// copied from MinGW's <basetyps.h>
|
|
#if defined (__cplusplus) && !defined (CINTERFACE)
|
|
# define REFGUID const GUID&
|
|
# define REFIID const IID&
|
|
# define REFCLSID const CLSID&
|
|
# define REFFMTID const FMTID&
|
|
#else
|
|
# define REFGUID const GUID* const
|
|
# define REFIID const IID* const
|
|
# define REFCLSID const CLSID* const
|
|
# define REFFMTID const FMTID* const
|
|
#endif
|