X-Git-Url: https://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=Makefile;h=146a516ac97f0ba9f1028a9ec2bf80664fde178f;hp=4e49797456302ff8bad93620071cbf132c4db601;hb=3404ba2a1b34e766628d5b9febf401011aa6753f;hpb=6841e5f5400313f101709bc502a197163b49fdbc diff --git a/Makefile b/Makefile index 4e497974..146a516a 100644 --- a/Makefile +++ b/Makefile @@ -1,19 +1,17 @@ -# Hacky makefile to compile everything and run the tests in some kind of sane order. -# V=--verbose for verbose tests. +# Hacky makefile to compile everything and run the tests in some kind +# of sane order. -# This can be overridden on cmdline to generate pages elsewhere. -WEBDIR=~/www/html/ccan/ +# Main targets: +# +# check: run tests on all ccan modules (use 'make check V=--verbose' for more) +# Includes building libccan.a. +# tools: build useful tools in tools/ dir. +# Especially tools/ccanlint/ccanlint and tools/namespacize. +# distclean: destroy everything back to pristine state ALL=$(patsubst ccan/%/test, %, $(wildcard ccan/*/test)) ALL_DIRS=$(patsubst %, ccan/%, $(ALL)) 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) include Makefile-ccan @@ -21,60 +19,11 @@ check: $(ALL_DIRS:%=test-%) 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 > $@ - -# 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 ) @@ -82,7 +31,10 @@ test-ccan/%: tools/run_tests libccan.a(%.o) @echo Testing $*... @if tools/run_tests $(V) ccan/$* | grep ^'not ok'; then exit 1; else exit 0; fi -ccanlint: tools/ccanlint/ccanlint +# Some don't have object files. +test-ccan/%:: tools/run_tests + @echo Testing $*... + @if tools/run_tests $(V) ccan/$* | grep ^'not ok'; then exit 1; else exit 0; fi clean: tools-clean $(RM) `find . -name '*.o'` `find . -name '.depends'` `find . -name '*.a'` `find . -name _info` @@ -98,3 +50,4 @@ test-depends: $(ALL_DEPENDS) include tools/Makefile -include inter-depends -include test-depends +-include Makefile-web