diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2015-04-22 05:36:41 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2015-04-22 05:36:41 (GMT) |
commit | aec050919344b9272f260b6275523cfb3abd1e41 (patch) | |
tree | fb82d940be22625d4f83662d79e5ecd4ff0fed20 /Lib/test/test_tcl.py | |
parent | c3a7f181008fef91b5a5977b370271ce3f7f75b0 (diff) | |
parent | 462c357d70cf499f82349c6839c624e4f3026a49 (diff) | |
download | cpython-aec050919344b9272f260b6275523cfb3abd1e41.zip cpython-aec050919344b9272f260b6275523cfb3abd1e41.tar.gz cpython-aec050919344b9272f260b6275523cfb3abd1e41.tar.bz2 |
Fixed full Tcl version parsing in tests for pre-final versions.
Diffstat (limited to 'Lib/test/test_tcl.py')
-rw-r--r-- | Lib/test/test_tcl.py | 26 |
1 files changed, 11 insertions, 15 deletions
diff --git a/Lib/test/test_tcl.py b/Lib/test/test_tcl.py index 83b4c9a..10b7675 100644 --- a/Lib/test/test_tcl.py +++ b/Lib/test/test_tcl.py @@ -1,4 +1,5 @@ import unittest +import re import sys import os from test import support @@ -17,27 +18,22 @@ try: except ImportError: INT_MAX = PY_SSIZE_T_MAX = sys.maxsize -tcl_version = _tkinter.TCL_VERSION.split('.') -try: - for i in range(len(tcl_version)): - tcl_version[i] = int(tcl_version[i]) -except ValueError: - pass -tcl_version = tuple(tcl_version) +tcl_version = tuple(map(int, _tkinter.TCL_VERSION.split('.'))) _tk_patchlevel = None def get_tk_patchlevel(): global _tk_patchlevel if _tk_patchlevel is None: tcl = Tcl() - patchlevel = [] - for x in tcl.call('info', 'patchlevel').split('.'): - try: - x = int(x, 10) - except ValueError: - x = -1 - patchlevel.append(x) - _tk_patchlevel = tuple(patchlevel) + patchlevel = tcl.call('info', 'patchlevel') + m = re.fullmatch(r'(\d+)\.(\d+)([ab.])(\d+)', patchlevel) + major, minor, releaselevel, serial = m.groups() + major, minor, serial = int(major), int(minor), int(serial) + releaselevel = {'a': 'alpha', 'b': 'beta', '.': 'final'}[releaselevel] + if releaselevel == 'final': + _tk_patchlevel = major, minor, serial, releaselevel, 0 + else: + _tk_patchlevel = major, minor, 0, releaselevel, serial return _tk_patchlevel |