X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=Makefile;h=309e17adea4c3e07e57547d3fc68221c06d07ab0;hb=862fcd16ade791995e38a63f29ce36bfef02613c;hp=3a1b9a2fe9e77b7dd363c003e3418b8aed5384cd;hpb=b42be39ff01f53ace4b72726c27842a22739f6a3;p=myplc.git diff --git a/Makefile b/Makefile index 3a1b9a2..309e17a 100644 --- a/Makefile +++ b/Makefile @@ -1,18 +1,25 @@ -# -# $Id$ -# +########## +tags: + find . -type f | egrep -v '.svn/|~$$' | xargs etags + +.PHONY: tags -BINARIES = plc-config plc-config-tty db-config dns-config plc-map.py plc-kml.py clean-empty-dirs.py mtail.py \ - support-scripts/renew_reminder.py support-scripts/gen_aliases.py -INIT_SCRIPTS = api bootcd bootmanager crond db dns functions gpg httpd mail network packages postgresql ssh ssl syslog +########## sync +# 2 forms are supported +# (*) if your plc root context has direct ssh access: +# make sync PLC=boot.planet-lab.eu +# (*) otherwise, entering through the root context +# make sync PLCHOST=testplc.onelab.eu GUEST=vplc03.inria.fr -INITS=$(addprefix plc.d/,$(INIT_SCRIPTS)) +PLCHOST ?= testplc.onelab.eu -########## make sync PLCHOST=hostname -ifdef PLCHOST ifdef GUEST -PLCSSH:=root@$(PLCHOST):/vservers/$(GUEST) +SSHURL:=root@$(PLCHOST):/vservers/$(GUEST) +SSHCOMMAND:=ssh root@$(PLCHOST) vserver $(GUEST) endif +ifdef PLC +SSHURL:=root@$(PLC):/ +SSHCOMMAND:=ssh root@$(PLC) endif LOCAL_RSYNC_EXCLUDES := --exclude '*.pyc' @@ -21,21 +28,28 @@ RSYNC_COND_DRY_RUN := $(if $(findstring n,$(MAKEFLAGS)),--dry-run,) RSYNC := rsync -a -v $(RSYNC_COND_DRY_RUN) $(RSYNC_EXCLUDES) sync: -ifeq (,$(PLCSSH)) - echo "sync: You must define PLCHOST and GUEST on the command line" - echo " e.g. make sync PLCHOST=private.one-lab.org GUEST=myplc01" ; exit 1 +ifeq (,$(SSHURL)) + @echo "sync: You must define, either PLC, or PLCHOST & GUEST, on the command line" + @echo " e.g. make sync PLC=boot.planet-lab.eu" + @echo " or make sync PLCHOST=testplc.onelab.eu GUEST=vplc03.inria.fr" + @exit 1 else - +$(RSYNC) plc.init $(PLCSSH)/etc/init.d/plc - +$(RSYNC) $(BINARIES) $(PLCSSH)/usr/bin - +$(RSYNC) $(INITS) $(PLCSSH)/etc/plc.d - +$(RSYNC) plc_config.py $(PLCSSH)/usr/lib/python2.4/site-packages/plc_config.py - +$(RSYNC) default_config.xml $(PLCSSH)/etc/planetlab/default_config.xml - @echo XXXXXXXX You might consider running the following command - @echo ssh $(PLCHOST) service plc start + +$(RSYNC) plc.init $(SSHURL)/etc/init.d/plc + +$(RSYNC) bin/ $(SSHURL)/usr/bin/ + +$(RSYNC) plc.d/ $(SSHURL)/etc/plc.d/ + +$(RSYNC) db-config.d/ $(SSHURL)/etc/planetlab/db-config.d/ + +$(RSYNC) plc_config.py $(SSHURL)/usr/lib/python2.\*/site-packages/plc_config.py + +$(RSYNC) default_config.xml $(SSHURL)/etc/planetlab/default_config.xml + @echo XXXXXXXX you might need to run ssh root@$(PLC) service plc start endif +#################### convenience, for debugging only +# make +foo : prints the value of $(foo) +# make ++foo : idem but verbose, i.e. foo=$(foo) +++%: varname=$(subst +,,$@) +++%: + @echo "$(varname)=$($(varname))" ++%: varname=$(subst +,,$@) ++%: + @echo "$($(varname))" -tags: - find . -type f | egrep -v '.svn/|~$$' | xargs etags - -.PHONY: tags