X-Git-Url: https://pd.if.org/git/?p=nbds;a=blobdiff_plain;f=makefile;h=dfabc2db889269431a709505caf47cd89a97c932;hp=f2d16912de4d0c2e87f415ba1d26159256536dd8;hb=f0777b2151019e22458f6f166a8f3c569c32a505;hpb=d791fc64b23a9c0a3ed90aa60571344d7735aee9 diff --git a/makefile b/makefile index f2d1691..dfabc2d 100644 --- a/makefile +++ b/makefile @@ -1,12 +1,11 @@ ################################################################################################### # Written by Josh Dybnis and released to the public domain, as explained at # http://creativecommons.org/licenses/publicdomain -# ################################################################################################### # Makefile for building programs with whole-program interfile optimization ################################################################################################### -OPT := -fwhole-program -combine -03# -DNDEBUG -CFLAGS := -g -Wall -Werror -std=c99 -m64 -fnested-functions $(OPT)# -DENABLE_TRACE +OPT := -fwhole-program -combine -03 #-DNDEBUG +CFLAGS := -g -Wall -Werror -std=c99 -m64 $(OPT) #-DENABLE_TRACE INCS := $(addprefix -I, include) TESTS := output/ll_test output/sl_test output/ht_test output/rcu_test EXES := $(TESTS) @@ -22,7 +21,7 @@ ht_test_SRCS := $(TEST_SRCS) struct/hashtable.c test/ht_test.c test/CuTest.c st tests: $(TESTS) ################################################################################################### -# Run the tests +# build and run tests ################################################################################################### test: $(addsuffix .log, $(TESTS)) @echo > /dev/null @@ -33,15 +32,19 @@ $(addsuffix .log, $(TESTS)) : %.log : % ################################################################################################### # Rebuild an executable if any of it's source files need to be recompiled # -# Note: Calculating dependancies as a side-effect of compilation is disabled. There is a bug in +# Note: Calculating dependencies as a side-effect of compilation is disabled. There is a bug in # gcc. Compilation fails when -MM -MF is used and there is more than one source file. -# -MM -MT $@.d -MF $@.d +# Otherwise "-MM -MT $@.d -MF $@.d" should be part of the command line for the compile. +# +# Also, when calculating dependencies -combine is removed from CFLAGS because of another bug +# in gcc. It chokes when -MM is used with -combine. ################################################################################################### $(EXES): output/% : output/%.d makefile + gcc $(CFLAGS:-combine:) $(INCS) -MM -MT $@ $($*_SRCS) > $@.d gcc $(CFLAGS) $(INCS) -o $@ $($*_SRCS) ################################################################################################### -# Build tags file for vi +# tags file for vi ################################################################################################### tags: ctags -R . @@ -52,15 +55,11 @@ tags: clean: rm -rfv output/* -.PHONY: clean test tags - ################################################################################################### -# Generate the dependencies lists for each executable -# -# Note: -combine is removed from CFLAGS because of a bug in gcc. The compiler chokes when -# -MM is used with -combine. +# dummy rule for boostrapping dependency files ################################################################################################### $(addsuffix .d, $(EXES)) : output/%.d : - gcc $(CFLAGS:-combine:) $(INCS) -MM -MT $@ $($*_SRCS) > $@ -include $(addsuffix .d, $(EXES)) + +.PHONY: clean test tags