X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=Makefile;h=31ee234baea84cfee8e1d81175c257d023e97f33;hb=fea9b7e286cc86f11844e371d67d184198afc287;hp=dde9fac305543daeea208b7f661c1aaaeb74f791;hpb=620d87604e975f2b5f0451a6ece40bcd93e421a2;p=myslice.git diff --git a/Makefile b/Makefile index dde9fac3..31ee234b 100644 --- a/Makefile +++ b/Makefile @@ -1,38 +1,180 @@ -### -all: - @echo no default target +SHELL = /bin/bash + +MAKE-SILENT = $(MAKE) --no-print-directory + +all: static templates + +# clean up and recompute +redo: clean-oldies redo-static redo-templates + +clean-oldies: + rm -rf all-static all-templates django-static force: +DESTDIR := / +datadir := /usr/share +bindir := /usr/bin + +PWD := $(shell pwd) + +# +build: static templates force + python setup.py build + +install: + python setup.py install \ + --install-purelib=$(DESTDIR)/$(datadir)/unfold \ + --install-scripts=$(DESTDIR)/$(datadir)/unfold \ + --install-data=$(DESTDIR)/$(datadir)/unfold + +static: force + ./manage.py collectstatic --noinput + +clean-static: + rm -rf static/ + +redo-static: clean-static static + +#################### +# general stuff +DATE=$(shell date -u +"%a, %d %b %Y %T") + +# This is called from the build with the following variables set +# (see build/Makefile and target_debian) +# (.) RPMTARBALL +# (.) RPMVERSION +# (.) RPMRELEASE +# (.) RPMNAME +DEBVERSION=$(RPMVERSION).$(RPMRELEASE) +DEBTARBALL=../$(RPMNAME)_$(DEBVERSION).orig.tar.bz2 + +debian: static templates debian/changelog debian.source debian.package + +debian/changelog: debian/changelog.in + sed -e "s|@VERSION@|$(DEBVERSION)|" -e "s|@DATE@|$(DATE)|" debian/changelog.in > debian/changelog + +debian.source: force + rsync -a $(RPMTARBALL) $(DEBTARBALL) + +debian.package: + debuild -uc -us -b + +debian.clean: + $(MAKE) -f debian/rules clean + rm -rf build/ MANIFEST ../*.tar.gz ../*.dsc ../*.build + find . -name '*.pyc' -delete + + +### #################### third-party layout is kind of special +### # because we have differents versions, and also we +### # try to preserve the file structure from upstream +### # so let's handle this manually +### THIRD-PARTY-RESOURCES = +### # ignore variants, use the main symlink third-party/bootstrap +### THIRD-PARTY-RESOURCES += $(shell ls third-party/bootstrap/*/*) +### # just the single js as identified with a symlink +### THIRD-PARTY-RESOURCES += $(shell ls third-party/datatables/js/dataTables.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/datatables/js/dataTables.bootstrap.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/datatables/css/dataTables.bootstrap.css) +### # likewise +### THIRD-PARTY-RESOURCES += $(shell ls third-party/jquery/js/jquery.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/jquery/js/jquery.min.js) +### # for storing the visible status of plugins +### THIRD-PARTY-RESOURCES += $(shell ls third-party/jquery-html5storage/jquery.html5storage.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/jquery-html5storage/jquery.html5storage.min.js) +### # creating queries uuids on the fly +### THIRD-PARTY-RESOURCES += $(shell ls third-party/uuid/Math.uuid.js) +### # spin comes in plain or min, + the jquery plugin, and our own settings +### THIRD-PARTY-RESOURCES += $(shell ls third-party/spin/*.js) +### # used in QueryCode +### THIRD-PARTY-RESOURCES += $(shell ls third-party/syntaxhighlighter/scripts/shCore.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/syntaxhighlighter/scripts/shAutoloader.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/syntaxhighlighter/scripts/shBrushPython.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/syntaxhighlighter/scripts/shBrushRuby.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/syntaxhighlighter/styles/shCore.css) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/syntaxhighlighter/styles/shCoreDefault.css) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/syntaxhighlighter/styles/shThemeDefault.css) +### # wizard plugin +### THIRD-PARTY-RESOURCES += $(shell ls third-party/smartwizard-1636c86/js/jquery.smartWizard-2.0.js) +### #THIRD-PARTY-RESOURCES += $(shell ls third-party/smartwizard-1636c86/js/jquery.smartWizard-2.0.min.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/smartwizard-1636c86/styles/smart_wizard.css) +### # jquery.notify +### THIRD-PARTY-RESOURCES += $(shell ls third-party/jquery-notify/jquery.notify.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/jquery-notify/jquery.notify.min.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/jquery-notify/ui.notify.css) +### # CodeMirror +### THIRD-PARTY-RESOURCES += $(shell ls third-party/codemirror-3.15/lib/codemirror.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/codemirror-3.15/lib/codemirror.css) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/codemirror-3.15/mode/sql/sql.js) +### # Mustache.js +### THIRD-PARTY-RESOURCES += $(shell ls third-party/mustache/mustache.js) +### # markerclustererplus for the googlemap plugin +### THIRD-PARTY-RESOURCES += $(shell ls third-party/markerclusterer/markerclusterer.js) +### THIRD-PARTY-RESOURCES += $(shell ls third-party/markerclusterer/markerclusterer_packed.js) +### +### thirdparty-js: +### @find $(THIRD-PARTY-RESOURCES) -name '*.js' +### thirdparty-css: +### @find $(THIRD-PARTY-RESOURCES) -name '*.css' +### thirdparty-img: +### @find $(THIRD-PARTY-RESOURCES) -name '*.png' -o -name '*.ico' +### +### # we might have any of these as templates - e.g. ./unfold/templates/plugin-init.js +### # so if there's a /templates/ in the path ignore the file +### local-js: force +### @find . -type f -name '*.js' | egrep -v '/all-(static|templates)/|/third-party/|/templates/' +### local-css: force +### @find . -type f -name '*.css' | egrep -v 'all-(static|templates)/|/third-party/|/templates/' +### local-img: force +### @find . -type f -name '*.png' -o -name '*.ico' | egrep -v 'all-(static|templates)/|/third-party/|/templates/' +### +### list-js: thirdparty-js local-js +### list-css: thirdparty-css local-css +### list-img: thirdparty-img local-img + +# having templates in a templates/ subdir is fine most of the time except for plugins +plugins-templates: force + @find plugins -type f -name '*.html' +local-templates: force + @$(foreach tmpl,$(shell find . -name templates | grep -v '^\./templates$$'),ls -1 $(tmpl)/*;) + +list-templates: plugins-templates local-templates + +#################### manage templates for the plugin area +templates: force + mkdir -p templates + ln -sf $(foreach x,$(shell $(MAKE-SILENT) list-templates),../$(x)) ./templates + +clean-templates templates-clean: force + rm -rf ./templates + +redo-templates: clean-templates templates + +#################### +### list-all list-resources: list-templates list-js list-css list-img + #################### 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/|/bootstrap/|/jquery/|datatables/' + @git ls-files | egrep -v 'insert(_|-)above|third-party/|play/' # in general it's right to rely on the contents as reported by git tags: force - $(MAKE) myfiles | xargs etags + $(MAKE-SILENT) 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 -#################### 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 -LOCAL_RSYNC_EXCLUDES := --exclude '*.pyc' --exclude settings.py --exclude devel --exclude DataTables-1.9.4 +# the config file should probably not be overridden ?? +# --exclude settings.py +LOCAL_RSYNC_EXCLUDES := --exclude '*.pyc' --exclude config.py --exclude static --exclude templates --exclude '*.sqlite3' --exclude play/ # usual excludes RSYNC_EXCLUDES := --exclude .git --exclude '*~' --exclude TAGS --exclude .DS_Store $(LOCAL_RSYNC_EXCLUDES) # make -n will propagate as rsync -n @@ -40,7 +182,9 @@ RSYNC_COND_DRY_RUN := $(if $(findstring n,$(MAKEFLAGS)),--dry-run,) # putting it together RSYNC := rsync -a -v $(RSYNC_COND_DRY_RUN) $(RSYNC_EXCLUDES) +##### convenience for development only, push code on a specific test box # xxx until we come up with a packaging this is going to be a wild guess +# on debian04 I have stuff in /usr/share/myslice and a symlink in /root/myslice #INSTALLED=/usr/share/myslice INSTALLED=/root/myslice