X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;ds=sidebyside;f=src%2FMakefile;h=d034771b175b750a31b4dacd6144d3bbaf49e531;hb=4c23826c2c9f8f6c7d1fec69769ba0d7254c9a7c;hp=2be4220a3589872a6d424ee28cd257aeacaf9ca0;hpb=a16126b0981ba82ddcd5f7b0f763bc4ce6aa9bdc;p=rocksndiamonds.git diff --git a/src/Makefile b/src/Makefile index 2be4220a..d034771b 100644 --- a/src/Makefile +++ b/src/Makefile @@ -34,11 +34,44 @@ ifeq ($(PLATFORM),solaris) EXTRA_LIBS = -lnsl -lsocket -R$(XLIB_PATH) endif -INCL = $(X11_INCL) -LIBS = $(X11_LIBS) -lX11 -lm $(EXTRA_LIBS) +ifeq ($(PLATFORM),windows) +PROGNAME = ../rocksndiamonds.exe +TARGET = sdl +else +PROFILING = -pg +endif + +ifeq ($(TARGET),sdl) +USE_SDL = true +else +USE_SDL = false +endif + +ifeq ($(USE_SDL_OLD_LIBS),true) +SDL_EXTRA_LIBS = -lIMG -lmixer +else +SDL_EXTRA_LIBS = -lSDL_image -lSDL_mixer +endif + +SDL_CFLAGS := -DUSE_SDL_LIBRARY $(shell sdl-config --cflags) +SDL_LDFLAGS := $(SDL_EXTRA_LIBS) $(shell sdl-config --libs) +X11_CFLAGS = $(X11_INCL) +X11_LDFLAGS = $(X11_LIBS) -lX11 + +ifeq ($(USE_SDL),true) +SYS_CFLAGS = $(SDL_CFLAGS) +SYS_LDFLAGS = $(SDL_LDFLAGS) +else +SYS_CFLAGS = $(X11_CFLAGS) +SYS_LDFLAGS = $(X11_LDFLAGS) endif +INCL = $(SYS_CFLAGS) +LIBS = $(SYS_LDFLAGS) $(EXTRA_LIBS) -lm + +endif # (PLATFORM != dos) + ifdef RO_GAME_DIR # path to read-only game data specified CONFIG_RO_GAME_DIR = -DRO_GAME_DIR="\"$(RO_GAME_DIR)\"" @@ -56,16 +89,18 @@ CONFIG_GAME_DIR = $(CONFIG_RO_GAME_DIR) $(CONFIG_RW_GAME_DIR) CONFIG = $(CONFIG_GAME_DIR) $(CONFIG_SCORE_ENTRIES) $(SOUNDS) $(JOYSTICK) +DEBUG = -DDEBUG -g -# OPTIONS = -DDEBUG -g -Wall -ansi -pedantic # only for debugging purposes -# OPTIONS = -DDEBUG -g -Wall # only for debugging purposes +OPTIONS = $(DEBUG) -Wall # only for debugging purposes +# OPTIONS = $(DEBUG) -O3 -Wall # only for debugging purposes +# OPTIONS = $(DEBUG) -Wall -ansi -pedantic # only for debugging purposes # OPTIONS = -O3 -Wall -ansi -pedantic # OPTIONS = -O3 -Wall -OPTIONS = -O3 +# OPTIONS = -O3 -# SYSTEM = -DSYSV -Ae # may be needed for HP-UX +# SYSTEM = -DSYSV -Ae # may be needed for HP-UX -CFLAGS = $(OPTIONS) $(SYSTEM) $(INCL) $(CONFIG) +CFLAGS = $(OPTIONS) $(SYSTEM) $(SYS_CFLAGS) $(CONFIG) SRCS = main.c \ init.c \ @@ -86,7 +121,10 @@ SRCS = main.c \ image.c \ network.c \ netserv.c \ - msdos.c + msdos.c \ + system.c \ + x11.c \ + sdl.c OBJS = main.o \ init.o \ @@ -107,16 +145,32 @@ OBJS = main.o \ image.o \ network.o \ netserv.o \ - msdos.o + msdos.o \ + system.o \ + x11.o \ + sdl.o all: $(PROGNAME) $(PROGNAME): $(OBJS) - $(CC) $(CFLAGS) $(OBJS) $(LIBS) -o $(PROGNAME) + $(CC) $(PROFILING) $(OBJS) $(LIBS) -o $(PROGNAME) .c.o: - $(CC) $(CFLAGS) -c $*.c + $(CC) $(PROFILING) $(CFLAGS) -c $*.c clean: $(RM) *.o + $(RM) ../*.exe $(RM) $(PROGNAME) + + +#-----------------------------------------------------------------------------# +# development only stuff # +#-----------------------------------------------------------------------------# + +depend: + for i in $(SRCS); do $(CPP) $(CFLAGS) -M $$i; done > .depend + +ifeq (.depend,$(wildcard .depend)) +include .depend +endif