-### first purpose, build and install from the specfile
-all: build
+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:
PWD := $(shell pwd)
-build: static templates
+#
+build: static templates force
python setup.py build
install:
python setup.py install \
- --install-purelib=$(DESTDIR)/$(datadir)/myslice \
- --install-scripts=$(DESTDIR)/$(datadir)/myslice \
- --install-data=$(DESTDIR)/$(datadir)/myslice
+ --install-purelib=$(DESTDIR)/$(datadir)/unfold \
+ --install-scripts=$(DESTDIR)/$(datadir)/unfold \
+ --install-data=$(DESTDIR)/$(datadir)/unfold
+#################### third-party layout is managed as part of collectstatic
+static: force
+ ./manage.py collectstatic --noinput
-#################### 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|/third-party/|/play/'
+clean-static:
+ rm -rf static/
-# in general it's right to rely on the contents as reported by git
-tags: force
- $(MAKE) myfiles | xargs etags
+redo-static: clean-static static
-# however sometimes we have stuff not yet added, so in this case
-ftags: force
- find . -type f | fgrep -v '/.git/' | xargs etags
+####################
+# 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 --set-envvar PREFIX=/usr -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 all
-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)
-# likewise
-THIRD-PARTY-RESOURCES += $(shell ls third-party/jquery/js/jquery.js)
-# spin comes in plain or min, + the jquery plugin, and our own settings
-THIRD-PARTY-RESOURCES += $(shell ls third-party/spin/*.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'
-
-# we might have any of these as templates - e.g. ./engine/templates/plugin-setenv.js
-# so if there's a /templates/ in the path ignore the file
-other-js: force
- @find . -type f -name '*.js' | egrep -v '/all-(static|templates)/|/third-party/|/templates/'
-other-css: force
- @find . -type f -name '*.css' | egrep -v 'all-(static|templates)/|/third-party/|/templates/'
-other-img: force
- @find . -type f -name '*.png' | egrep -v 'all-(static|templates)/|/third-party/|/templates/'
-
-list-js: thirdparty-js other-js
-list-css: thirdparty-css other-css
-list-img: thirdparty-img other-img
# having templates in a templates/ subdir is fine most of the time except for plugins
-list-templates: force
+plugins-templates: force
@find plugins -type f -name '*.html'
+local-templates: force
+ @$(foreach tmpl,$(shell find . -name templates | grep -v '^\./templates$$'),find $(tmpl) -maxdepth 2 -type f -name *.html;)
+local-templates2: force
+ @$(foreach tmpl,$(shell find . -name templates | grep -v '^\./templates$$'),ls -1 $(tmpl)/*;)
-#################### manage static contents (extract from all the modules into the single all-static location)
-static run-static static-run: force
- mkdir -p ./all-static/js all-static/css all-static/img
- ln -sf $(foreach x,$(shell $(MAKE) list-js),../../$(x)) ./all-static/js
- ln -sf $(foreach x,$(shell $(MAKE) list-css),../../$(x)) ./all-static/css
- ln -sf $(foreach x,$(shell $(MAKE) list-img),../../$(x)) ./all-static/img
-# rsync -av $(shell $(MAKE) list-js) ./all-static/js
-# rsync -av $(shell $(MAKE) list-css) ./all-static/css
-# rsync -av $(shell $(MAKE) list-img) ./all-static/img
-
-clean-static static-clean: force
- rm -rf ./all-static
-all-static: clean-static run-static
+list-templates: plugins-templates local-templates
#################### manage templates for the plugin area
-templates run-templates templates-run: force
- mkdir -p all-templates
- ln -sf $(foreach x,$(shell $(MAKE) list-templates),../$(x)) ./all-templates
-# rsync -av $(shell $(MAKE) list-templates) ./all-templates
+templates: force
+ @mkdir -p templates
+ ln -sf $(foreach x,$(shell $(MAKE-SILENT) list-templates),../$(x)) ./templates
clean-templates templates-clean: force
- rm -rf ./all-templates
+ rm -rf ./templates
-all-templates: clean-templates run-templates
+redo-templates: clean-templates templates
####################
-list-all list-resources: list-templates list-js list-css list-img
+### list-all list-resources: list-templates list-js list-css list-img
-#################### sync : push current code on a (devel) box running myslice
+#################### 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|third-party/|to-be-integrated/'
+
+# in general it's right to rely on the contents as reported by git
+tags: force
+ $(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
+
+########################################
+### devel-oriented
+########################################
+
+#################### sync : push current code on a box running myslice
+# this for now targets deployments based on the debian packaging
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 config.py --exclude all-static --exclude all-templates --exclude '*.sqlite3'
+LOCAL_RSYNC_EXCLUDES := --exclude '*.pyc'
+LOCAL_RSYNC_EXCLUDES += --exclude '*.sqlite3' --exclude myslice.ini
+LOCAL_RSYNC_EXCLUDES += --exclude static --exclude templates --exclude build
+LOCAL_RSYNC_EXCLUDES += --exclude to-be-integrated --exclude third-party
# usual excludes
RSYNC_EXCLUDES := --exclude .git --exclude '*~' --exclude TAGS --exclude .DS_Store $(LOCAL_RSYNC_EXCLUDES)
# make -n will propagate as rsync -n
# putting it together
RSYNC := rsync -a -v $(RSYNC_COND_DRY_RUN) $(RSYNC_EXCLUDES)
+#################### minimal convenience for pushing work-in-progress in an apache-based depl.
# 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
+INSTALLED_MAIN =/usr/share/pyshared
+# this is for a debian box
+INSTALLED_APACHE =/etc/apache2/sites-available/
+
+sync: sync-main sync-apache
+
+sync-main:
+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_MAIN)/
+endif
-sync:
+sync-apache:
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)/
+ +$(RSYNC) ./apache/unfold.conf $(SSHURL)/$(INSTALLED_APACHE)/
+ +$(RSYNC) ./apache/unfold-init-ssl.sh $(SSHURL)/$(bindir)/
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
+ +$(SSHCOMMAND) apachectl restart
endif