summaryrefslogtreecommitdiff
path: root/methods.py
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2020-02-26 15:12:00 +0100
committerGitHub <noreply@github.com>2020-02-26 15:12:00 +0100
commit216d2ad31cb0e43d6b5a31f2dcad5fc528633808 (patch)
tree1a1d3106caa37eecfff5d26f587c237f0aacb1e0 /methods.py
parent3ef37f05c67db8732330dead4950225535e16bef (diff)
parentc7dc5142b56b3f52ba9c2746eb4855fae68ed26e (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.py13
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