Support rc version in update_version.py (#5750)

* Support rc version in update_version.py
pull/5766/head
Hao Nguyen 6 years ago committed by Bo Yang
parent c7b3392201
commit 05f57125c3
  1. 63
      update_version.py

@ -1,16 +1,25 @@
#!/usr/bin/env python #!/usr/bin/env python
# Usage: ./update_version.py <MAJOR>.<MINOR>.<MICRO> [<RC version>]
#
# 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 datetime
import re import re
import sys import sys
from xml.dom import minidom from xml.dom import minidom
if len(sys.argv) < 2: if len(sys.argv) < 2 or len(sys.argv) > 3:
print """ print """
[ERROR] Please specify a version. [ERROR] Please specify a version.
./update_version.py <MAJOR>.<MINOR>.<MICRO> [<RC version>]
Example: Example:
./update_version.py 2.1.3 ./update_version.py 3.7.1 2
""" """
exit(1) exit(1)
@ -21,10 +30,14 @@ if len(NEW_VERSION_INFO) != 3:
[ERROR] Version must be in the format <MAJOR>.<MINOR>.<MICRO> [ERROR] Version must be in the format <MAJOR>.<MINOR>.<MICRO>
Example: Example:
./update_version.py 2.1.3 ./update_version.py 3.7.3
""" """
exit(1) exit(1)
RC_VERSION = 0
if len(sys.argv) > 2:
RC_VERSION = int(sys.argv[2])
def Find(elem, tagname): def Find(elem, tagname):
for child in elem.childNodes: for child in elem.childNodes:
@ -41,6 +54,13 @@ def ReplaceText(elem, text):
elem.firstChild.replaceWholeText(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): def RewriteXml(filename, rewriter, add_xml_prefix=True):
document = minidom.parse(filename) document = minidom.parse(filename)
rewriter(document) rewriter(document)
@ -74,7 +94,7 @@ def UpdateConfigure():
lambda line : re.sub( lambda line : re.sub(
r'^AC_INIT\(\[Protocol Buffers\],\[.*\],\[protobuf@googlegroups.com\],\[protobuf\]\)$', r'^AC_INIT\(\[Protocol Buffers\],\[.*\],\[protobuf@googlegroups.com\],\[protobuf\]\)$',
('AC_INIT([Protocol Buffers],[%s],[protobuf@googlegroups.com],[protobuf])' ('AC_INIT([Protocol Buffers],[%s],[protobuf@googlegroups.com],[protobuf])'
% NEW_VERSION), % GetFullVersion()),
line)) line))
@ -111,44 +131,44 @@ def UpdateCsharp():
RewriteXml('csharp/src/Google.Protobuf/Google.Protobuf.csproj', RewriteXml('csharp/src/Google.Protobuf/Google.Protobuf.csproj',
lambda document : ReplaceText( lambda document : ReplaceText(
Find(Find(document.documentElement, 'PropertyGroup'), 'VersionPrefix'), Find(Find(document.documentElement, 'PropertyGroup'), 'VersionPrefix'),
NEW_VERSION), GetFullVersion(rc_suffix = '-rc.')),
add_xml_prefix=False) add_xml_prefix=False)
RewriteXml('csharp/Google.Protobuf.Tools.nuspec', RewriteXml('csharp/Google.Protobuf.Tools.nuspec',
lambda document : ReplaceText( lambda document : ReplaceText(
Find(Find(document.documentElement, 'metadata'), 'version'), Find(Find(document.documentElement, 'metadata'), 'version'),
NEW_VERSION)) GetFullVersion(rc_suffix = '-rc.')))
def UpdateJava(): def UpdateJava():
RewriteXml('java/pom.xml', RewriteXml('java/pom.xml',
lambda document : ReplaceText( lambda document : ReplaceText(
Find(document.documentElement, 'version'), NEW_VERSION)) Find(document.documentElement, 'version'), GetFullVersion()))
RewriteXml('java/bom/pom.xml', RewriteXml('java/bom/pom.xml',
lambda document : ReplaceText( lambda document : ReplaceText(
Find(document.documentElement, 'version'), NEW_VERSION)) Find(document.documentElement, 'version'), GetFullVersion()))
RewriteXml('java/core/pom.xml', RewriteXml('java/core/pom.xml',
lambda document : ReplaceText( lambda document : ReplaceText(
Find(Find(document.documentElement, 'parent'), 'version'), Find(Find(document.documentElement, 'parent'), 'version'),
NEW_VERSION)) GetFullVersion()))
RewriteXml('java/util/pom.xml', RewriteXml('java/util/pom.xml',
lambda document : ReplaceText( lambda document : ReplaceText(
Find(Find(document.documentElement, 'parent'), 'version'), Find(Find(document.documentElement, 'parent'), 'version'),
NEW_VERSION)) GetFullVersion()))
RewriteXml('protoc-artifacts/pom.xml', RewriteXml('protoc-artifacts/pom.xml',
lambda document : ReplaceText( lambda document : ReplaceText(
Find(document.documentElement, 'version'), NEW_VERSION)) Find(document.documentElement, 'version'), GetFullVersion()))
def UpdateJavaScript(): def UpdateJavaScript():
RewriteTextFile('js/package.json', RewriteTextFile('js/package.json',
lambda line : re.sub( lambda line : re.sub(
r'^ "version": ".*",$', r'^ "version": ".*",$',
' "version": "%s",' % NEW_VERSION, ' "version": "%s",' % GetFullVersion(rc_suffix = '-rc.'),
line)) line))
@ -176,7 +196,7 @@ def UpdateObjectiveC():
RewriteTextFile('Protobuf.podspec', RewriteTextFile('Protobuf.podspec',
lambda line : re.sub( lambda line : re.sub(
r"^ s.version = '.*'$", r"^ s.version = '.*'$",
" s.version = '%s'" % NEW_VERSION, " s.version = '%s'" % GetFullVersion(rc_suffix = '-rc.'),
line)) line))
@ -194,8 +214,12 @@ def UpdatePhp():
root = document.documentElement root = document.documentElement
version = Find(root, 'version') version = Find(root, 'version')
ReplaceText(Find(version, 'release'), NEW_VERSION) ReplaceText(Find(version, 'release'), GetFullVersion(rc_suffix = 'RC'))
ReplaceText(Find(version, 'api'), NEW_VERSION) 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() now = datetime.datetime.now()
ReplaceText(Find(root, 'date'), now.strftime('%Y-%m-%d')) ReplaceText(Find(root, 'date'), now.strftime('%Y-%m-%d'))
ReplaceText(Find(root, 'time'), now.strftime('%H:%M:%S')) ReplaceText(Find(root, 'time'), now.strftime('%H:%M:%S'))
@ -206,7 +230,6 @@ def UpdatePhp():
% NEW_VERSION) % NEW_VERSION)
return return
changelog.appendChild(document.createTextNode(' ')) changelog.appendChild(document.createTextNode(' '))
stability = Find(root, 'stability')
release = CreateNode('release', 2, [ release = CreateNode('release', 2, [
CreateNode('version', 3, [ CreateNode('version', 3, [
FindAndClone(version, 'release'), FindAndClone(version, 'release'),
@ -230,18 +253,24 @@ def UpdatePhp():
'PHP_PROTOBUF_VERSION "%s"' % NEW_VERSION, 'PHP_PROTOBUF_VERSION "%s"' % NEW_VERSION,
line)) line))
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(): def UpdatePython():
RewriteTextFile('python/google/protobuf/__init__.py', RewriteTextFile('python/google/protobuf/__init__.py',
lambda line : re.sub( lambda line : re.sub(
r"^__version__ = '.*'$", r"^__version__ = '.*'$",
"__version__ = '%s'" % NEW_VERSION, "__version__ = '%s'" % GetFullVersion(rc_suffix = 'rc'),
line)) line))
def UpdateRuby(): def UpdateRuby():
RewriteTextFile('ruby/google-protobuf.gemspec', RewriteTextFile('ruby/google-protobuf.gemspec',
lambda line : re.sub( lambda line : re.sub(
r'^ s.version = ".*"$', r'^ s.version = ".*"$',
' s.version = "%s"' % NEW_VERSION, ' s.version = "%s"' % GetFullVersion(rc_suffix = '.rc.'),
line)) line))

Loading…
Cancel
Save