X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=Makefile;h=3233b9fd24d1c250b93b83a1b86f21c50a87e2b3;hb=e97df22eacc433a9982aad507f980b303d5fa2c1;hp=e0480fa73f8b23d0994e6bff82157dbf32c028d6;hpb=a7c29df3b9bf8f3c3b23fec0f1d2feb814cb61fe;p=platal.git diff --git a/Makefile b/Makefile index e0480fa..3233b9f 100644 --- a/Makefile +++ b/Makefile @@ -16,12 +16,17 @@ 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 -build: core banana wiki jquery +build: core conf static banana wiki openid medals jquery q: @echo -e "Code statistics\n" @@ -37,22 +42,34 @@ q: ## core ## -core: spool/templates_c spool/mails_c include/globals.inc.php configs/platal.cron htdocs/.htaccess spool/conf +core: + [ -d core/.git ] || ( git submodule init && git submodule update ) + make -C core all + +## +## conf +## + +conf: spool/templates_c spool/mails_c classes/platalglobals.php configs/platal.cron htdocs/.htaccess spool/conf spool/tmp -spool/templates_c spool/mails_c spool/uploads spool/conf spool/uploads/temp: +spool/templates_c spool/mails_c spool/uploads spool/conf spool/tmp: mkdir -p $@ chmod o+w $@ -spool/uploads/temp/.htaccess: spool/uploads/temp Makefile - echo "Order deny,allow" > $@ - echo "Deny from all" >> $@ - 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 ## @@ -68,7 +85,7 @@ wiki: get-wiki build-wiki build-wiki: $(WIKI_NEEDS) | get-wiki -htdocs/uploads: spool/uploads/temp/.htaccess +htdocs/uploads: cd htdocs && ln -sf ../spool/uploads htdocs/wiki: @@ -94,36 +111,78 @@ wiki/pub/skins/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; \ + 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 -sf $(BANANA)/img $(@F) + cd $(@D) && ln -snf $(BANANA)/img $(@F) htdocs/css/banana.css: - cd $(@D) && ln -sf $(BANANA)/css/style.css $(@F) + cd $(@D) && ln -snf $(BANANA)/css/style.css $(@F) include/banana/banana.inc.php: - cd $(@D) && find $(BANANA)/banana/ -name '*.php' -exec ln -sf {} . ";" + 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: htdocs/javascript/jquery.js htdocs/javascript/jquery.autocomplete.js +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: - wget http://jquery.com/src/jquery-latest.pack.js -O $@ -q || ($(RM) $@; exit 1) + @$(download) + +$(JQUERY_PLUGINS_PATHES): DOWNLOAD_SRC = http://plugins.jquery.com/files/$(@F).txt +$(JQUERY_PLUGINS_PATHES): + @$(download) ################################################################################ -.PHONY: build dist clean wiki build-wiki banana +.PHONY: build dist clean core wiki build-wiki banana htdocs/images/banana htdocs/css/banana.css include/banana/banana.inc.php http*