X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=Makefile;h=23c1be31d5762f5c578e479061ee7955595cb0c7;hb=df86e084563ff7d7483ccde93b87e21aa71729cc;hp=ca37ab65d1f80e01581d146816c5bafd034bd266;hpb=4db0fb4c8e067200712eb377e42013c6fc2c628b;p=sfa.git diff --git a/Makefile b/Makefile index ca37ab65..23c1be31 100644 --- a/Makefile +++ b/Makefile @@ -1,15 +1,15 @@ # -## (Re)builds Python metafile (__init__.py) -# +## (Re)builds Python metafile (__init__.py) +# # overwritten by the specfile DESTDIR="/" PREFIX=/usr ########## -all: python wsdl +all: python wsdl install: python-install wsdl-install tests-install -clean: python-clean wsdl-clean +clean: python-clean wsdl-clean uninstall: python-uninstall tests-uninstall @@ -22,14 +22,10 @@ rpmtaglevel:=$(shell rpm -q --specfile sfa.spec --queryformat="%{release}\n" 2> VERSIONTAG=$(rpmversion)-$(rpmtaglevel) # this used to be 'should-be-redefined-by-specfile' and it indeed should be SCMURL=git://git.onelab.eu/sfa.git -TARBALL_HOST=root@build.onelab.eu -TARBALL_TOPDIR=/build/sfa -# I have an alternate pypitest entry defined in my .pypirc -PYPI_TARGET=pypi python: version -version: sfa/util/version.py +version: sfa/util/version.py sfa/util/version.py: sfa/util/version.py.in force sed -e "s,@VERSIONTAG@,$(VERSIONTAG),g" -e "s,@SCMURL@,$(SCMURL),g" sfa/util/version.py.in > $@ @@ -48,14 +44,14 @@ python-clean: version-clean version-clean: rm -f sfa/util/version.py -.PHONY: python version python-install python-clean version-clean +.PHONY: python version python-install python-clean version-clean ########## -wsdl: - $(MAKE) -C wsdl +wsdl: + $(MAKE) -C wsdl # propagate DESTDIR from the specfile wsdl-install: - $(MAKE) -C wsdl install + $(MAKE) -C wsdl install wsdl-clean: $(MAKE) -C wsdl clean @@ -63,7 +59,7 @@ wsdl-clean: .PHONY: wsdl wsdl-install wsdl-clean ######################################## debian packaging -# The 'debian' target is called from the build with the following variables set +# The 'debian' target is called from the build with the following variables set # (see build/Makefile and target_debian) # (.) RPMTARBALL # (.) RPMVERSION @@ -81,11 +77,11 @@ debian: 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 +debian.source: force rsync -a $(RPMTARBALL) $(DEBTARBALL) debian.package: - debuild -uc -us -b + debuild -uc -us -b debian.clean: $(MAKE) -f debian/rules clean @@ -104,7 +100,7 @@ tests-uninstall: ########## refreshing methods package metafile # Metafiles - manage Legacy/ and Accessors by hand -init := sfa/methods/__init__.py +init := sfa/methods/__init__.py index: $(init) @@ -119,7 +115,7 @@ methods_files := $(sort $(notdir $(methods_paths:.py=))) ifneq ($(methods_now),$(methods_files)) sfa/methods/__init__.py: force endif -sfa/methods/__init__.py: +sfa/methods/__init__.py: (echo '## Please use make index to update this file' ; echo 'all = """' ; cd sfa/methods; ls -1 *.py | grep -v __init__ | sed -e 's,.py$$,,' ; echo '""".split()') > $@ force: @@ -127,12 +123,12 @@ force: ########## # a lot of stuff in the working dir is just noise files: - @find . -type f | egrep -v '^\./\.|/\.git/|/\.svn/|TAGS|AA-|~$$|egg-info|\.(py[co]|doc|html|pdf|png|svg|out|bak|dg|pickle)$$' + @find . -type f | egrep -v '^\./\.|/\.git/|/\.svn/|TAGS|AA-|~$$|egg-info|\.(py[co]|doc|html|pdf|png|svg|out|bak|dg|pickle)$$' git-files: - @git ls-files | grep -v '\.doc$$' + @git ls-files | egrep -v '\.(doc|html|pdf)$$' -tags: +tags: $(MAKE) git-files | xargs etags .PHONY: files tags @@ -142,13 +138,18 @@ signatures: .PHONY: signatures ########## for uploading onto pypi +# use pypitest instead for tests (both entries need to be defined in your .pypirc) +PYPI_TARGET=pypi +PYPI_TARBALL_HOST=root@build.onelab.eu +PYPI_TARBALL_TOPDIR=/build/sfa + # a quick attempt on pypitest did not quite work as expected # I was hoping to register the project using "setup.py register" # but somehow most of my meta data did not make it up there # and I could not find out why # so I went for the manual method instead # there also was a web dialog prompting for a zip file that would -# be used to initialize the project's home dir but this too +# be used to initialize the project's home dir but this too # did not seem to work the way I was trying to use it, so ... # this target is still helpful to produce the readme in html from README.md @@ -160,15 +161,15 @@ index.zip index.html: README.md # we need to re-run make so the version is right git_pypi: git pypi -git: +git: git pull $(MAKE) version # run this only once the sources are in on the right tag pypi: index.html setup.py sdist upload -r $(PYPI_TARGET) - ssh $(TARBALL_HOST) mkdir -p $(TARBALL_TOPDIR)/$(VERSIONTAG) - rsync -av dist/sfa-$(VERSIONTAG).tar.gz $(TARBALL_HOST):$(TARBALL_TOPDIR)/$(VERSIONTAG) + ssh $(PYPI_TARBALL_HOST) mkdir -p $(PYPI_TARBALL_TOPDIR)/$(VERSIONTAG) + rsync -av dist/sfa-$(VERSIONTAG).tar.gz $(PYPI_TARBALL_HOST):$(PYPI_TARBALL_TOPDIR)/$(VERSIONTAG) # cleanup clean: readme-clean @@ -190,7 +191,7 @@ SSHCOMMAND:=ssh root@$(PLC) else ifdef PLCHOSTLXC SSHURL:=root@$(PLCHOSTLXC):/vservers/$(GUESTNAME) -SSHCOMMAND:=ssh root@$(PLCHOSTLXC) virsh -c lxc:/// lxc-enter-namespace $(GUESTNAME) -- /usr/bin/env +SSHCOMMAND:=ssh root@$(PLCHOSTLXC) ssh -o StrictHostKeyChecking=no $(GUESTHOSTNAME) else ifdef PLCHOSTVS SSHURL:=root@$(PLCHOSTVS):/vservers/$(GUESTNAME) @@ -199,7 +200,7 @@ endif endif endif -synccheck: +synccheck: ifeq (,$(SSHURL)) @echo "sync: I need more info from the command line, e.g." @echo " make sync PLC=boot.planetlab.eu" @@ -208,7 +209,7 @@ ifeq (,$(SSHURL)) @exit 1 endif -LOCAL_RSYNC_EXCLUDES += --exclude '*.pyc' +LOCAL_RSYNC_EXCLUDES += --exclude '*.pyc' LOCAL_RSYNC_EXCLUDES += --exclude '*.png' --exclude '*.svg' --exclude '*.out' RSYNC_EXCLUDES := --exclude .svn --exclude .git --exclude '*~' --exclude TAGS $(LOCAL_RSYNC_EXCLUDES) RSYNC_COND_DRY_RUN := $(if $(findstring n,$(MAKEFLAGS)),--dry-run,) @@ -223,8 +224,12 @@ BINS = ./config/sfa-config-tty ./config/gen-sfa-cm-config.py \ synclib: synccheck +$(RSYNC) --relative ./sfa/ --exclude migrations $(SSHURL)/usr/lib\*/python2.\*/site-packages/ +synclib3: synccheck + +$(RSYNC) --relative ./sfa/ --exclude migrations $(SSHURL)/usr/lib\*/python3.\*/site-packages/ synclibdeb: synccheck +$(RSYNC) --relative ./sfa/ --exclude migrations $(SSHURL)/usr/share/pyshared/ +syncmigrations: + +$(RSYNC) ./sfa/storage/migrations/versions/*.py $(SSHURL)/usr/share/sfa/migrations/versions/ syncbin: synccheck +$(RSYNC) $(BINS) $(SSHURL)/usr/bin/ syncinit: synccheck @@ -255,9 +260,9 @@ sfa/examples/miniclient.py \ sfa/__init__.py \ sfa/client/{sfaserverproxy,sfaclientlib,__init__}.py \ sfa/trust/{certificate,__init__}.py \ -sfa/util/{sfalogging,faults,genicode,enumeration,__init__}.py +sfa/util/{sfalogging,faults,genicode,enumeration,__init__}.py -clientlibsync: +clientlibsync: @[ -d "$(CLIENTLIBTARGET)" ] || { echo "You need to set the make variable CLIENTLIBTARGET"; exit 1; } rsync -av --relative $(CLIENTLIBFILES) $(CLIENTLIBTARGET)