X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=Makefile;h=8d53cbc68449ed475f4847c6ae511094f25108ce;hp=62f244ed98ee6367dc0fbd2ef296acd81672b107;hb=2622d34405aa838770d9c72c523db4ed8defadaa;hpb=c737f1fcc960571bb88c47f217991d4b0e48f663 diff --git a/Makefile b/Makefile index 62f244ed..8d53cbc6 100644 --- a/Makefile +++ b/Makefile @@ -1,99 +1,58 @@ -# Hacky makefile to compile everything and run the tests in some kind of sane order. -# V=--verbose for verbose tests. - -# This can be overridden on cmdline to generate pages elsewhere. -WEBDIR=~/www/html/ccan/ - -ALL=$(patsubst ccan/%/test, %, $(wildcard ccan/*/test)) -ALL_DIRS=$(patsubst %, ccan/%, $(ALL)) +# Hacky makefile to compile everything and run the tests in some kind +# of sane order. + +# Main targets: +# +# check: run tests on all ccan modules (use 'make check V=--verbose' for more) +# Includes building libccan.a. +# libccan.a: A library with all the ccan modules in it. +# tools: build useful tools in tools/ dir. +# Especially tools/ccanlint/ccanlint and tools/namespacize. +# distclean: destroy everything back to pristine state + +# Anything with an _info file is a module. +ALL=$(patsubst ccan/%/_info, %, $(wildcard ccan/*/_info)) ALL_DEPENDS=$(patsubst %, ccan/%/.depends, $(ALL)) -ALL_PAGES=$(patsubst ccan/%, $(WEBDIR)/info/%.html, $(ALL_DIRS)) -DIRECT_TARBALLS=$(patsubst ccan/%, $(WEBDIR)/tarballs/%.tar.bz2, $(ALL_DIRS)) -DEPEND_TARBALLS=$(patsubst ccan/%, $(WEBDIR)/tarballs/with-deps/%.tar.bz2, $(ALL_DIRS)) -WEB_SUBDIRS=$(WEBDIR)/tarballs $(WEBDIR)/junkcode $(WEBDIR)/tarballs/with-deps $(WEBDIR)/info -JUNKDIRS=$(wildcard junkcode/*) -JUNKPAGES=$(JUNKDIRS:%=$(WEBDIR)/%.html) -JUNKBALLS=$(JUNKDIRS:%=$(WEBDIR)/%.tar.bz2) +# Not all modules have tests. +ALL_TESTS=$(patsubst ccan/%/test/, %, $(wildcard ccan/*/test/)) + +default: libccan.a include Makefile-ccan -check: $(ALL_DIRS:%=test-%) +check: $(ALL_TESTS:%=check-%) distclean: clean rm -f $(ALL_DEPENDS) - rm -rf $(WEBDIR) - -webpages: $(WEB_SUBDIRS) $(WEBDIR)/junkcode $(ALL_PAGES) $(WEBDIR)/list.html $(WEBDIR)/index.html $(WEBDIR)/upload.html $(WEBDIR)/uploader.php $(WEBDIR)/example-config.h $(WEBDIR)/ccan.jpg $(DIRECT_TARBALLS) $(DEPEND_TARBALLS) $(WEBDIR)/ccan.tar.bz2 $(WEBDIR)/Makefile-ccan $(JUNKPAGES) $(JUNKBALLS) - -$(WEB_SUBDIRS): - mkdir -p $@ - -$(WEBDIR)/junkcode/%.tar.bz2: junkcode/% $(WEBDIR)/junkcode - tar cvfj $@ `bzr ls --versioned --kind=file $<` - -$(WEBDIR)/junkcode/%.html: $(WEBDIR)/junkcode/%.tar.bz2 - cd $(WEBDIR) && tar xfj junkcode/$*.tar.bz2 - php5 web/staticjunkcode.php junkcode/$* $* > $@ - -# Override implicit attempt to link directory. -$(ALL_DIRS): - @touch $@ - -$(WEBDIR)/ccan.tar.bz2: - tar cvfj $@ `bzr ls --versioned --kind=file ccan` - -$(ALL_PAGES): tools/doc_extract web/staticmoduleinfo.php - -$(WEBDIR)/list.html: web/staticall.php tools/doc_extract $(DIRECT_TARBALLS) $(DEPEND_TARBALLS) $(WEBDIR)/ccan.tar.bz2 $(JUNKBALLS) - php5 web/staticall.php ccan/ junkcode/ $(WEBDIR) > $@ -$(WEBDIR)/upload.html: web/staticupload.php - php5 web/staticupload.php > $@ +$(ALL_DEPENDS): %/.depends: %/_info tools/ccan_depends + @tools/ccan_depends $* > $@ || ( rm -f $@; exit 1 ) -# cpp inserts gratuitous linebreaks at start of file, makes for php problems. -$(WEBDIR)/uploader.php: web/uploader.php.cpp - cpp -w -C -P $< | grep . > $@ - -$(WEBDIR)/index.html: web/staticindex.php - php5 web/staticindex.php > $@ - -$(WEBDIR)/example-config.h: config.h - cp $< $@ - -$(WEBDIR)/Makefile-ccan: Makefile-ccan - cp $< $@ - -$(WEBDIR)/ccan.jpg: web/ccan.jpg - cp $< $@ - -$(WEBDIR)/info/%.html: ccan/% ccan/%/test $(WEBDIR)/tarballs/%.tar.bz2 $(WEBDIR)/tarballs/with-deps/%.tar.bz2 - URLPREFIX=../ php5 web/staticmoduleinfo.php ccan/$* > $@ - -$(WEBDIR)/tarballs/%.tar.bz2: ccan/% ccan/%/test - tar -c -v -j -f $@ `bzr ls --versioned --kind=file ccan/$*` - -$(WEBDIR)/tarballs/with-deps/%.tar.bz2: ccan/% ccan/%/test tools/ccan_depends - tar cvfj $@ $$(echo ccan/$* $$(tools/ccan_depends ccan/$*) | xargs -n 1 bzr ls --versioned --kind=file) - -$(ALL_DEPENDS): %/.depends: tools/ccan_depends - tools/ccan_depends $* > $@ || ( rm -f $@; exit 1 ) - -test-ccan/%: tools/run_tests ccan/%.o +# Actual dependencies are created in inter-depends +check-%: tools/run_tests ccan/%/info @echo Testing $*... - @if tools/run_tests $(V) ccan/$* | grep ^'not ok'; then exit 1; else exit 0; fi + @if tools/run_tests $(V) $$(for f in `ccan/$*/info libs`; do echo --lib=$$f; done) `[ ! -f ccan/$*.o ] || echo --apiobj=ccan/$*.o` ccan/$* $(filter-out ccan/$*.o, $(filter %.o, $^)) | grep ^'not ok'; then exit 1; else exit 0; fi + +ccan/%/info: ccan/%/_info + $(CC) $(CFLAGS) -o $@ -x c $< -ccanlint: tools/ccanlint/ccanlint +libccan.a(%.o): ccan/%.o + $(AR) r $@ $< clean: tools-clean - $(RM) `find . -name '*.o'` `find . -name '.depends'` `find . -name '*.a'` `find . -name _info` + $(RM) `find . -name '*.o'` `find . -name '.depends'` `find . -name '*.a'` `find . -name info` `find . -name '*.d'` $(RM) inter-depends lib-depends test-depends -inter-depends: $(ALL_DEPENDS) - for f in $(ALL_DEPENDS); do echo test-ccan/`basename \`dirname $$f\``: `sed -n 's,ccan/\(.*\),ccan/\1.o,p' < $$f`; done > $@ +# Creates a dependency from the tests to the object files which it needs. +inter-depends: $(ALL_DEPENDS) Makefile + @for f in $(ALL_DEPENDS); do echo check-$$(basename $$(dirname $$f) ): $$(for dir in $$(cat $$f) $$(dirname $$f); do [ "$$(echo $$dir/*.c)" = "$$dir/*.c" ] || echo ccan/"$$(basename $$dir)".o; done); done > $@ -test-depends: $(ALL_DEPENDS) - for f in $(ALL_DEPENDS); do echo test-ccan/`basename \`dirname $$f\``: `sed -n 's,ccan/\(.*\),test-ccan/\1,p' < $$f`; done > $@ +# Creates dependencies between tests, so if foo depends on bar, bar is tested +# first +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 > $@ include tools/Makefile -include inter-depends -include test-depends +-include Makefile-web