X-Git-Url: http://git.onelab.eu/?p=plcapi.git;a=blobdiff_plain;f=Makefile;h=3f61822cf6c9174099150cff0861499052014b18;hp=e6668f80f404dad88c9a2d513f963495153e38ae;hb=9aecb8c6fde06136bef94e2fd6fce832dc3c0c10;hpb=542250de03d111553d3aa6dcd27d5eb68b327264 diff --git a/Makefile b/Makefile index e6668f8..3f61822 100644 --- a/Makefile +++ b/Makefile @@ -4,18 +4,13 @@ # Mark Huang # Copyright (C) 2005 The Trustees of Princeton University # -# $Id$ -# - -# Metafiles - manage Legacy/ and Accessors by hand -init := PLC/__init__.py PLC/Methods/__init__.py # python-pycurl and python-psycopg2 avail. from fedora 5 # we used to ship our own version of psycopg2 and pycurl, for fedora4 # starting with 5.0, support for these two modules is taken out # Other stuff - doc not implicit, it's redone by myplc-docs -subdirs := php php/xmlrpc +subdirs := php/xmlrpc # autoconf compatible variables DESTDIR := / @@ -24,7 +19,7 @@ bindir := /usr/bin PWD := $(shell pwd) -all: $(init) $(subdirs) +all: $(subdirs) python setup.py build install: @@ -34,8 +29,6 @@ install: --install-data=$(DESTDIR)/$(datadir)/plc_api install -D -m 755 php/xmlrpc/xmlrpc.so $(DESTDIR)/$(shell php-config --extension-dir)/xmlrpc.so -$(subdirs): $(init) - $(subdirs): %: $(MAKE) -C $@ @@ -45,47 +38,18 @@ clean: for dir in $(SUBDIRS) ; do $(MAKE) -C $$dir clean ; done python setup.py clean && rm -rf build -index: $(init) - -index-clean: - rm $(init) - -#################### regenerate indexes - not used by the build, as both files are svn added - please update as appropriate - -########## PLC/ -# the current content of __init__.py -PLC_now := $(sort $(shell fgrep -v '"' PLC/__init__.py 2>/dev/null)) -# what should be declared -PLC_paths := $(filter-out %/__init__.py, $(wildcard PLC/*.py)) -PLC_files := $(sort $(notdir $(PLC_paths:.py=))) - -ifneq ($(PLC_now),$(PLC_files)) -PLC/__init__.py: force -endif -PLC/__init__.py: - (echo 'all = """' ; cd PLC; ls -1 *.py | grep -v __init__ | sed -e 's,.py$$,,' ; echo '""".split()') > $@ - -########## Methods/ -# the current content of __init__.py -METHODS_now := $(sort $(shell fgrep -v '"' PLC/Methods/__init__.py 2>/dev/null)) -# what should be declared -METHODS_paths := $(filter-out %/__init__.py, $(wildcard PLC/Methods/*.py PLC/Methods/system/*.py)) -METHODS_files := $(sort $(notdir $(subst system/, system., $(METHODS_paths:.py=)))) - -ifneq ($(METHODS_now),$(METHODS_files)) -PLC/Methods/__init__.py: force -endif -PLC/Methods/__init__.py: - (echo 'native_methods = """' ; cd PLC/Methods; ls -1 *.py system/*.py | grep -v __init__ | sed -e 's,.py$$,,' -e 's,system/,system.,' ; echo '""".split()') > $@ +index: + echo "This step is obsolete" ########## + force: .PHONY: all install force clean index tags $(subdirs) #################### devel tools tags: - find . '(' -name '*.py' -o -name '*.sql' -o -name '*.php' -o -name Makefile ')' | xargs etags + find . '(' -name '*.py' -o -name '*.sql' -o -name '*.php' -o -name Makefile -o -name '[0-9][0-9][0-9]*' ')' | fgrep -v '.git/' | xargs etags .PHONY: tags @@ -93,34 +57,37 @@ tags: # 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 +# (*) otherwise, for test deployments, use on your testmaster +# $ run export +# and cut'n paste the export lines before you run make sync -ifdef 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) +else +ifdef PLCHOSTLXC +SSHURL:=root@$(PLCHOSTLXC):/vservers/$(GUESTNAME) +SSHCOMMAND:=ssh root@$(PLCHOSTLXC) ssh -o StrictHostKeyChecking=no -o LogLevel=quiet $(GUESTHOSTNAME) +endif endif -LOCAL_RSYNC_EXCLUDES := --exclude '*.pyc' -RSYNC_EXCLUDES := --exclude .svn --exclude CVS --exclude '*~' --exclude TAGS $(LOCAL_RSYNC_EXCLUDES) +LOCAL_RSYNC_EXCLUDES := --exclude '*.pyc' --exclude Accessors_site.py +RSYNC_EXCLUDES := --exclude .svn --exclude .git --exclude '*~' --exclude TAGS $(LOCAL_RSYNC_EXCLUDES) RSYNC_COND_DRY_RUN := $(if $(findstring n,$(MAKEFLAGS)),--dry-run,) RSYNC := rsync -a -v $(RSYNC_COND_DRY_RUN) $(RSYNC_EXCLUDES) sync: 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" + @echo "sync: I need more info from the command line, e.g." + @echo " make sync PLC=boot.planetlab.eu" + @echo " make sync PLCHOSTLXC=.. GUESTNAME=.." @exit 1 else - +$(RSYNC) plcsh PLC planetlab5.sql migrations $(SSHURL)/usr/share/plc_api/ - $(SSHCOMMAND) exec apachectl graceful + +$(RSYNC) plcsh PLC planetlab5.sql migrations aspects $(SSHURL)/usr/share/plc_api/ + +$(RSYNC) db-config.d/ $(SSHURL)/etc/planetlab/db-config.d/ + +$(RSYNC) plc.d/ $(SSHURL)/etc/plc.d/ + $(SSHCOMMAND) /etc/plc.d/httpd stop + $(SSHCOMMAND) /etc/plc.d/httpd start endif #################### convenience, for debugging only