X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=Makefile;h=0c33c67a484e76c6f30f180149f4c25311bd6ac5;hb=refs%2Fheads%2F4.3;hp=752e7470faccb7f8517eb9809d02602093d01bc2;hpb=adaf52ecdc1fc8f7d4c97a670c8bb34a77075db5;p=myplc.git diff --git a/Makefile b/Makefile index 752e747..0c33c67 100644 --- a/Makefile +++ b/Makefile @@ -2,17 +2,36 @@ # $Id$ # -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 +BINARIES = plc-config plc-config-tty db-config dns-config \ + clean-empty-dirs.py mtail.py \ + plc-check-ssl-peering.py plc-map.py plc-kml.py plc-orphan-accounts.py \ + support-scripts/renew_reminder.py support-scripts/gen_aliases.py +INIT_SCRIPTS = api bootcd bootmanager db dns functions gpg httpd mail network packages postgresql ssh ssl INITS=$(addprefix plc.d/,$(INIT_SCRIPTS)) -########## make sync PLCHOST=hostname -ifdef PLCHOST +########## +tags: + find . -type f | egrep -v '.svn/|~$$' | xargs etags + +.PHONY: tags + +########## sync +# 2 forms are supported +# (*) if your plc root context has direct ssh access: +# make sync PLC=private.one-lab.org +# (*) otherwise, entering through the root context +# make sync PLCHOST=testbox1.inria.fr GUEST=vplc03.inria.fr + ifdef GUEST -PLCSSH:=root@$(PLCHOST):/vservers/$(GUEST) +ifdef PLCHOST +SSHURL:=root@$(PLCHOST):/vservers/$(GUEST) +SSHCOMMAND:=ssh root@$(PLCHOST) vserver $(GUEST) +endif endif +ifdef PLC +SSHURL:=root@$(PLC):/ +SSHCOMMAND:=ssh root@$(PLC) endif LOCAL_RSYNC_EXCLUDES := --exclude '*.pyc' @@ -21,21 +40,27 @@ 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=private.one-lab.org" + @echo " or make sync PLCHOST=testbox1.inria.fr GUEST=vplc03.inria.fr" + @exit 1 else - +$(RSYNC) guest.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) $(BINARIES) $(SSHURL)/usr/bin + +$(RSYNC) $(INITS) $(SSHURL)/etc/plc.d + +$(RSYNC) plc_config.py $(SSHURL)/usr/lib/python2.5/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