X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;f=makefile;h=45b2d97f666b7f08004d331141799d3bde69430f;hb=a53f08b7a4c95132c6d6bd3aad981df62ffa493d;hp=bba5e017dda16eb916bc8d74cb463ee51bec71ce;hpb=832ba0937327c893bfd49f1a738812dae1a995a5;p=xonotic%2Fdarkplaces.git diff --git a/makefile b/makefile index bba5e017..45b2d97f 100644 --- a/makefile +++ b/makefile @@ -1,4 +1,4 @@ -##### DP_MAKE_TARGET autodetection and arch specific variables ##### +##### DP_MAKE_TARGET autodetection and arch specific variables ##### ifndef DP_MAKE_TARGET @@ -9,14 +9,27 @@ else # UNIXes DP_ARCH:=$(shell uname) -ifeq ($(DP_ARCH),NetBSD) +ifneq ($(filter %BSD,$(DP_ARCH)),) DP_MAKE_TARGET=bsd +else +ifeq ($(DP_ARCH), Darwin) + DP_MAKE_TARGET=macosx +else +ifeq ($(DP_ARCH), SunOS) + DP_MAKE_TARGET=sunos else DP_MAKE_TARGET=linux -endif -endif +endif # ifeq ($(DP_ARCH), SunOS) +endif # ifeq ($(DP_ARCH), Darwin) +endif # ifneq ($(filter %BSD,$(DP_ARCH)),) +endif # ifdef windir +endif # ifndef DP_MAKE_TARGET +# If we're not on compiling for Win32, we need additional information +ifneq ($(DP_MAKE_TARGET), mingw) + DP_ARCH:=$(shell uname) + DP_MACHINE:=$(shell uname -m) endif @@ -27,66 +40,212 @@ else CMD_RM=$(CMD_UNIXRM) endif - -DP_MACHINE:=$(shell uname -m) +# 64bits AMD CPUs use another lib directory ifeq ($(DP_MACHINE),x86_64) - UNIX_X11LIBPATH:=-L/usr/X11R6/lib64 + UNIX_X11LIBPATH:=/usr/X11R6/lib64 else - UNIX_X11LIBPATH:=-L/usr/X11R6/lib + UNIX_X11LIBPATH:=/usr/X11R6/lib endif # Linux configuration ifeq ($(DP_MAKE_TARGET), linux) - OBJ_SOUND=$(OBJ_LINUXSOUND) - LIB_SOUND=$(LIB_LINUXSOUND) + DEFAULT_SNDAPI=ALSA OBJ_CD=$(OBJ_LINUXCD) OBJ_CL=$(OBJ_GLX) + OBJ_ICON= + OBJ_ICON_NEXUIZ= LDFLAGS_CL=$(LDFLAGS_LINUXCL) LDFLAGS_SV=$(LDFLAGS_LINUXSV) LDFLAGS_SDL=$(LDFLAGS_LINUXSDL) + SDLCONFIG_CFLAGS=$(SDLCONFIG_UNIXCFLAGS) + SDLCONFIG_LIBS=$(SDLCONFIG_UNIXLIBS) + SDLCONFIG_STATICLIBS=$(SDLCONFIG_UNIXSTATICLIBS) + + EXE_CL=$(EXE_UNIXCL) + EXE_SV=$(EXE_UNIXSV) + EXE_SDL=$(EXE_UNIXSDL) + EXE_CLNEXUIZ=$(EXE_UNIXCLNEXUIZ) + EXE_SVNEXUIZ=$(EXE_UNIXSVNEXUIZ) + EXE_SDLNEXUIZ=$(EXE_UNIXSDLNEXUIZ) +endif + +# Mac OS X configuration +ifeq ($(DP_MAKE_TARGET), macosx) + DEFAULT_SNDAPI=COREAUDIO + OBJ_CD=$(OBJ_MACOSXCD) + + OBJ_CL=$(OBJ_AGL) + OBJ_ICON= + OBJ_ICON_NEXUIZ= + + LDFLAGS_CL=$(LDFLAGS_MACOSXCL) + LDFLAGS_SV=$(LDFLAGS_MACOSXSV) + LDFLAGS_SDL=$(LDFLAGS_MACOSXSDL) + + SDLCONFIG_CFLAGS=$(SDLCONFIG_MACOSXCFLAGS) + SDLCONFIG_LIBS=$(SDLCONFIG_MACOSXLIBS) + SDLCONFIG_STATICLIBS=$(SDLCONFIG_MACOSXSTATICLIBS) + + EXE_CL=$(EXE_MACOSXCL) + EXE_SV=$(EXE_UNIXSV) + EXE_SDL=$(EXE_UNIXSDL) + EXE_CLNEXUIZ=$(EXE_MACOSXCLNEXUIZ) + EXE_SVNEXUIZ=$(EXE_UNIXSVNEXUIZ) + EXE_SDLNEXUIZ=$(EXE_UNIXSDLNEXUIZ) + + ifeq ($(word 2, $(filter -arch, $(CC))), -arch) + CFLAGS_MAKEDEP= + endif +endif + +# SunOS configuration (Solaris) +ifeq ($(DP_MAKE_TARGET), sunos) + DEFAULT_SNDAPI=BSD + OBJ_CD=$(OBJ_SUNOSCD) + + OBJ_CL=$(OBJ_GLX) + OBJ_ICON= + OBJ_ICON_NEXUIZ= + + CFLAGS_EXTRA=$(CFLAGS_SUNOS) + + LDFLAGS_CL=$(LDFLAGS_SUNOSCL) + LDFLAGS_SV=$(LDFLAGS_SUNOSSV) + LDFLAGS_SDL=$(LDFLAGS_SUNOSSDL) + + SDLCONFIG_CFLAGS=$(SDLCONFIG_UNIXCFLAGS) + SDLCONFIG_LIBS=$(SDLCONFIG_UNIXLIBS) + SDLCONFIG_STATICLIBS=$(SDLCONFIG_UNIXSTATICLIBS) + EXE_CL=$(EXE_UNIXCL) EXE_SV=$(EXE_UNIXSV) EXE_SDL=$(EXE_UNIXSDL) + EXE_CLNEXUIZ=$(EXE_UNIXCLNEXUIZ) + EXE_SVNEXUIZ=$(EXE_UNIXSVNEXUIZ) + EXE_SDLNEXUIZ=$(EXE_UNIXSDLNEXUIZ) endif # BSD configuration ifeq ($(DP_MAKE_TARGET), bsd) - OBJ_SOUND=$(OBJ_BSDSOUND) - LIB_SOUND=$(LIB_BSDSOUND) +ifeq ($(DP_ARCH),FreeBSD) + DEFAULT_SNDAPI=OSS +else + DEFAULT_SNDAPI=BSD +endif OBJ_CD=$(OBJ_BSDCD) OBJ_CL=$(OBJ_GLX) + OBJ_ICON= + OBJ_ICON_NEXUIZ= LDFLAGS_CL=$(LDFLAGS_BSDCL) LDFLAGS_SV=$(LDFLAGS_BSDSV) LDFLAGS_SDL=$(LDFLAGS_BSDSDL) + SDLCONFIG_CFLAGS=$(SDLCONFIG_UNIXCFLAGS) + SDLCONFIG_LIBS=$(SDLCONFIG_UNIXLIBS) + SDLCONFIG_STATICLIBS=$(SDLCONFIG_UNIXSTATICLIBS) + EXE_CL=$(EXE_UNIXCL) EXE_SV=$(EXE_UNIXSV) EXE_SDL=$(EXE_UNIXSDL) + EXE_CLNEXUIZ=$(EXE_UNIXCLNEXUIZ) + EXE_SVNEXUIZ=$(EXE_UNIXSVNEXUIZ) + EXE_SDLNEXUIZ=$(EXE_UNIXSDLNEXUIZ) endif # Win32 configuration ifeq ($(DP_MAKE_TARGET), mingw) - OBJ_SOUND=$(OBJ_WINSOUND) - LIB_SOUND=$(LIB_WINSOUND) + DEFAULT_SNDAPI=WIN OBJ_CD=$(OBJ_WINCD) OBJ_CL=$(OBJ_WGL) + OBJ_ICON=darkplaces.o + OBJ_ICON_NEXUIZ=nexuiz.o LDFLAGS_CL=$(LDFLAGS_WINCL) LDFLAGS_SV=$(LDFLAGS_WINSV) LDFLAGS_SDL=$(LDFLAGS_WINSDL) + SDLCONFIG_CFLAGS=$(SDLCONFIG_UNIXCFLAGS) + SDLCONFIG_LIBS=$(SDLCONFIG_UNIXLIBS) + SDLCONFIG_STATICLIBS=$(SDLCONFIG_UNIXSTATICLIBS) + EXE_CL=$(EXE_WINCL) EXE_SV=$(EXE_WINSV) EXE_SDL=$(EXE_WINSDL) + EXE_CLNEXUIZ=$(EXE_WINCLNEXUIZ) + EXE_SVNEXUIZ=$(EXE_WINSVNEXUIZ) + EXE_SDLNEXUIZ=$(EXE_WINSDLNEXUIZ) +endif + +##### Sound configuration ##### + +ifndef DP_SOUND_API + DP_SOUND_API=$(DEFAULT_SNDAPI) +endif + +# NULL: no sound +ifeq ($(DP_SOUND_API), NULL) + OBJ_SOUND=$(OBJ_SND_NULL) + LIB_SOUND=$(LIB_SND_NULL) +endif + +# OSS: Open Sound System +ifeq ($(DP_SOUND_API), OSS) + OBJ_SOUND=$(OBJ_SND_OSS) + LIB_SOUND=$(LIB_SND_OSS) +endif + +# ALSA: Advanced Linux Sound Architecture +ifeq ($(DP_SOUND_API), ALSA) + OBJ_SOUND=$(OBJ_SND_ALSA) + LIB_SOUND=$(LIB_SND_ALSA) endif +# COREAUDIO: Core Audio +ifeq ($(DP_SOUND_API), COREAUDIO) + OBJ_SOUND=$(OBJ_SND_COREAUDIO) + LIB_SOUND=$(LIB_SND_COREAUDIO) +endif + +# BSD: BSD / Sun audio API +ifeq ($(DP_SOUND_API), BSD) + OBJ_SOUND=$(OBJ_SND_BSD) + LIB_SOUND=$(LIB_SND_BSD) +endif + +# WIN: DirectX and Win32 WAVE output +ifeq ($(DP_SOUND_API), WIN) + OBJ_SOUND=$(OBJ_SND_WIN) + LIB_SOUND=$(LIB_SND_WIN) +endif + + +##### Extra CFLAGS ##### + +CFLAGS_MAKEDEP?=-MD +ifdef DP_FS_BASEDIR + CFLAGS_FS=-DDP_FS_BASEDIR='\"$(DP_FS_BASEDIR)\"' +else + CFLAGS_FS= +endif + +CFLAGS_PRELOAD= +ifneq ($(DP_MAKE_TARGET), mingw) +ifdef DP_PRELOAD_DEPENDENCIES +# DP_PRELOAD_DEPENDENCIES: when set, link against the libraries needed using -l +# dynamically so they won't get loaded at runtime using dlopen + LDFLAGS_CL+=$(LDFLAGS_UNIXCL_PRELOAD) + LDFLAGS_SV+=$(LDFLAGS_UNIXSV_PRELOAD) + LDFLAGS_SDL+=$(LDFLAGS_UNIXSDL_PRELOAD) + CFLAGS_PRELOAD=$(CFLAGS_UNIX_PRELOAD) +endif +endif ##### GNU Make specific definitions #####