diff --git a/update_version.py b/update_version.py index 7a961ae1397c6..7d279410e1df3 100755 --- a/update_version.py +++ b/update_version.py @@ -1,16 +1,25 @@ #!/usr/bin/env python +# Usage: ./update_version.py .. [] +# +# Example: +# ./update_version.py 3.7.1 2 +# => Version will become 3.7.1-rc-2 (beta) +# ./update_version.py 3.7.1 +# => Version will become 3.7.1 (stable) import datetime import re import sys from xml.dom import minidom -if len(sys.argv) < 2: +if len(sys.argv) < 2 or len(sys.argv) > 3: print """ [ERROR] Please specify a version. +./update_version.py .. [] + Example: -./update_version.py 2.1.3 +./update_version.py 3.7.1 2 """ exit(1) @@ -21,10 +30,14 @@ [ERROR] Version must be in the format .. Example: -./update_version.py 2.1.3 +./update_version.py 3.7.3 """ exit(1) +RC_VERSION = 0 +if len(sys.argv) > 2: + RC_VERSION = int(sys.argv[2]) + def Find(elem, tagname): for child in elem.childNodes: @@ -41,6 +54,13 @@ def ReplaceText(elem, text): elem.firstChild.replaceWholeText(text) +def GetFullVersion(rc_suffix = '-rc-'): + if RC_VERSION == 0: + return NEW_VERSION + else: + return '%s%s%s' % (NEW_VERSION, rc_suffix, RC_VERSION) + + def RewriteXml(filename, rewriter, add_xml_prefix=True): document = minidom.parse(filename) rewriter(document) @@ -74,7 +94,7 @@ def UpdateConfigure(): lambda line : re.sub( r'^AC_INIT\(\[Protocol Buffers\],\[.*\],\[protobuf@googlegroups.com\],\[protobuf\]\)$', ('AC_INIT([Protocol Buffers],[%s],[protobuf@googlegroups.com],[protobuf])' - % NEW_VERSION), + % GetFullVersion()), line)) @@ -120,44 +140,44 @@ def UpdateCsharp(): RewriteXml('csharp/src/Google.Protobuf/Google.Protobuf.csproj', lambda document : ReplaceText( Find(Find(document.documentElement, 'PropertyGroup'), 'VersionPrefix'), - NEW_VERSION), + GetFullVersion(rc_suffix = '-rc.')), add_xml_prefix=False) RewriteXml('csharp/Google.Protobuf.Tools.nuspec', lambda document : ReplaceText( Find(Find(document.documentElement, 'metadata'), 'version'), - NEW_VERSION)) + GetFullVersion(rc_suffix = '-rc.'))) def UpdateJava(): RewriteXml('java/pom.xml', lambda document : ReplaceText( - Find(document.documentElement, 'version'), NEW_VERSION)) + Find(document.documentElement, 'version'), GetFullVersion())) RewriteXml('java/bom/pom.xml', lambda document : ReplaceText( - Find(document.documentElement, 'version'), NEW_VERSION)) + Find(document.documentElement, 'version'), GetFullVersion())) RewriteXml('java/core/pom.xml', lambda document : ReplaceText( Find(Find(document.documentElement, 'parent'), 'version'), - NEW_VERSION)) + GetFullVersion())) RewriteXml('java/util/pom.xml', lambda document : ReplaceText( Find(Find(document.documentElement, 'parent'), 'version'), - NEW_VERSION)) + GetFullVersion())) RewriteXml('protoc-artifacts/pom.xml', lambda document : ReplaceText( - Find(document.documentElement, 'version'), NEW_VERSION)) + Find(document.documentElement, 'version'), GetFullVersion())) def UpdateJavaScript(): RewriteTextFile('js/package.json', lambda line : re.sub( r'^ "version": ".*",$', - ' "version": "%s",' % NEW_VERSION, + ' "version": "%s",' % GetFullVersion(rc_suffix = '-rc.'), line)) @@ -185,7 +205,7 @@ def UpdateObjectiveC(): RewriteTextFile('Protobuf.podspec', lambda line : re.sub( r"^ s.version = '.*'$", - " s.version = '%s'" % NEW_VERSION, + " s.version = '%s'" % GetFullVersion(rc_suffix = '-rc.'), line)) @@ -203,8 +223,12 @@ def CreateNode(tagname, indent, children): root = document.documentElement version = Find(root, 'version') - ReplaceText(Find(version, 'release'), NEW_VERSION) + ReplaceText(Find(version, 'release'), GetFullVersion(rc_suffix = 'RC')) ReplaceText(Find(version, 'api'), NEW_VERSION) + stability = Find(root, 'stability') + ReplaceText(Find(version, 'release'), + 'stable' if RC_VERSION == 0 else 'beta') + ReplaceText(Find(version, 'api'), 'stable' if RC_VERSION == 0 else 'beta') now = datetime.datetime.now() ReplaceText(Find(root, 'date'), now.strftime('%Y-%m-%d')) ReplaceText(Find(root, 'time'), now.strftime('%H:%M:%S')) @@ -215,7 +239,6 @@ def CreateNode(tagname, indent, children): % NEW_VERSION) return changelog.appendChild(document.createTextNode(' ')) - stability = Find(root, 'stability') release = CreateNode('release', 2, [ CreateNode('version', 3, [ FindAndClone(version, 'release'), @@ -234,18 +257,24 @@ def CreateNode(tagname, indent, children): changelog.appendChild(document.createTextNode('\n ')) RewriteXml('php/ext/google/protobuf/package.xml', Callback) + RewriteTextFile('php/ext/google/protobuf/protobuf.h', + lambda line : re.sub( + r"^#define PHP_PROTOBUF_VERSION .*$", + "#define PHP_PROTOBUF_VERSION \"%s\"" % GetFullVersion(rc_suffix = 'RC'), + line)) + def UpdatePython(): RewriteTextFile('python/google/protobuf/__init__.py', lambda line : re.sub( r"^__version__ = '.*'$", - "__version__ = '%s'" % NEW_VERSION, + "__version__ = '%s'" % GetFullVersion(rc_suffix = 'rc'), line)) def UpdateRuby(): RewriteTextFile('ruby/google-protobuf.gemspec', lambda line : re.sub( r'^ s.version = ".*"$', - ' s.version = "%s"' % NEW_VERSION, + ' s.version = "%s"' % GetFullVersion(rc_suffix = '.rc.'), line))