X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=Makefile;h=9c70f2ba823fddd99ca1864bbdd2346a41fb427c;hp=b36aca6b2a5b020bd483737fb551a74740523f3c;hb=5f551788224a3cf0988ae490a807b20292822f20;hpb=c07a2b209d44273098e2d435ebdca82f158c0373 diff --git a/Makefile b/Makefile index b36aca6b..9c70f2ba 100644 --- a/Makefile +++ b/Makefile @@ -10,80 +10,32 @@ # 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 >> $@ cat $^ | grep 'Total score:' >> $@ -$(SCOREDIR)/score-%: ccan/%/_info tools/ccanlint/ccanlint $(OBJFILES) - mkdir -p $(SCOREDIR) +$(SCOREDIR)/%.score: ccan/%/_info tools/ccanlint/ccanlint $(OBJFILES) + mkdir -p `dirname $@` tools/ccanlint/ccanlint -v -s ccan/$* > $@ || true $(ALL_DEPENDS): %/.depends: %/_info tools/ccan_depends @@ -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 $<