X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=Makefile;h=3233b9fd24d1c250b93b83a1b86f21c50a87e2b3;hb=e97df22eacc433a9982aad507f980b303d5fa2c1;hp=31418c5bbb2ecd1365acf3ac3ffc10f7c097ca54;hpb=fee731e35ebcb570b2b98f488badfe54284d4cda;p=platal.git diff --git a/Makefile b/Makefile index 31418c5..3233b9f 100644 --- a/Makefile +++ b/Makefile @@ -1,8 +1,13 @@ + # $Id: Makefile,v 1.5 2004/11/25 20:18:39 x99laine Exp $ ################################################################################ # definitions -VERSION := $(shell grep VERSION ChangeLog | head -1 | sed -e "s/VERSION //;s/\t.*//") +VERSNUM := $(shell grep VERSION ChangeLog | head -1 | sed -e "s/VERSION //;s/ .*//") +VERSTAG := $(shell grep VERSION ChangeLog | head -1 | grep 'XX' > /dev/null 2> /dev/null && echo 'beta') +BANANA := $(shell ( [ -d ../banana ] && echo `pwd`"/../banana" ) || echo "/home/web/dev/banana") + +VERSION = $(VERSNUM)$(VERSTAG) PKG_NAME = platal PKG_DIST = $(PKG_NAME)-$(VERSION) @@ -11,64 +16,173 @@ PKG_DIRS = configs htdocs include install.d plugins po scripts templates upgrade VCS_FILTER = ! -name .arch-ids ! -name CVS +define download +@echo "Downloading $@ from $(DOWNLOAD_SRC)" +wget $(DOWNLOAD_SRC) -O $@ -q || ($(RM) $@; exit 1) +endef + ################################################################################ # global targets all: build -headers: - headache -c install.d/platal-dev/templates/header.conf -h install.d/platal-dev/templates/header \ - `find templates -name '*.tpl' ! -path 'templates/xnet/skin.tpl' ! -path 'templates/skin/*.tpl' ! -name 'vcard.tpl' ` +build: core conf static banana wiki openid medals jquery + +q: + @echo -e "Code statistics\n" + @sloccount $(filter-out wiki/ spool/, $(wildcard */)) 2> /dev/null | egrep '^[a-z]*:' + +%: %.in Makefile ChangeLog + sed -e 's,@VERSION@,$(VERSION),g' $< > $@ -build: pkg-build +################################################################################ +# targets -dist: clean pkg-dist +## +## core +## -bzdist: clean pkg-bzdist +core: + [ -d core/.git ] || ( git submodule init && git submodule update ) + make -C core all -clean: - rm -rf include/platal/globals.inc.php - rm -f htdocs/banana/banana.css htdocs/valid.html include/banana htdocs/banana/img +## +## conf +## -%: %.in Makefile - sed -e 's,@VERSION@,$(VERSION),g' $< > $@ +conf: spool/templates_c spool/mails_c classes/platalglobals.php configs/platal.cron htdocs/.htaccess spool/conf spool/tmp -################################################################################ -# devel targets -templates_c: - mkdir templates_c - chmod o+w templates_c +spool/templates_c spool/mails_c spool/uploads spool/conf spool/tmp: + mkdir -p $@ + chmod o+w $@ + +htdocs/.htaccess: htdocs/.htaccess.in Makefile + @REWRITE_BASE="/~$$(id -un)"; \ + test "$$REWRITE_BASE" = "/~web" && REWRITE_BASE="/"; \ + sed -e "s,@REWRITE_BASE@,$$REWRITE_BASE,g" $< > $@ + +## +## static content +## +static: htdocs/javascript@VERSION + +%@VERSION: % Makefile ChangeLog + cd $< && rm -f $(VERSION) && ln -sf . $(VERSION) + +## +## wiki +## + +WIKI_NEEDS = \ + wiki/local/farmconfig.php \ + wiki/pub/skins/empty \ + wiki/cookbook/e-protect.php \ + spool/wiki.d \ + htdocs/uploads \ + htdocs/wiki \ + +wiki: get-wiki build-wiki + +build-wiki: $(WIKI_NEEDS) | get-wiki + +htdocs/uploads: + cd htdocs && ln -sf ../spool/uploads + +htdocs/wiki: + cd htdocs && ln -sf ../wiki/pub wiki + + +spool/wiki.d: + mkdir -p $@ + chmod o+w $@ + cd $@ && ln -sf ../../include/wiki/wiki.d/* . -htdocs/valid.html: - touch templates_c/valid.html - ln -sf ../templates_c/valid.html htdocs/valid.html -devel: build templates_c htdocs/valid.html +wiki/cookbook/e-protect.php: + cd wiki/cookbook && ln -sf ../../include/wiki/e-protect.php +wiki/local/farmconfig.php: + cd wiki/local/ && ln -sf ../../include/wiki/farmconfig.php + +wiki/pub/skins/empty: + cd wiki/pub/skins/ && ln -sf ../../../include/wiki/empty + + +get-wiki: + @if ! test -d wiki; then \ + wget http://www.pmwiki.org/pub/pmwiki/pmwiki-latest.tgz; \ + tar -xzvf pmwiki-latest.tgz; \ + rm pmwiki-latest.tgz; \ + mv pmwiki-* wiki; \ + fi + +## +## openid +## + +openid: get-openid spool/openid/store + +# There is no obvious way to automatically use the latest version +OPENID_VERSION = 2.1.3 +get-openid: + @if ! test -d include/Auth; then \ + wget http://openidenabled.com/files/php-openid/packages/php-openid-$(OPENID_VERSION).tar.bz2; \ + tar -xjf php-openid-$(OPENID_VERSION).tar.bz2; \ + mv php-openid-$(OPENID_VERSION)/Auth include/; \ + rm php-openid-$(OPENID_VERSION).tar.bz2; \ + rm -r php-openid-$(OPENID_VERSION); \ + fi + +spool/openid/store: + mkdir -p $@ + chmod o+w $@ + +## +## banana +## + +banana: htdocs/images/banana htdocs/css/banana.css include/banana/banana.inc.php +htdocs/images/banana: + cd $(@D) && ln -snf $(BANANA)/img $(@F) + +htdocs/css/banana.css: + cd $(@D) && ln -snf $(BANANA)/css/style.css $(@F) + +include/banana/banana.inc.php: + cd $(@D) && find $(BANANA)/banana/ -name '*.php' -exec ln -snf {} . ";" + +## +## Medal thumbnails +## +MEDAL_PICTURES=$(wildcard htdocs/images/medals/*.jpg) +MEDAL_THUMBNAILS=$(subst /medals/,/medals/thumb/,$(MEDAL_PICTURES)) + +medals: $(MEDAL_THUMBNAILS) + +$(MEDAL_THUMBNAILS): $(subst /medals/thumb/,/medals/,$(@F)) + convert -resize x50 $(subst /medals/thumb/,/medals/,$@) $@ + +## +## jquery +## + +JQUERY_PLUGINS=color +JQUERY_PLUGINS_PATHES=$(addprefix htdocs/javascript/jquery.,$(addsuffix .js,$(JQUERY_PLUGINS))) + +# TODO: jquery.autocomplete.js should rather be downloaded from an official source. The issue +# is that the version we use is not available anymore on the Internet, and the latest version +# we could use is not backward compatible with our current code. +jquery: htdocs/javascript/jquery.js $(JQUERY_PLUGINS_PATHES) + +htdocs/javascript/jquery.js: DOWNLOAD_SRC = http://jquery.com/src/jquery-latest.min.js +htdocs/javascript/jquery.js: + @$(download) + +$(JQUERY_PLUGINS_PATHES): DOWNLOAD_SRC = http://plugins.jquery.com/files/$(@F).txt +$(JQUERY_PLUGINS_PATHES): + @$(download) ################################################################################ -# diogenes package targets - -pkg-build: include/platal/globals.inc.php - -$(PKG_DIST): pkg-build - mkdir $(PKG_DIST) - cp -a $(PKG_FILES) $(PKG_DIST) - for dir in `find $(PKG_DIRS) -type d $(VCS_FILTER)`; \ - do \ - mkdir -p $(PKG_DIST)/$$dir; \ - find $$dir -type f -maxdepth 1 -exec cp {} $(PKG_DIST)/$$dir \; ; \ - done - -pkg-dist: $(PKG_DIST) - rm -f $(PKG_DIST).tar.gz - tar czf $(PKG_DIST).tar.gz $(PKG_DIST) - rm -rf $(PKG_DIST) - -pkg-bzdist: $(PKG_DIST) - rm -f $(PKG_DIST).tar.bz2 - tar cjf $(PKG_DIST).tar.bz2 $(PKG_DIST) - rm -rf $(PKG_DIST) - -.PHONY: build dist clean pkg-build pkg-dist + +.PHONY: build dist clean core wiki build-wiki banana htdocs/images/banana htdocs/css/banana.css include/banana/banana.inc.php http*