diff options
author | Simon Warta <[email protected]> | 2017-09-07 23:53:06 +0200 |
---|---|---|
committer | Simon Warta <[email protected]> | 2017-09-07 23:57:18 +0200 |
commit | 59ca3d8b4b733ad72b0eda950e9f730dc5898762 (patch) | |
tree | 95f53827d5787727627c5e3134555024fc0f3129 | |
parent | eb0232cc7db8849b1c4f2f07c9e3516c8b5c4f0c (diff) |
Improve appleclang version logic
For appleclang version >= X, return minimal clang version Y. This now
works for all intermediate versions between the known fixed points. This
is especially important for compiling today's code with a future
compiler.
-rwxr-xr-x | configure.py | 24 | ||||
-rwxr-xr-x | src/scripts/python_unittests.py | 25 |
2 files changed, 36 insertions, 13 deletions
diff --git a/configure.py b/configure.py index 6b5b700ed..1314e05b8 100755 --- a/configure.py +++ b/configure.py @@ -2704,25 +2704,23 @@ class CompilerDetector(object): cc_version = "%d.%d" % (major, minor) if cc_version is None and self._cc_name == 'clang' and self._os_name in ['darwin', 'ios']: + # For appleclang version >= X, return minimal clang version Y appleclang_to_clang_version = { - '703': '3.8', - '800': '3.9', + 703: '3.8', + 800: '3.9', # 802 has no support for clang 4.0 flags -Og and -MJ, 900 has. - '802': '3.9', - '900': '4.0', + 802: '3.9', + 900: '4.0', } + cc_version = '3.8' # safe default match = re.search(r'Apple LLVM version [0-9\.]+ \(clang-([0-9]+)\.', cc_output) if match: - apple_clang_version = match.group(1) - if apple_clang_version in appleclang_to_clang_version: - cc_version = appleclang_to_clang_version[apple_clang_version] - logging.info('Mapping Apple Clang version %s to LLVM version %s' % ( - apple_clang_version, cc_version)) - else: - logging.warning('Unable to determine LLVM Clang version cooresponding to Apple Clang %s' % - (apple_clang_version)) - cc_version = '3.8' # safe default + user_appleclang = int(match.group(1)) + for appleclang, clang in sorted(appleclang_to_clang_version.items()): + if user_appleclang >= appleclang: + cc_version = clang + logging.info('Mapping Apple Clang version %s to LLVM version %s' % (user_appleclang, cc_version)) if not cc_version: logging.warning("Tried to get %s version, but output '%s' does not match expected version format" % ( diff --git a/src/scripts/python_unittests.py b/src/scripts/python_unittests.py index 1df35f0cd..649ccf662 100755 --- a/src/scripts/python_unittests.py +++ b/src/scripts/python_unittests.py @@ -110,6 +110,31 @@ Thread model: posix InstalledDir: /Applications/Xcode-beta.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin""" self.assertEqual(detector.version_from_compiler_output(compiler_out), "4.0") + def test_clang_version_appleclang_intermediate(self): + # fake versions in between the knwon ones + # clang-700.0.0 is lower than all known versions + # clang-802.1.0 is a minor update of known clang-802 + # clang-1111.9.99 is a random future value + detector = CompilerDetector("clang", "clang++", "darwin") + + compiler_out = """Apple LLVM version 7.0.0 (clang-700.0.0) +Target: x86_64-apple-darwin16.7.0 +Thread model: posix +InstalledDir: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin""" + self.assertEqual(detector.version_from_compiler_output(compiler_out), "3.8") + + compiler_out = """Apple LLVM version 8.1.1 (clang-802.1.0) +Target: x86_64-apple-darwin16.7.0 +Thread model: posix +InstalledDir: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin""" + self.assertEqual(detector.version_from_compiler_output(compiler_out), "3.9") + + compiler_out = """Apple LLVM version 11.11.0 (clang-1111.9.99) +Target: x86_64-apple-darwin16.7.0 +Thread model: posix +InstalledDir: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin""" + self.assertEqual(detector.version_from_compiler_output(compiler_out), "4.0") + def test_msvc_version(self): detector = CompilerDetector("msvc", "cl.exe", "windows") compiler_out = """msvc_version.c |