X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=Makefile-web;h=86031c55693c6fda8a99534a65c9b63feb898f35;hp=4a180ecaa6899c1637a15e8b526296097f5cb38a;hb=adc90816df194167a588a943ae503a37fec3fb6a;hpb=e30753942e5a5ea6e958fdd850fc7a9c33285dae diff --git a/Makefile-web b/Makefile-web index 4a180eca..86031c55 100644 --- a/Makefile-web +++ b/Makefile-web @@ -1,48 +1,62 @@ # This can be overridden on cmdline to generate pages elsewhere. -WEBDIR=~/www/html/ccan/ +WEBDIR=/srv/www/ccodearchive.net -ALL_PAGES=$(patsubst %, $(WEBDIR)/info/%.html, $(ALL)) -DIRECT_TARBALLS=$(patsubst %, $(WEBDIR)/tarballs/%.tar.bz2, $(ALL)) -DEPEND_TARBALLS=$(patsubst %, $(WEBDIR)/tarballs/with-deps/%.tar.bz2, $(ALL)) +ALL_PAGES=$(patsubst %, $(WEBDIR)/info/%.html, $(MODS)) +DIRECT_TARBALLS=$(patsubst %, $(WEBDIR)/tarballs/%.tar.bz2, $(MODS)) +DEPEND_TARBALLS=$(patsubst %, $(WEBDIR)/tarballs/with-deps/%.tar.bz2, $(MODS)) WEB_SUBDIRS=$(WEBDIR)/tarballs $(WEBDIR)/junkcode $(WEBDIR)/tarballs/with-deps $(WEBDIR)/info JUNKDIRS=$(wildcard junkcode/*) JUNKPAGES=$(JUNKDIRS:%=$(WEBDIR)/%.html) JUNKBALLS=$(JUNKDIRS:%=$(WEBDIR)/%.tar.bz2) +PRETTIFY=$(WEBDIR)/prettify/src/run_prettify.js $(WEBDIR)/prettify/src/prettify.css -upload: check webpages - bzr push - send-web # Rusty's upload script. +upload: fastcheck modcheck + git push origin HEAD:master + git push github HEAD:master -webpages: $(WEB_SUBDIRS) $(WEBDIR)/junkcode $(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 $(ALL_PAGES) $(JUNKPAGES) $(JUNKBALLS) +# Check MODS list in Makefile-ccan matches modules we find. +modcheck: + @FOUND=$$(echo $$(find ccan -name _info | sed 's,ccan/\(.*\)/_info,\1,' | sort) ); LISTED=$$(echo $$(echo $(MODS) | tr ' ' '\012' | sort) ); if [ "$$FOUND" = "$$LISTED" ]; then exit 0; fi; while true; do a="$${FOUND%% *}"; b="$${LISTED%% *}"; if [ "$$a" != "$$b" ]; then echo "$$a found but $$b in MOD" >&2; exit 1; fi; FOUND="$${FOUND#* }"; LISTED="$${LISTED#* }"; done -$(WEB_SUBDIRS): +clean-tree: + [ "$(WEBDEV)" ] || ! git status --porcelain | grep . + +webpages: modcheck clean-tree webpages-unchecked + +webpages-unchecked: $(WEB_SUBDIRS) $(PRETTIFY) $(WEBDIR)/index.html $(WEBDIR)/upload.html $(WEBDIR)/uploader.php $(WEBDIR)/example-config.h $(WEBDIR)/ccan.png $(WEBDIR)/ccan-bg.png $(WEBDIR)/ccan.css $(DIRECT_TARBALLS) $(DEPEND_TARBALLS) $(WEBDIR)/ccan.tar.bz2 $(WEBDIR)/Makefile-ccan $(ALL_PAGES) junkpages + +junkpages: $(WEBDIR)/list.html $(WEBDIR)/junkcode $(JUNKPAGES) $(JUNKBALLS) +$(WEB_SUBDIRS): $(WEBDIR) mkdir -p $@ +$(PRETTIFY): + svn checkout http://google-code-prettify.googlecode.com/svn/trunk/ $(WEBDIR)/prettify + $(WEBDIR)/junkcode/%.tar.bz2: junkcode/% $(WEBDIR)/junkcode - bzr ls --versioned --kind=file --null $< | xargs -0 -x tar cvfj $@ + git ls-files -z $< | xargs -0 -x tar cvfj $@ $(WEBDIR)/junkcode/%.html: $(WEBDIR)/junkcode/%.tar.bz2 cd $(WEBDIR) && tar xfj junkcode/$*.tar.bz2 - php5 web/staticjunkcode.php junkcode/$* $* > $@ + URLPREFIX=../ php5 web/staticjunkcode.php junkcode/$* $* > $@ -# We want tarball to contain ccan/ -$(WEBDIR)/ccan.tar.bz2: config.h Makefile Makefile-ccan $(shell bzr ls --versioned --kind=file ccan) $(shell bzr ls --versioned --kind=file tools) - DIR=`pwd` && cd /tmp && ln -sf "$$DIR" ccan && tar cvfj $@ `for f in $^; do echo ccan/$$f; done` && rm ccan +# We want tarball to contain ccan/; we put junkcode in, but don't depend on it. +$(WEBDIR)/ccan.tar.bz2: config.h Makefile Makefile-ccan $(shell git ls-files ccan tools licenses) + DIR=`pwd` && cd /tmp && ln -sf "$$DIR" ccan && tar cvfj $@ `for f in $^; do echo ccan/$$f; done` ccan/junkcode && rm 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) > $@ + php5 web/staticall.php ccan/ junkcode/ $(WEBDIR) $(MODS) > $@ $(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 . > $@ + cpp -w -C -P $< | grep . > $@ $(WEBDIR)/index.html: web/staticindex.php - @php5 web/staticindex.php > $@ + php5 web/staticindex.php > $@ $(WEBDIR)/example-config.h: config.h cp $< $@ @@ -50,17 +64,26 @@ $(WEBDIR)/example-config.h: config.h $(WEBDIR)/Makefile-ccan: Makefile-ccan cp $< $@ -$(WEBDIR)/ccan.jpg: web/ccan.jpg +$(WEBDIR)/ccan.png: web/ccan.png + cp $< $@ + +$(WEBDIR)/ccan-bg.png: web/ccan-bg.png + cp $< $@ + +$(WEBDIR)/ccan.css: web/ccan.css cp $< $@ $(WEBDIR)/info/%.html: $(WEBDIR)/tarballs/%.tar.bz2 $(WEBDIR)/tarballs/with-deps/%.tar.bz2 - @URLPREFIX=../ php5 web/staticmoduleinfo.php ccan/$* > $@ + @mkdir -p `dirname $@` + URLPREFIX=../`echo $* | tr -dc '/' | sed s',/,../,g'` php5 web/staticmoduleinfo.php `pwd`/ccan/$* $* > $@ -$(WEBDIR)/tarballs/%.tar.bz2: ccan/%/_info.c - tar -c -j -f $@ `bzr ls --versioned --kind=file ccan/$*` +$(WEBDIR)/tarballs/%.tar.bz2: ccan/%/_info clean-tree + @mkdir -p `dirname $@` + FILES=$$(tools/list_files.sh ccan/$*) && tar -c -j -f $@ $$FILES $$(echo $$FILES | xargs -n1 -r readlink | sed 's,^\(../\)*,,' | sort -u) -$(WEBDIR)/tarballs/with-deps/%.tar.bz2: ccan/%/_info.c tools/ccan_depends - tar cfj $@ $$(echo ccan/$* $$(tools/ccan_depends ccan/$*) | xargs -n 1 bzr ls --versioned --kind=file) +$(WEBDIR)/tarballs/with-deps/%.tar.bz2: ccan/%/_info tools/ccan_depends clean-tree + @mkdir -p `dirname $@` + FILES=$$(tools/list_files.sh ccan/$* $$(tools/ccan_depends ccan/$*) ) && tar -c -j -f $@ $$FILES $$(echo $$FILES | xargs -n1 -r readlink | sed 's,^\(../\)*,,' | sort -u) distclean: distclean-web