summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xbuild/bin/tagrelease.py140
1 files changed, 140 insertions, 0 deletions
diff --git a/build/bin/tagrelease.py b/build/bin/tagrelease.py
new file mode 100755
index 0000000000..ae8c7a9a65
--- /dev/null
+++ b/build/bin/tagrelease.py
@@ -0,0 +1,140 @@
+#!/usr/bin/python
+
+import os,sys,re
+
+###############################################################################
+# Read maps
+###############################################################################
+def readMap(fin, separator):
+ lines = map(lambda x: x.strip(), fin.readlines())
+
+ values = {}
+ for line in lines:
+ if line == "":
+ continue
+
+ m = re.match(separator, line)
+ if not m:
+ print "Line '%s' not parseable." % line
+ sys.exit(1)
+ values[m.group(1)] = m.group(2)
+
+ return values
+
+def getSvnInfo():
+ pin = os.popen("svn info", "r")
+ values = readMap(pin, r'^([^:]+):\s*(.+)$')
+ pin.close()
+ return values
+
+def readProperties(filename):
+ fin = open(filename, "r")
+ values = readMap(fin, r'^([^=]+)\s*=\s*(.+)$')
+ fin.close()
+ return values
+
+###############################################################################
+# Help
+###############################################################################
+def helpAndExit():
+ print "Usage: build/bin/tagrelease <command> [parameters...]"
+ print "Commands:"
+ print "\ttag <version> <changeset>"
+ sys.exit(1)
+
+###############################################################################
+# Checks if a tag exists
+###############################################################################
+def isTagged(trgUrl):
+ return not os.system("svn list --depth empty %s 2> /dev/null" % trgUrl)
+
+###############################################################################
+# Tag
+###############################################################################
+def checkNotTagged(tagUrl):
+ if isTagged(tagUrl):
+ print "The tag '%s' already exists." % tagUrl
+ sys.exit(1)
+
+def tag(product, srcUrl, trgUrl, version, changeset, dryrun = 1):
+ # Check that the tag doesn't already exist
+ checkNotTagged(trgUrl)
+
+ tagComment = "Tagged %s %s release." % (product, version)
+ tagCmd = "svn copy -m \"%s\" %s %s" % (tagComment, srcUrl+"@"+changeset, trgUrl)
+ print tagCmd
+
+ # TODO enable
+ # error = os.system(tagCmd)
+ error = 0
+ if error:
+ print "Tagging failed."
+ sys.exit(1)
+
+###############################################################################
+# Tag command
+###############################################################################
+def tagCommand(version, changeset):
+ # Check parameters
+ m = re.match(r'^[0-9]+\.[0-9]+\.[0-9]+(\.\w+)?$', version)
+ if not m:
+ print "Invalid version number '%s'" % version
+ sys.exit(1)
+ m = re.match(r'^[0-9]+$', changeset)
+ if not m:
+ print "Invalid changeset number '%s'" % changeset
+ sys.exit(1)
+
+ # Repository parameters
+ svnInfo = getSvnInfo()
+ url = svnInfo["URL"]
+ repoRoot = svnInfo["Repository Root"]
+ tagUrl = repoRoot+"/releases/"+version
+
+ # Book tag parameters
+ versionProperties = readProperties("build/VERSION.properties")
+ bookRepo = versionProperties["manual.repository"]
+ if not re.search(r'branches/[0-9\.]+$', bookRepo):
+ print "Bad documentation branch '%s' for release." % (bookRepo)
+ sys.exit(1)
+ bookTagUrl = repoRoot+"/doc/tags/"+version
+
+ # Check that neither tag exists
+ checkNotTagged(tagUrl)
+ checkNotTagged(bookTagUrl)
+
+ # Do the tagging
+ tag("Vaadin", url, tagUrl, version, changeset)
+ tag("Book of Vaadin", bookRepo, bookTagUrl, version, changeset)
+
+###############################################################################
+# Verify command
+###############################################################################
+def verifyCommand(version, changeset):
+ # Check parameters
+ # TODO Put to a function
+ m = re.match(r'^[0-9]+\.[0-9]+\.[0-9]+(\.\w+)?$', version)
+ if not m:
+ print "Invalid version number '%s'" % version
+ sys.exit(1)
+ m = re.match(r'^[0-9]+$', changeset)
+ if not m:
+ print "Invalid changeset number '%s'" % changeset
+ sys.exit(1)
+
+ print "Verification not yet implemented, but ok."
+
+###############################################################################
+# Main
+###############################################################################
+
+if len(sys.argv) < 2:
+ helpAndExit()
+
+if sys.argv[1] == "tag" and len(sys.argv) == 4:
+ tagCommand(sys.argv[2], sys.argv[3])
+elif sys.argv[1] == "verify" and len(sys.argv) == 4:
+ verifyCommand(sys.argv[2], sys.argv[3])
+else:
+ print "Invalid command or number of parameters."
+ helpAndExit()