X-Git-Url: https://de.git.xonotic.org/?a=blobdiff_plain;f=makefile;h=87de6620beae8137ef5adcea39760e0bacbc8604;hb=55a593206761a8e3db4f9db23dd6663d5873ca8f;hp=c4e530c559885541215232bf1f063e033926fb57;hpb=21d1d0035598647e62df2ba9a5259938e09b49a5;p=xonotic%2Fdarkplaces.git diff --git a/makefile b/makefile index c4e530c5..87de6620 100644 --- a/makefile +++ b/makefile @@ -1,24 +1,94 @@ -SND=snd_alsa_0_5.o -OBJECTS= buildnumber.o cd_linux.o chase.o cl_demo.o cl_input.o cl_main.o cl_parse.o cl_tent.o cmd.o common.o console.o cpu_noasm.o crc.o cvar.o fractalnoise.o gl_draw.o gl_poly.o gl_refrag.o gl_rmain.o gl_rmisc.o gl_rsurf.o gl_screen.o gl_warp.o host.o host_cmd.o image.o keys.o mathlib.o menu.o model_alias.o model_brush.o model_shared.o model_sprite.o net_bsd.o net_udp.o net_dgrm.o net_loop.o net_main.o net_vcr.o pr_cmds.o pr_edict.o pr_exec.o r_light.o r_part.o sbar.o snd_dma.o snd_mem.o snd_mix.o $(SND) sv_main.o sv_move.o sv_phys.o sv_user.o sys_linux.o transform.o view.o wad.o world.o zone.o vid_shared.o +##### DP_MAKE_TARGET autodetection and arch specific variables ##### -OPTIMIZATIONS= -O6 -ffast-math -funroll-loops -fomit-frame-pointer -fexpensive-optimizations +ifndef DP_MAKE_TARGET -CFLAGS= -Wall -Werror -I/usr/X11R6/include -I/usr/include/glide $(OPTIMIZATIONS) -#CFLAGS= -Wall -Werror -I/usr/X11/include -ggdb $(OPTIMIZATIONS) -#LDFLAGS= -L/usr/X11R6/lib -lm -lX11 -lXext -lXIE -lXxf86dga -lXxf86vm -lGL -ldl -LDFLAGS= -L/usr/X11R6/lib -lm -lX11 -lXext -lXIE -lXxf86dga -lXxf86vm -lGL -ldl -lasound +# Win32 +ifdef windir + DP_MAKE_TARGET=mingw +else -all: darkplaces-glx darkplaces-3dfx +# UNIXes +DP_ARCH:=$(shell uname) +ifeq ($(DP_ARCH),NetBSD) + DP_MAKE_TARGET=bsd +else + DP_MAKE_TARGET=linux +endif -.c.o: - gcc $(CFLAGS) -c $*.c +endif -darkplaces-glx: $(OBJECTS) vid_glx.o - gcc -o $@ $^ $(LDFLAGS) +endif -darkplaces-3dfx: $(OBJECTS) in_svgalib.o vid_3dfxsvga.o - gcc -o $@ $^ $(LDFLAGS) +# Command used to delete files +ifdef windir + CMD_RM=del +else + CMD_RM=$(CMD_UNIXRM) +endif -clean: - rm -f darkplaces-glx $(OBJECTS) + +# Linux configuration +ifeq ($(DP_MAKE_TARGET), linux) + OBJ_SOUND=$(OBJ_LINUXSOUND) + LIB_SOUND=$(LIB_LINUXSOUND) + OBJ_CD=$(OBJ_LINUXCD) + + OBJ_CL=$(OBJ_GLX) + + LDFLAGS_CL=$(LDFLAGS_LINUXCL) + LDFLAGS_SV=$(LDFLAGS_LINUXSV) + LDFLAGS_SDL=$(LDFLAGS_LINUXSDL) + + EXE_CL=$(EXE_UNIXCL) + EXE_SV=$(EXE_UNIXSV) + EXE_SDL=$(EXE_UNIXSDL) +endif + +# BSD configuration +ifeq ($(DP_MAKE_TARGET), bsd) + OBJ_SOUND=$(OBJ_BSDSOUND) + LIB_SOUND=$(LIB_BSDSOUND) + OBJ_CD=$(OBJ_BSDCD) + + OBJ_CL=$(OBJ_GLX) + + LDFLAGS_CL=$(LDFLAGS_BSDCL) + LDFLAGS_SV=$(LDFLAGS_BSDSV) + LDFLAGS_SDL=$(LDFLAGS_BSDSDL) + + EXE_CL=$(EXE_UNIXCL) + EXE_SV=$(EXE_UNIXSV) + EXE_SDL=$(EXE_UNIXSDL) +endif + +# Win32 configuration +ifeq ($(DP_MAKE_TARGET), mingw) + OBJ_SOUND=$(OBJ_WINSOUND) + LIB_SOUND=$(LIB_WINSOUND) + OBJ_CD=$(OBJ_WINCD) + + OBJ_CL=$(OBJ_WGL) + + LDFLAGS_CL=$(LDFLAGS_WINCL) + LDFLAGS_SV=$(LDFLAGS_WINSV) + LDFLAGS_SDL=$(LDFLAGS_WINSDL) + + EXE_CL=$(EXE_WINCL) + EXE_SV=$(EXE_WINSV) + EXE_SDL=$(EXE_WINSDL) +endif + + +##### GNU Make specific definitions ##### + +DO_LD=$(CC) -o $@ $^ $(LDFLAGS) + + +##### Definitions shared by all makefiles ##### +include makefile.inc + + +##### Dependency files ##### + +-include *.d