diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2020-02-26 15:12:00 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-02-26 15:12:00 +0100 |
commit | 216d2ad31cb0e43d6b5a31f2dcad5fc528633808 (patch) | |
tree | 1a1d3106caa37eecfff5d26f587c237f0aacb1e0 /methods.py | |
parent | 3ef37f05c67db8732330dead4950225535e16bef (diff) | |
parent | c7dc5142b56b3f52ba9c2746eb4855fae68ed26e (diff) |
Merge pull request #36559 from akien-mga/scons-compiler-version-ints
SCons: Fix get_compiler_version() to return ints
Diffstat (limited to 'methods.py')
-rw-r--r-- | methods.py | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/methods.py b/methods.py index 2e858e3865..3f03e6bbd2 100644 --- a/methods.py +++ b/methods.py @@ -558,19 +558,18 @@ def is_vanilla_clang(env): def get_compiler_version(env): """ - Returns an array of version numbers as strings: [major, minor, patch]. + Returns an array of version numbers as ints: [major, minor, patch]. The return array should have at least two values (major, minor). """ - if using_gcc(env): - version = decode_utf8(subprocess.check_output([env['CXX'], '-dumpversion']).strip()) - elif using_clang(env): - # Not using -dumpversion as it used to return 4.2.1: https://reviews.llvm.org/D56803 + if not env.msvc: + # Not using -dumpversion as some GCC distros only return major, and + # Clang used to return hardcoded 4.2.1: # https://reviews.llvm.org/D56803 version = decode_utf8(subprocess.check_output([env['CXX'], '--version']).strip()) else: # TODO: Implement for MSVC return None - match = re.search('[0-9]+\.[0-9.]*', version) + match = re.search('[0-9]+\.[0-9.]+', version) if match is not None: - return match.group().split('.') + return list(map(int, match.group().split('.'))) else: return None |