X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=Makefile;h=a29b5b3a44980d20fe6280c4346c9b2d8e521e68;hb=26264b80b63ea1475a3b6bf5f1f87861fdbcac11;hp=d4fd1302511718e7e59a4a026ed18d71d938fe78;hpb=942f0c826530444332e45de0367b560e0af22b33;p=unfold.git diff --git a/Makefile b/Makefile index d4fd1302..a29b5b3a 100644 --- a/Makefile +++ b/Makefile @@ -1,2 +1,76 @@ -tags: - git ls-files | xargs etags +### +all: + @echo no default target + +force: + +#################### compute emacs tags +# list files under git but exclude third-party stuff like bootstrap and jquery +myfiles: force + @git ls-files | egrep -v 'insert(_|-)above|static/bootstrap|/jquery/|datatables/' + +# in general it's right to rely on the contents as reported by git +tags: force + $(MAKE) myfiles | xargs etags + +# however sometimes we have stuff not yet added, so in this case +ftags: force + find . -type f | fgrep -v '/.git/' | xargs etags + +list-html: force + @find . -type f -name '*.html' +list-js: force + @find . -type f -name '*.js' | grep -v '/all-static/' +list-css: force + @find . -type f -name '*.css' | grep -v '/all-static/' +list-img: force + @find . -type f -name '*.png' | grep -v '/all-static/' + +list-all list-resources: list-html list-js list-css list-img + +#################### manage static contents (extract from all the modules into the single all-static location) +static: force + ./manage.py collectstatic --noinput + +clean-static: force + rm -rf ./all-static/ + +allst: clean-static static + +#################### sync : push current code on a (devel) box running myslice +SSHURL:=root@$(MYSLICEBOX):/ +SSHCOMMAND:=ssh root@$(MYSLICEBOX) + +### rsync options +# the config file should probably not be overridden ?? +# --exclude settings.py +LOCAL_RSYNC_EXCLUDES := --exclude '*.pyc' --exclude devel --exclude DataTables-1.9.4 --exclude all-static --exclude '*.sqlite3' +# usual excludes +RSYNC_EXCLUDES := --exclude .git --exclude '*~' --exclude TAGS --exclude .DS_Store $(LOCAL_RSYNC_EXCLUDES) +# make -n will propagate as rsync -n +RSYNC_COND_DRY_RUN := $(if $(findstring n,$(MAKEFLAGS)),--dry-run,) +# putting it together +RSYNC := rsync -a -v $(RSYNC_COND_DRY_RUN) $(RSYNC_EXCLUDES) + +# xxx until we come up with a packaging this is going to be a wild guess +#INSTALLED=/usr/share/myslice +INSTALLED=/root/myslice + +sync: +ifeq (,$(MYSLICEBOX)) + @echo "you need to set MYSLICEBOX, like in e.g." + @echo " $(MAKE) MYSLICEBOX=debian04.pl.sophia.inria.fr "$@"" + @exit 1 +else + +$(RSYNC) ./ $(SSHURL)/$(INSTALLED)/ +endif + +# xxx likewise until we run this under apache it's probably hard to restart from here +restart: +ifeq (,$(MYSLICEBOX)) + @echo "you need to set MYSLICEBOX, like in e.g." + @echo " $(MAKE) MYSLICEBOX=debian04.pl.sophia.inria.fr "$@"" + @exit 1 +else + @echo "$@" target not yet implemented - for an apache based depl it would read ...; exit; @$(SSHCOMMAND) /etc/init.d/apache2 restart +endif