X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=Makefile;h=b885875a4d6b3fcfa73c1c0b839c0f0db9ceee05;hp=570793c711aaf7634bf4215dd52eedc8f8420a01;hb=892f59bdc1830443f87ad3aaeddaab2eeefb5937;hpb=04f453bbedd1eca3e5ab93290304d8193ffdd87f diff --git a/Makefile b/Makefile index 570793c7..b885875a 100644 --- a/Makefile +++ b/Makefile @@ -10,73 +10,25 @@ # Especially tools/ccanlint/ccanlint and tools/namespacize. # distclean: destroy everything back to pristine state -# Trying to build the whole repo is usually a lose; there will be some -# dependencies you don't have. -EXCLUDE=wwviaudio ogg_to_pcm jmap jset nfs - # Where make scores puts the results SCOREDIR=scores/$(shell whoami)/$(shell uname -s)-$(shell uname -m)-$(CC)-$(shell git describe --always --dirty) -ALL=$(filter-out $(EXCLUDE), $(REALLY_ALL)) - -ALL_DEPENDS=$(patsubst %, ccan/%/.depends, $(REALLY_ALL)) - -# Not all modules have tests. -ALL_TESTS=$(patsubst ccan/%/test/, %, $(foreach dir, $(ALL), $(wildcard ccan/$(dir)/test/))) - -# Here's my rough logarithmic timeout graph for my laptop: -# -# 302 - -# | / --* -# | / -# | / -# | / -# |Execution Time, seconds / -# | / -# | ---// -# | / -# | // -# | ---\ --- -# | --- \\ ------ -# |----------------- \--- -# 19 +------------------------------------------------------+-- -# 0 Timeout (ms, logarithmic) 262144 -# -# 140 -# | -# |------------ -# | --- -# | --------- -# | ------- -# | --\ -# | \\- -# | Tests skipped --\ -# | \ -# | \\ -# | \\\ -# | \ -# | \---- -# --+0---------------------------------------------------==+-- -# 0 Timeout (ms, logarithmic) 262144 -# -# On my laptop, this runs 574 tests in 40 seconds, vs. a full check which -# runs 676 tests in 260 seconds. -FASTTIMEOUT=750 - default: libccan.a +ALL_DEPENDS=$(patsubst %, ccan/%/.depends, $(MODS_NORMAL) $(MODS_EXTERNAL)) + include Makefile-ccan -fastcheck: $(ALL_TESTS:%=summary-fastcheck-%) +fastcheck: $(MODS_NORMAL:%=summary-fastcheck-%) -check: $(ALL_TESTS:%=summary-check-%) +check: $(MODS_NORMAL:%=summary-check-%) distclean: clean rm -f $(ALL_DEPENDS) scores: $(SCOREDIR)/SUMMARY -$(SCOREDIR)/SUMMARY: $(patsubst ccan/%/_info, $(SCOREDIR)/score-%, $(wildcard ccan/*/_info)) +$(SCOREDIR)/SUMMARY: $(MODS:%=$(SCOREDIR)/score-%) git describe --always > $@ uname -a >> $@ $(CC) -v >> $@ @@ -94,7 +46,7 @@ check-%: tools/ccanlint/ccanlint tools/ccanlint/ccanlint ccan/$* fastcheck-%: tools/ccanlint/ccanlint - tools/ccanlint/ccanlint --timeout $(FASTTIMEOUT) ccan/$* + tools/ccanlint/ccanlint -x tests_pass_valgrind -x tests_compile_coverage ccan/$* # Doesn't test dependencies, doesn't print verbose fail results. summary-check-%: tools/ccanlint/ccanlint $(OBJFILES) @@ -103,6 +55,13 @@ summary-check-%: tools/ccanlint/ccanlint $(OBJFILES) summary-fastcheck-%: tools/ccanlint/ccanlint $(OBJFILES) tools/ccanlint/ccanlint -x tests_pass_valgrind -x tests_compile_coverage -s ccan/$* +# FIXME: Horrible hacks because % doesn't match / +summary-fastcheck-antithread/%: tools/ccanlint/ccanlint $(OBJFILES) + tools/ccanlint/ccanlint -x tests_pass_valgrind -x tests_compile_coverage -s ccan/antithread/$* + +summary-fastcheck-tal/%: tools/ccanlint/ccanlint $(OBJFILES) + tools/ccanlint/ccanlint -x tests_pass_valgrind -x tests_compile_coverage -s ccan/tal/$* + ccan/%/info: ccan/%/_info $(CC) $(CCAN_CFLAGS) -o $@ -x c $< @@ -122,8 +81,14 @@ inter-depends: $(ALL_DEPENDS) Makefile test-depends: $(ALL_DEPENDS) Makefile for f in $(ALL_DEPENDS); do echo check-`basename \`dirname $$f\``: `sed -n 's,ccan/\(.*\),check-\1,p' < $$f`; done > $@ +TAGS: FORCE + find * -name '*.[ch]' | xargs etags + +FORCE: + +# Ensure we don't end up with empty file if configurator fails! config.h: tools/configurator/configurator Makefile Makefile-ccan - @tools/configurator/configurator $(CC) $(CCAN_CFLAGS) > config.h + tools/configurator/configurator $(CC) $(CCAN_CFLAGS) > $@.tmp && mv $@.tmp $@ include tools/Makefile -include inter-depends