aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSimon Warta <[email protected]>2017-09-07 23:53:06 +0200
committerSimon Warta <[email protected]>2017-09-07 23:57:18 +0200
commit59ca3d8b4b733ad72b0eda950e9f730dc5898762 (patch)
tree95f53827d5787727627c5e3134555024fc0f3129
parenteb0232cc7db8849b1c4f2f07c9e3516c8b5c4f0c (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-xconfigure.py24
-rwxr-xr-xsrc/scripts/python_unittests.py25
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