X-Git-Url: https://git.artsoft.org/?p=rocksndiamonds.git;a=blobdiff_plain;f=src%2FMakefile;h=044e136ddff7e86355652ad288bee9477a1de087;hp=4c0a427baea5f9e3ab285213d2227e6449084447;hb=8d46c5298f0fcce7bdb52f3835b2fbbdc403dfe0;hpb=6c76f4a6d82bd6d75b16a3072f61e79865117d8b diff --git a/src/Makefile b/src/Makefile index 4c0a427b..044e136d 100644 --- a/src/Makefile +++ b/src/Makefile @@ -1,97 +1,74 @@ #=============================================================================# -# Makefile for Rocks'n'Diamonds 1.2 # -# (c) 1995-98 Holger Schemel, aeglos@valinor.owl.de # +# Makefile for Rocks'n'Diamonds 1.4.0 # +# (c) 1995-1999 Holger Schemel, aeglos@valinor.owl.de # #=============================================================================# -#-----------------------------------------------------------------------------# -# configuration section # -#-----------------------------------------------------------------------------# - -# change this to your favorite ANSI C compiler -CC = gcc +ifndef PLATFORM # platform not specified -- try auto detection +ifdef COMSPEC +PLATFORM = dos +else +PLATFORM = unix +endif +endif -# on Solaris and similar systems, you'll need to uncomment this -# EXTRA_LIBS = -lnsl -lsocket +ifdef X11_PATH # path to X11 specified by top level Makefile +XINC_PATH = $(X11_PATH)/include +XLIB_PATH = $(X11_PATH)/lib +X11_INCL = -I$(XINC_PATH) +X11_LIBS = -L$(XLIB_PATH) +endif -# specify X11 library path on your system -XLIB_PATH = /usr/X11/lib -# change this to the directory where you want to install game data like levels -GAME_DIR = . +ifeq ($(PLATFORM),dos) # DOS / Windows -# uncomment this if your system has no joystick include file -# JOYSTICK = -DNO_JOYSTICK +RM = del +PROGNAME = ../rocks.exe +LIBS = -s -lm -lalleg -# uncomment this if your system has no sound -# SOUNDS = -DNO_SOUNDS +else # Unix -# choose if you want to allow many global score file entries for one player -# when installing the game in a multi user environment, choose this -# SCORE_ENTRIES = ONE_PER_NAME -# when installing the game in a single user environment, choose this -SCORE_ENTRIES = MANY_PER_NAME +RM = rm -f +PROGNAME = ../rocksndiamonds -# The XPM-Library is no longer needed to build this program, -# but is used to load graphics if XPM_INCLUDE_FILE is defined, -# because the GIF loading routines are still a bit beta. -# If you want to use the Xpm library, convert the GIF files to Xpm -# files (and you need corresponding mask files in xbm format). +ifeq ($(PLATFORM),solaris) +EXTRA_LIBS = -lnsl -lsocket -R$(XLIB_PATH) +endif -# XPM_INCLUDE_FILE = -DXPM_INCLUDE_FILE="" -# EXTRA_X11_LIBS = -lXpm +SDL_CFLAGS := -DUSE_SDL_LIBRARY $(shell sdl-config --cflags) +SDL_LDFLAGS := -lIMG $(shell sdl-config --libs) -#-----------------------------------------------------------------------------# -# you shouldn't need to change anything below # -#-----------------------------------------------------------------------------# +INCL = $(X11_INCL) +LIBS = $(X11_LIBS) -lX11 -lm $(EXTRA_LIBS) $(SDL_LDFLAGS) -ifdef COMSPEC -PLATFORM = dos -else -PLATFORM = unix endif -ifeq ($(PLATFORM),unix) -RM = rm -f -PROGNAME = ../rocksndiamonds -LIBS = -L$(XLIB_PATH) $(EXTRA_X11_LIBS) -lX11 -lm $(EXTRA_LIBS) -else -RM = del -PROGNAME = ..\rocks.exe -LIBS = -lm -lalleg + +ifdef RO_GAME_DIR # path to read-only game data specified +CONFIG_RO_GAME_DIR = -DRO_GAME_DIR="\"$(RO_GAME_DIR)\"" endif -CPP = $(CC) -E +ifdef RW_GAME_DIR # path to writable game data specified +CONFIG_RW_GAME_DIR = -DRW_GAME_DIR="\"$(RW_GAME_DIR)\"" +endif -CONFIG_GAME_DIR = -DGAME_DIR="\"$(GAME_DIR)\"" +ifdef SCORE_ENTRIES # number of score entries per player specified CONFIG_SCORE_ENTRIES = -D$(SCORE_ENTRIES) +endif -CONFIG = $(CONFIG_GAME_DIR) $(SOUNDS) $(JOYSTICK) \ - $(CONFIG_SCORE_ENTRIES) $(XPM_INCLUDE_FILE) - -# DEBUG = -DDEBUG -g -Wall -ansi -pedantic -DEBUG = -DDEBUG -g -Wall -# DEBUG = -O3 -Wall -ansi -pedantic -# DEBUG = -O3 -Wall -# DEBUG = -O3 +CONFIG_GAME_DIR = $(CONFIG_RO_GAME_DIR) $(CONFIG_RW_GAME_DIR) -# SYSTEM = -Aa -D_HPUX_SOURCE -Dhpux # for HP-UX (obsolete) -# SYSTEM = -DSYSV -Ae # for HP-UX -# INCL = -I/usr/include/X11R5 # for HP-UX and others -# INCL = -I/usr/local/X11/include # for SunOS and others -# LIBS = -L/usr/lib/X11R5 -lXpm -lX11 -lm -# # for HP-UX and others -# LIBS = -L/usr/local/X11/lib -lXpm -lX11 -lm -lsocket -R/usr/local/X11/lib -# # for SunOS and others -# LIBS = -L/usr/X11R6/lib -lXpm -lX11 -lm -# LIBS = -L/usr/X11R6/lib -lX11 -lm +CONFIG = $(CONFIG_GAME_DIR) $(CONFIG_SCORE_ENTRIES) $(SOUNDS) $(JOYSTICK) -# LIBS = -L/usr/X11R6/lib $(EXTRA_X11_LIBS) -lX11 -lm $(EXTRA_LIBS) +# OPTIONS = -DDEBUG -g -Wall -ansi -pedantic # only for debugging purposes +OPTIONS = -DDEBUG -g -Wall # only for debugging purposes +# OPTIONS = -O3 -Wall -ansi -pedantic +# OPTIONS = -O3 -Wall +# OPTIONS = -O3 -# LIBS = -L$(XLIB_PATH) $(EXTRA_X11_LIBS) -lX11 -lm $(EXTRA_LIBS) +# SYSTEM = -DSYSV -Ae # may be needed for HP-UX -# CFLAGS = -O2 $(CONFIG) $(SYSTEM) -CFLAGS = $(DEBUG) $(CONFIG) $(SYSTEM) $(INCL) +CFLAGS = $(OPTIONS) $(SDL_CFLAGS) $(SYSTEM) $(INCL) $(CONFIG) SRCS = main.c \ init.c \ @@ -112,7 +89,8 @@ SRCS = main.c \ image.c \ network.c \ netserv.c \ - msdos.c + msdos.c \ + sdl.c OBJS = main.o \ init.o \ @@ -133,7 +111,8 @@ OBJS = main.o \ image.o \ network.o \ netserv.o \ - msdos.o + msdos.o \ + sdl.o all: $(PROGNAME) @@ -146,10 +125,3 @@ $(PROGNAME): $(OBJS) clean: $(RM) *.o $(RM) $(PROGNAME) - -depend: - for i in $(SRCS); do $(CPP) $(CFLAGS) -M $$i; done > .depend - -ifeq (.depend,$(wildcard .depend)) -include .depend -endif