added target fps
[physics.git] / Makefile
index e50347d..e61452c 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -14,14 +14,6 @@ CXXFLAGS := ${MYFLAGS} ${DBGFLAGS}
 CXX := g++
 
 DIRS := # := start
-DIRS += ./
-DIRS += Entities/
-DIRS += GameStates/
-DIRS += Effects/
-DIRS += config/
-DIRS += input/
-DIRS += graphics/
-DIRS += locks/
 
 SRCSDIR := src/
 SRCS    := # := start
@@ -33,7 +25,8 @@ DEPSDIR := deps/
 DEPS    := # := start
 
 # include all of the dir.mk
-include $(addprefix ${SRCSDIR},$(addsuffix dir.mk,${DIRS}))
+DIRMK   := dir.mk
+include ${SRCSDIR}${DIRMK}
 
 WORKINGDIR  := bind/
 
@@ -49,22 +42,24 @@ TARGETNAME  := run_physics
 TARGETTMP   := ${OBJSDIR}${TARGETNAME}
 TARGET      := ${WORKINGDIR}${TARGETNAME}
 
-DEPSBLDDIRS := $(addprefix ${DEPSDIR},${DIRS})
-OBJSBLDDIRS := $(addprefix ${OBJSDIR},${DIRS})
+DEPSBLDDIRS := ${DEPSDIR} $(addprefix ${DEPSDIR},${DIRS})
+OBJSBLDDIRS := ${OBJSDIR} $(addprefix ${OBJSDIR},${DIRS})
 BLDDIRS     := ${OBJSBLDDIRS} ${DEPSBLDDIRS} ${WORKINGDIR} ${DSTCFGDIR}
 
+INCDIRS     := ${SRCSDIR}
+
 
 PRNTFMT := printf "%-5s: %s\n"
 
 VERBOSE := 0
 
 ifeq (${VERBOSE},0)
-    # quiet the echo command
+    # quiet the printf command
     Q1 := @
     # quiet the command that is `replaced' by an echo
     Q2 := @
 else
-    # EAT the echo command as if it was not there
+    # EAT the printf 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 :=
@@ -85,45 +80,52 @@ ${TARGET}: ${TARGETTMP} | ${WORKINGDIR}
 
 # how to make a directory
 ${BLDDIRS}:
+       ${Q1}${PRNTFMT} "mkdir" "$@"
        ${Q2}mkdir -p $@
 
+#${SRCSDIR}%.cpp: ${SRCSDIR}%.h
+
+# cause the below directory rules to work out
+.SECONDEXPANSION:
+
 # rule to make an object file from a .cpp
-${OBJSDIR}%.o: ${SRCSDIR}%.cpp | ${OBJSBLDDIRS}
+${OBJSDIR}%.o: ${SRCSDIR}%.cpp | $$(dir $$@)
        ${Q1}${PRNTFMT} "${CXX}" "$@"
-       ${Q2}${CXX} ${CXXFLAGS} -c -o $@ $<
+       ${Q2}${CXX} ${CXXFLAGS} -c -o $@ $< -I "${INCDIRS}"
 
 # rule to make a depend file from a .cpp
 #   be clever and escape the / chars in file paths
 #   DON'T simply use another sed delimiter or it can't appear in the file paths
-${DEPSDIR}%.d: ${SRCSDIR}%.cpp | ${DEPSBLDDIRS}
+${DEPSDIR}%.d: ${SRCSDIR}%.cpp | $$(dir $$@)
        ${Q1}${PRNTFMT} "DEP" "$@"
-       ${Q2}${CXX} -MM ${CXXFLAGS} $< | \
+       ${Q2}${CXX} -MM ${CXXFLAGS} $< -I "${INCDIRS}" | \
                sed 's/\(^.*\):/$(subst /,\/,${OBJSDIR}\1 $@):/' > $@
 
 # rule to copy the config files into the working directory
-${DSTCFGDIR}%.cfg: ${SRCCFGDIR}%.cfg | ${DSTCFGDIR}
+${DSTCFGDIR}%.cfg: ${SRCCFGDIR}%.cfg | $$(dir $$@)
        ${Q1}${PRNTFMT} "cp" "$@"
        ${Q2}cp $< $@
 
+.PHONY: cleantargets
+cleantargets:
+       ${Q1}${PRNTFMT} "rm" "${TARGET} ${TARGETTMP}"
+       ${Q2}rm -f ${TARGET}
 
-tags: ${SRCS}
-       ${Q1}${PRNTFMT} "ctags" "$@"
-       ${Q2}ctags $^
-
-
-.PHONY: clean
-clean:
+.PHONY: cleanobjs
+cleanobjs:
        ${Q1}${PRNTFMT} "rm" "${OBJSDIR}"
        ${Q2}rm -rf ${OBJSDIR}
-       ${Q1}${PRNTFMT} "rm" "${TARGET} ${TARGETTMP}"
-       ${Q2}rm -f ${TARGET}
 
-.PHONY: distclean
-distclean: clean
+.PHONY: cleandeps
+cleandeps:
        ${Q1}${PRNTFMT} "rm" "${DEPSDIR}"
        ${Q2}rm -rf ${DEPSDIR}
-       ${Q1}${PRNTFMT} "rm" "tags prof gmon.out"
-       ${Q2}rm -f tags prof gmon.out
+
+.PHONY: clean
+clean: cleantargets cleanobjs
+
+.PHONY: cleanall
+cleanall: clean cleandeps
 
 .PHONY: gitclean
 gitclean:
@@ -162,8 +164,8 @@ val: all
 
 .PHONY: prof
 prof: run
-       cd ${WORKINGDIR}; gprof -b ${TARGETNAME} > src/prof
-       kprof -f prof
+       cd ${WORKINGDIR}; gprof -b ${TARGETNAME} > prof
+       cd ${WORKINGDIR}; kprof -f prof
 
 
 MINGMAKEARGS := "LIBGL      := -lopengl32 -lglu32" \
@@ -188,4 +190,5 @@ final:
        ${Q1}${PRNTFMT} "make" "final"
        ${Q2}${MAKE} ${FINALMAKEARGS} clean all
 
+
 -include ${DEPS}