-LIBALLG = `allegro-config --libs release`
-LIBGL = -lGL -lGLU
-LIBSDL = `sdl-config --libs`
-LIBS = ${LIBSDL} ${LIBGL}
+LIBGL := -lGL -lGLU
+LIBSDL := `sdl-config --libs`
+LIBS := ${LIBSDL} ${LIBGL}
-CXX = g++
-CXXFLAGS = -ggdb -Wall -pedantic
+OPTFLAGS := -O2
+DBGFLAGS := -ggdb
+PRFFLAGS := ${DBGFLAGS} -pg
+CXXFLAGS := -Wall -pedantic -ansi ${DBGFLAGS}
-SRCS = Vector2.cpp ticks.cpp main.cpp game.cpp entityManager.cpp gldraw.cpp graphics.cpp
-OBJS = ${SRCS:.cpp=.o}
+VALFLAGS := --leak-check=full
-TARGETS = ../run_physics
-DEPEND = depend.mk
+TARGET := ../run_physics
-# set suffixes to look for ...
-.SUFFIXES: .cpp .o
+SRCS := # simply to keep every line below the same
+SRCS += game.cpp
+SRCS += main.cpp
+SRCS += mathw.cpp
+SRCS += ticks.cpp
+SRCS += Vector2.cpp
+SRCS += handleSignal.cpp
-# set default action for a *.cc to create a *.o
-.cpp.o:
- g++ -c $< ${CXXFLAGS}
+SRCS += entityManager.cpp
+SRCS += effectManager.cpp
+SRCS += entityCreator.cpp
+SRCS += collisionHandler.cpp
+SRCS += CollisionInfo.cpp
-all: ${TARGETS}
+SRCS += Entities/Ball.cpp
+SRCS += Entities/Entity.cpp
+SRCS += Entities/Line.cpp
+SRCS += Entities/Particle.cpp
+SRCS += Entities/PhysicsEntity.cpp
+SRCS += Entities/Point.cpp
+SRCS += Entities/Polygon.cpp
+SRCS += Entities/WindParticle.cpp
-depend:
- ${CXX} -MM ${SRCS} > ${DEPEND}
+SRCS += GameStates/CreatingPolygon.cpp
+SRCS += GameStates/GameState.cpp
+SRCS += GameStates/Paused.cpp
+SRCS += GameStates/Running.cpp
-tags:
- ctags ${SRCS}
+SRCS += Effects/Effect.cpp
+SRCS += Effects/Gravity.cpp
+SRCS += Effects/GravityWell.cpp
+SRCS += Effects/Screen.cpp
-clean:
- rm -f ${OBJS} ${TARGETS} *~
+SRCS += config/config.cpp
-distclean: clean
- rm -f tags depend.mk
- touch depend.mk
+SRCS += input/inputManager.cpp
+
+SRCS += graphics/graphics.cpp
+
+OBJSDIR := ../objs/
+OBJS := ${SRCS:.cpp=.o}
+OBJS := $(addprefix ${OBJSDIR},${OBJS})
+
+DEPSDIR := ../deps/
+DEPS := ${SRCS:.cpp=.d}
+DEPS := $(addprefix ${DEPSDIR},${DEPS})
+
+HRDS := ${SRCS:.cpp=.h}
+HRDS := $(filter-out main.h,$HRDS) # remove main.h
+HRDS += debug.h
+
+HRDS += graphics/colors.h
-# i need to find a nice way of ijnoring .svn folders for the below
-tar: clean
- cd ..; tar -cjf bluestar.tar.bz2 images/ source/
+TARS := ${SRCS} ${HRDS} Makefile
-run: ../run_physics
- cd ..; ./run_physics
+VERBOSE := 0
-../run_physics: ${OBJS}
- ${CXX} ${CXXFLAGS} -o ../run_physics ${OBJS} ${LIBS}
+ifeq (${VERBOSE},0)
+ # quiet the echo command
+ Q1 := @
+ # quiet the command that is `replaced' by an echo
+ Q2 := @
+else
+ # EAT the echo command as if it was not there
+ Q1 := @true # NOTE: the space between @true and the # is VERY important!!
+ # do not quiet the command output
+ Q2 :=
+endif
-Entities.d:
- cd Entities; make
+.PHONY: all
+all: ${TARGET}
-include ${DEPEND}
+${TARGET}: ${OBJS}
+ ${Q1}echo "${CXX}: $@"
+ ${Q2}${CXX} ${CXXFLAGS} -o $@ $^ ${LIBS}
+# rule to make a depend file from a .cpp
+${DEPSDIR}%.d: %.cpp
+ ${Q1}echo "DEP: $@"
+ ${Q2}${CXX} -M ${CXXFLAGS} $< | sed 's,: , $@: ,' > $@
+
+# rule to make an object file from a .cpp
+${OBJSDIR}%.o: %.cpp
+ ${Q1}echo "${CXX}: $@"
+ ${Q2}${CXX} ${CXXFLAGS} -c -o $@ $<
+
+
+.PHONY: clean
+clean:
+ ${Q1}echo "CLEAN: OBJS"
+ ${Q2}rm -f ${OBJS}
+ ${Q1}echo "CLEAN: TARGET"
+ ${Q2}rm -f ${TARGET}
+
+.PHONY: distclean
+distclean: clean
+ ${Q1}echo "CLEAN: DEPS"
+ ${Q2}rm -f ${DEPS}
+ ${Q1}echo "CLEAN: tags prof gmon.out"
+ ${Q2}rm -f tags prof gmon.out
+
+.PHONY: gitclean
+gitclean:
+ ${Q1}echo "git-clean: show, use gitcleanf to force"
+ ${Q2}cd ..; git clean -nxd
+
+.PHONY: gitcleanf
+gitcleanf:
+ ${Q1}echo "git-clean: forced"
+ ${Q2}cd ..; git clean -fxd
+
+tags: ${SRCS}
+ ctags $^
+
+.PHONY: tar
+tar: ../physics.tar.bz2
+
+.PHONY: ../physics.tar.bz2
+../physics.tar.bz2:
+ @echo "git-archive: Warning, archives HEAD not current"
+ ${Q1}echo "git-archive: ../physics.tar.bz2"
+ ${Q2}cd ..; git-archive --prefix=physics/ HEAD | bzip2 > physics.tar.bz2
+
+.PHONY: run
+run: all
+ ${TARGET}
+
+.PHONY: gdb
+gdb: all
+ gdb ${TARGET}
+
+.PHONY: val
+val: all
+ valgrind ${VALFLAGS} ${TARGET}
+
+.PHONY: prof
+prof: all
+ ${TARGET}
+ gprof -b ${TARGET} > prof
+ kprof -f prof
+
+-include ${DEPS}