Merge pull request #11986 from williamspatrick/clang-enable-cpp23

add support for newer C++ -std= flags on Clang/GCC
pull/11932/head
Jussi Pakkanen 2 years ago committed by GitHub
commit 1cd16a7cc5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 26
      mesonbuild/compilers/cpp.py
  2. 15
      unittests/linuxliketests.py

@ -154,6 +154,10 @@ class CPPCompiler(CLikeCompiler, Compiler):
'gnu++17': 'gnu++1z',
'c++20': 'c++2a',
'gnu++20': 'gnu++2a',
'c++23': 'c++2b',
'gnu++23': 'gnu++2b',
'c++26': 'c++2c',
'gnu++26': 'gnu++2c',
}
# Currently, remapping is only supported for Clang, Elbrus and GCC
@ -222,6 +226,10 @@ class _StdCPPLibMixin(CompilerMixinBase):
class ClangCPPCompiler(_StdCPPLibMixin, ClangCompiler, CPPCompiler):
_CPP23_VERSION = '>=12.0.0'
_CPP26_VERSION = '>=17.0.0'
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
info: 'MachineInfo', exe_wrapper: T.Optional['ExternalProgram'] = None,
linker: T.Optional['DynamicLinker'] = None,
@ -248,11 +256,18 @@ class ClangCPPCompiler(_StdCPPLibMixin, ClangCompiler, CPPCompiler):
),
key.evolve('rtti'): coredata.UserBooleanOption('Enable RTTI', True),
})
opts[key.evolve('std')].choices = [
cppstd_choices = [
'none', 'c++98', 'c++03', 'c++11', 'c++14', 'c++17', 'c++1z',
'c++2a', 'c++20', 'gnu++11', 'gnu++14', 'gnu++17', 'gnu++1z',
'gnu++2a', 'gnu++20',
]
if version_compare(self.version, self._CPP23_VERSION):
cppstd_choices.append('c++23')
cppstd_choices.append('gnu++23')
if version_compare(self.version, self._CPP26_VERSION):
cppstd_choices.append('c++26')
cppstd_choices.append('gnu++26')
opts[key.evolve('std')].choices = cppstd_choices
if self.info.is_windows() or self.info.is_cygwin():
opts.update({
key.evolve('winlibs'): coredata.UserArrayOption(
@ -294,7 +309,11 @@ class ArmLtdClangCPPCompiler(ClangCPPCompiler):
class AppleClangCPPCompiler(ClangCPPCompiler):
pass
_CPP23_VERSION = '>=13.0.0'
# TODO: We don't know which XCode version will include LLVM 17 yet, so
# use something absurd.
_CPP26_VERSION = '>=99.0.0'
class EmscriptenCPPCompiler(EmscriptenMixin, ClangCPPCompiler):
@ -414,6 +433,9 @@ class GnuCPPCompiler(_StdCPPLibMixin, GnuCompiler, CPPCompiler):
if version_compare(self.version, '>=12.2.0'):
cppstd_choices.append('c++23')
cppstd_choices.append('gnu++23')
if version_compare(self.version, '>=14.0.0'):
cppstd_choices.append('c++26')
cppstd_choices.append('gnu++26')
opts[key].choices = cppstd_choices
if self.info.is_windows() or self.info.is_cygwin():
opts.update({

@ -517,6 +517,15 @@ class LinuxlikeTests(BasePlatformTests):
has_cpp20 = (compiler.get_id() not in {'clang', 'gcc'} or
compiler.get_id() == 'clang' and _clang_at_least(compiler, '>=10.0.0', None) or
compiler.get_id() == 'gcc' and version_compare(compiler.version, '>=10.0.0'))
has_cpp2b = (compiler.get_id() not in {'clang', 'gcc'} or
compiler.get_id() == 'clang' and _clang_at_least(compiler, '>=12.0.0', None) or
compiler.get_id() == 'gcc' and version_compare(compiler.version, '>=12.2.0'))
has_cpp23 = (compiler.get_id() not in {'clang', 'gcc'} or
compiler.get_id() == 'clang' and _clang_at_least(compiler, '>=17.0.0', None) or
compiler.get_id() == 'gcc' and version_compare(compiler.version, '>=12.2.0'))
has_cpp26 = (compiler.get_id() not in {'clang', 'gcc'} or
compiler.get_id() == 'clang' and _clang_at_least(compiler, '>=17.0.0', None) or
compiler.get_id() == 'gcc' and version_compare(compiler.version, '>=14.0.0'))
has_c18 = (compiler.get_id() not in {'clang', 'gcc'} or
compiler.get_id() == 'clang' and _clang_at_least(compiler, '>=8.0.0', '>=11.0') or
compiler.get_id() == 'gcc' and version_compare(compiler.version, '>=8.0.0'))
@ -533,6 +542,12 @@ class LinuxlikeTests(BasePlatformTests):
continue
elif '++20' in v and not has_cpp20:
continue
elif '++2b' in v and not has_cpp2b:
continue
elif '++23' in v and not has_cpp23:
continue
elif ('++26' in v or '++2c' in v) and not has_cpp26:
continue
# now C
elif '17' in v and not has_cpp2a_c17:
continue

Loading…
Cancel
Save