llvm-project/clang/test/Parser/cxx2b-init-statement.cpp
Mark de Wever ba15d186e5 [clang] Use -std=c++23 instead of -std=c++2b
During the ISO C++ Committee meeting plenary session the C++23 Standard
has been voted as technical complete.

This updates the reference to c++2b to c++23 and updates the __cplusplus
macro.

Drive-by fixes c++1z -> c++17 and c++2a -> c++20 when seen.

Reviewed By: aaron.ballman

Differential Revision: https://reviews.llvm.org/D149553
2023-05-04 19:19:52 +02:00

30 lines
906 B
C++

// RUN: %clang_cc1 -fsyntax-only -verify=expected -std=c++23 -Wall %s
// RUN: %clang_cc1 -fsyntax-only -verify=expected,expected-cxx20 -std=c++20 -Wall %s
namespace ns {
int i;
enum class e {};
}
void f() {
for (using foo = int;true;); //expected-cxx20-warning {{alias declaration in this context is a C++23 extension}}
switch(using foo = int; 0) { //expected-cxx20-warning {{alias declaration in this context is a C++23 extension}}
case 0: break;
}
if(using foo = int; false) {} //expected-cxx20-warning {{alias declaration in this context is a C++23 extension}}
if (using enum ns::e; false){} // expected-error {{expected '='}}
for (using ns::i; true;); // expected-error {{expected '='}}
if (using ns::i; false){} // expected-error {{expected '='}}
switch(using ns::i; 0) { // expected-error {{expected '='}}
case 0: break;
}
}