X-Git-Url: https://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=Makefile;h=4e49797456302ff8bad93620071cbf132c4db601;hp=d3e05e9fcd256390642547ea701829fa0823705d;hb=be74c29bc91273ce585139b2b1f7305512ae941b;hpb=963fa5ca9303d146d635e2fba04814f4f791c559 diff --git a/Makefile b/Makefile index d3e05e9f..4e497974 100644 --- a/Makefile +++ b/Makefile @@ -4,15 +4,16 @@ # This can be overridden on cmdline to generate pages elsewhere. WEBDIR=~/www/html/ccan/ -CFLAGS=-g -Wall -Wstrict-prototypes -Wold-style-definition -Wmissing-prototypes -Wmissing-declarations -Werror -Iccan -I. - 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)/tarballs/with-deps $(WEBDIR)/info +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 @@ -22,13 +23,17 @@ 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 +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: - cp -a junkcode $@ +$(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): @@ -39,8 +44,8 @@ $(WEBDIR)/ccan.tar.bz2: $(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 - php5 web/staticall.php ccan/ $(WEBDIR) > $@ +$(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 > $@ @@ -73,7 +78,7 @@ $(WEBDIR)/tarballs/with-deps/%.tar.bz2: ccan/% ccan/%/test tools/ccan_depends $(ALL_DEPENDS): %/.depends: tools/ccan_depends tools/ccan_depends $* > $@ || ( rm -f $@; exit 1 ) -test-ccan/%: tools/run_tests ccan/%.o +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 @@ -83,8 +88,9 @@ clean: tools-clean $(RM) `find . -name '*.o'` `find . -name '.depends'` `find . -name '*.a'` `find . -name _info` $(RM) inter-depends lib-depends test-depends +# Only list a dependency if there are object files to build. 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 > $@ + for f in $(ALL_DEPENDS); do echo test-ccan/$$(basename $$(dirname $$f) ): $$(for dir in $$(cat $$f); do [ "$$(echo $$dir/[a-z]*.c)" = "$$dir/[a-z]*.c" ] || echo libccan.a\("$$(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 > $@