X-Git-Url: http://de.git.xonotic.org/?p=xonotic%2Fdarkplaces.git;a=blobdiff_plain;f=makefile;h=7f2ebe5444396578625438897f78ad0840f2f9a5;hp=b39f6ca59c293b811e751f38469f8a914d912bf9;hb=e93d18b81c4c43ade8be7bb9c5d30710e12554b8;hpb=de9d94a6f5031904907c2fb5d022086d8124dcfd diff --git a/makefile b/makefile index b39f6ca5..7f2ebe54 100644 --- a/makefile +++ b/makefile @@ -1,49 +1,195 @@ -#uncomment one of these according to your sound driver -#if you use ALSA version 0.9.x -#SND=snd_alsa_0_9.o -#if you use ALSA version 0.5.x -#SND=snd_alsa_0_5.o -#if you use the kernel sound driver or OSS -SND=snd_oss.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 crc.o cvar.o fractalnoise.o gl_draw.o gl_poly.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 pr_cmds.o pr_edict.o pr_exec.o r_light.o r_part.o r_explosion.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 sv_light.o sys_linux.o transform.o view.o wad.o world.o zone.o vid_shared.o palette.o r_crosshairs.o gl_textures.o gl_models.o r_sprites.o r_modules.o r_explosion.o r_lerpanim.o cl_effects.o r_decals.o protocol.o quakeio.o - -OPTIMIZATIONS= -O6 -ffast-math -funroll-loops -fomit-frame-pointer -fexpensive-optimizations -#OPTIMIZATIONS= -O -g - -#note: -#the -Werror can be removed to compile even if there are warnings, -#the Quakeforge team uses this to ensure that all released versions are free -#of warnings. - -#normal compile -CFLAGS= -MD -Wall -Werror -I/usr/X11R6/include -I/usr/include/glide $(OPTIMIZATIONS) -#debug compile -#CFLAGS= -MD -Wall -Werror -I/usr/X11R6/include -ggdb $(OPTIMIZATIONS) - -#if using oss or kernel sound driver, use this line -LDFLAGS= -L/usr/X11R6/lib -lm -lX11 -lXext -lXIE -lXxf86dga -lXxf86vm -lGL -ldl -lz -#if using alsa, use this line -#LDFLAGS= -L/usr/X11R6/lib -lm -lX11 -lXext -lXIE -lXxf86dga -lXxf86vm -lGL -ldl -lasound -lz - -#most people can't build the -3dfx version (-3dfx version needs some updates for new mesa) -all: darkplaces-glx -#all: darkplaces-glx darkplaces-3dfx +##### Variables that you may want to modify ##### -.c.o: - gcc $(CFLAGS) -c $*.c +#choose the compiler you want to use +CC=gcc -darkplaces-glx: $(OBJECTS) vid_glx.o - gcc -o $@ $^ $(LDFLAGS) +#recommended for: anyone not using ALSA 0.5 +OBJ_SND=snd_oss.o snd_dma.o snd_mix.o snd_mem.o +SOUNDLIB= +#recommended for: anyone using ALSA 0.5 +#OBJ_SND=snd_alsa_0_5.o snd_dma.o snd_mix.o snd_mem.o +#SOUNDLIB=-lasound +#recommended for: no one (this driver needs to be updated, it doesn't compile anymore) +#OBJ_SND=snd_alsa_0_9.o snd_dma.o snd_mix.o snd_mem.o +#SOUNDLIB=-lasound +#recommended for: anyone who can't use the above drivers +#OBJ_SND=snd_null.o +#SOUNDLIB= -darkplaces-3dfx: $(OBJECTS) in_svgalib.o vid_3dfxsvga.o - gcc -o $@ $^ $(LDFLAGS) +#if you want CD sound in Linux +OBJ_CD=cd_linux.o +#if you want no CD audio +#OBJ_CD=cd_null.o +#K6/athlon optimizations +#CPUOPTIMIZATIONS=-march=k6 +#note: don't use -march=athlon, every gcc which has it currently (2.96-3.1) +#have optimizer bugs (like entities disappearing randomly - a bug with +#compiling BOX_ON_PLANE_SIDE in mathlib.h) +#CPUOPTIMIZATIONS=-march=athlon +#686 optimizations +#CPUOPTIMIZATIONS=-march=i686 +#no specific CPU +CPUOPTIMIZATIONS= -clean: - -rm -f darkplaces-glx darkplaces-3dfx - -rm -f vid_glx.o in_svgalib.o vid_3dfxsvga.o $(OBJECTS) *.d -.PHONY: clean +##### Variables that you shouldn't care about ##### + +# Objects +CLIENTOBJECTS= cgame.o cgamevm.o chase.o cl_collision.o cl_demo.o cl_input.o \ + cl_main.o cl_parse.o cl_particles.o cl_screen.o cl_video.o \ + console.o dpvsimpledecode.o fractalnoise.o gl_backend.o \ + gl_draw.o gl_models.o gl_rmain.o gl_rsurf.o gl_textures.o \ + jpeg.o keys.o menu.o meshqueue.o r_crosshairs.o r_explosion.o \ + r_explosion.o r_lerpanim.o r_light.o r_modules.o r_sky.o \ + r_sprites.o sbar.o ui.o vid_shared.o view.o wavefile.o \ + r_shadow.o +SERVEROBJECTS= pr_cmds.o pr_edict.o pr_exec.o sv_light.o sv_main.o sv_move.o \ + sv_phys.o sv_user.o +SHAREDOBJECTS= builddate.o cmd.o collision.o common.o crc.o cvar.o \ + filematch.o host.o host_cmd.o image.o mathlib.o matrixlib.o \ + model_alias.o model_brush.o model_shared.o model_sprite.o \ + net_bsd.o net_dgrm.o net_loop.o net_main.o net_master.o \ + net_udp.o palette.o portals.o protocol.o quakeio.o sys_linux.o \ + sys_shared.o world.o wad.o zone.o + +OBJ_COMMON= $(CLIENTOBJECTS) $(SERVEROBJECTS) $(SHAREDOBJECTS) +OBJ_GLX= vid_glx.o $(OBJ_CD) $(OBJ_SND) +OBJ_DED= vid_null.o cd_null.o snd_null.o + + +# Compilation +CFLAGS_COMMON=-MD -Wall -Werror +CFLAGS_DEBUG=-ggdb +CFLAGS_PROFILE=-g -pg -ggdb +CFLAGS_RELEASE= + +OPTIM_DEBUG= +OPTIM_RELEASE= -O6 -fno-strict-aliasing -ffast-math -funroll-loops \ + -fexpensive-optimizations $(CPUOPTIMIZATIONS) + +DO_CC=$(CC) $(CFLAGS) -c $< -o $@ + + +# Link +# LordHavoc note: I have been informed that system libraries must come last +# on the linker line, and that -lm must always be last +LDFLAGS_COMMON=-ldl -lm +LDFLAGS_DEBUG=-g -ggdb +LDFLAGS_PROFILE=-g -pg +LDFLAGS_RELEASE= + +EXE_GLX=darkplaces-glx +EXE_DED=darkplaces-dedicated + +GLX_LIB=-L/usr/X11R6/lib -lX11 -lXext -lXxf86dga -lXxf86vm $(SOUNDLIB) + +DO_LD=$(CC) $(LDFLAGS) -o $@ $^ + + +##### Commands ##### + +.PHONY : clean help \ + debug profile release \ + glx-debug glx-profile glx-release \ + ded-debug ded-profile ded-release \ + +help: + @echo + @echo "===== Choose one =====" + @echo "* $(MAKE) clean : delete the binaries, and .o and .d files" + @echo "* $(MAKE) help : this help" + @echo "* $(MAKE) debug : make GLX and dedicated binaries (debug versions)" + @echo "* $(MAKE) profile : make GLX and dedicated binaries (profile versions)" + @echo "* $(MAKE) release : make GLX and dedicated binaries (release versions)" + @echo "* $(MAKE) glx-debug : make GLX binary (debug version)" + @echo "* $(MAKE) glx-profile : make GLX binary (profile version)" + @echo "* $(MAKE) glx-release : make GLX binary (release version)" + @echo "* $(MAKE) ded-debug : make dedicated server (debug version)" + @echo "* $(MAKE) ded-profile : make dedicated server (profile version)" + @echo "* $(MAKE) ded-release : make dedicated server (release version)" + @echo + +debug : + $(MAKE) glx-debug ded-debug + +profile : + $(MAKE) glx-profile ded-profile + +release : + $(MAKE) glx-release ded-release + +glx-debug : + $(MAKE) bin-debug EXE="$(EXE_GLX)" + +glx-profile : + $(MAKE) bin-profile EXE="$(EXE_GLX)" + +glx-release : + $(MAKE) bin-release EXE="$(EXE_GLX)" + +ded-debug : + $(MAKE) bin-debug EXE="$(EXE_DED)" + +ded-profile : + $(MAKE) bin-profile EXE="$(EXE_DED)" + +ded-release : + $(MAKE) bin-release EXE="$(EXE_DED)" + +bin-debug : + @echo + @echo "========== $(EXE) (debug) ==========" +# @echo Using compiler $(CC) +# @echo Compiling with flags: $(CFLAGS_COMMON) $(CFLAGS_DEBUG) \ +# $(OPTIM_DEBUG) +# @echo + $(MAKE) $(EXE) \ + CFLAGS="$(CFLAGS_COMMON) $(CFLAGS_DEBUG) $(OPTIM_DEBUG)"\ + LDFLAGS="$(LDFLAGS_DEBUG)" + +bin-profile : + @echo + @echo "========== $(EXE) (profile) ==========" +# @echo Using compiler $(CC) +# @echo Compiling with flags: $(CFLAGS_COMMON) $(CFLAGS_PROFILE) \ +# $(OPTIM_RELEASE) +# @echo + $(MAKE) $(EXE) \ + CFLAGS="$(CFLAGS_COMMON) $(CFLAGS_PROFILE) $(OPTIM_RELEASE)"\ + LDFLAGS="$(LDFLAGS_PROFILE)" + +bin-release : + @echo + @echo "========== $(EXE) (release) ==========" +# @echo Using compiler $(CC) +# @echo Compiling with flags: $(CFLAGS_COMMON) $(CFLAGS_RELEASE) \ +# $(OPTIM_RELEASE) +# @echo + $(MAKE) $(EXE) \ + CFLAGS="$(CFLAGS_COMMON) $(CFLAGS_RELEASE) $(OPTIM_RELEASE)"\ + LDFLAGS="$(LDFLAGS_RELEASE)" + +builddate: + touch builddate.c + +vid_glx.o: vid_glx.c +# @echo " Compiling" $< + $(DO_CC) -I/usr/X11R6/include + +.c.o: +# @echo " Compiling" $< + $(DO_CC) + +$(EXE_GLX): $(OBJ_COMMON) $(OBJ_GLX) +# @echo " Linking " $@ + $(DO_LD) $(GLX_LIB) $(LDFLAGS_COMMON) + +$(EXE_DED): $(OBJ_COMMON) $(OBJ_DED) +# @echo " Linking " $@ + $(DO_LD) $(LDFLAGS_COMMON) + +clean: + rm -f $(EXE_GLX) $(EXE_DED) *.o *.d -include *.d