2017-08-25 10:25:07 +08:00
// RUN: %clang_cc1 -fsyntax-only -std=c++17 -pedantic -verify %s
2020-02-19 08:13:23 +08:00
// RUN: %clang_cc1 -fsyntax-only -std=c++20 -Wc++17-compat-pedantic -verify %s -Wno-defaulted-function-deleted
2017-08-25 10:25:07 +08:00
struct A { } ;
int ( A : : * pa ) ( ) const & ;
int use_pa = ( A ( ) . * pa ) ( ) ;
# if __cplusplus <= 201703L
2020-02-19 08:13:23 +08:00
// expected-warning@-2 {{invoking a pointer to a 'const &' member function on an rvalue is a C++20 extension}}
2017-08-25 10:25:07 +08:00
# else
2020-02-19 08:13:23 +08:00
// expected-warning@-4 {{invoking a pointer to a 'const &' member function on an rvalue is incompatible with C++ standards before C++20}}
2017-08-25 10:25:07 +08:00
# endif
struct B {
void b ( ) {
( void ) [ = , this ] { } ;
# if __cplusplus <= 201703L
2020-02-19 08:13:23 +08:00
// expected-warning@-2 {{explicit capture of 'this' with a capture default of '=' is a C++20 extension}}
2017-08-25 10:25:07 +08:00
# else
2020-02-19 08:13:23 +08:00
// expected-warning@-4 {{explicit capture of 'this' with a capture default of '=' is incompatible with C++ standards before C++20}}
2017-08-25 10:25:07 +08:00
# endif
}
2017-08-28 08:31:35 +08:00
int n : 5 = 0 ;
# if __cplusplus <= 201703L
2020-02-19 08:13:23 +08:00
// expected-warning@-2 {{default member initializer for bit-field is a C++20 extension}}
2017-08-28 08:31:35 +08:00
# else
2020-02-19 08:13:23 +08:00
// expected-warning@-4 {{default member initializer for bit-field is incompatible with C++ standards before C++20}}
2017-08-28 08:31:35 +08:00
# endif
2017-08-25 10:25:07 +08:00
} ;
2018-09-28 06:47:04 +08:00
auto Lambda = [ ] { } ;
decltype ( Lambda ) AnotherLambda ;
# if __cplusplus <= 201703L
// expected-error@-2 {{no matching constructor}} expected-note@-3 2{{candidate}}
# else
2020-02-19 08:13:23 +08:00
// expected-warning@-4 {{default construction of lambda is incompatible with C++ standards before C++20}}
2018-09-28 06:47:04 +08:00
# endif
void copy_lambda ( ) { Lambda = Lambda ; }
# if __cplusplus <= 201703L
// expected-error@-2 {{deleted}} expected-note@-10 {{lambda}}
# else
2020-02-19 08:13:23 +08:00
// expected-warning@-4 {{assignment of lambda is incompatible with C++ standards before C++20}}
2018-09-28 06:47:04 +08:00
# endif
2018-09-28 09:16:43 +08:00
struct DefaultDeleteWrongTypeBase {
DefaultDeleteWrongTypeBase ( DefaultDeleteWrongTypeBase & ) ;
} ;
struct DefaultDeleteWrongType : DefaultDeleteWrongTypeBase {
DefaultDeleteWrongType ( const DefaultDeleteWrongType & ) = default ;
# if __cplusplus <= 201703L
// expected-error@-2 {{a member or base requires it to be non-const}}
# else
2020-02-19 08:13:23 +08:00
// expected-warning@-4 {{explicitly defaulting this copy constructor with a type different from the implicit type is incompatible with C++ standards before C++20}}
2018-09-28 09:16:43 +08:00
# endif
} ;
2018-09-29 02:44:09 +08:00
void ForRangeInit ( ) {
for ( int arr [ 3 ] = { 1 , 2 , 3 } ; int n : arr ) { }
# if __cplusplus <= 201703L
2020-02-19 08:13:23 +08:00
// expected-warning@-2 {{range-based for loop initialization statements are a C++20 extension}}
2018-09-29 02:44:09 +08:00
# else
2020-02-19 08:13:23 +08:00
// expected-warning@-4 {{range-based for loop initialization statements are incompatible with C++ standards before C++20}}
2018-09-29 02:44:09 +08:00
# endif
}
2019-05-14 07:35:21 +08:00
struct ConstexprVirtual {
virtual constexpr void f ( ) { }
# if __cplusplus <= 201703L
// expected-error@-2 {{virtual function cannot be constexpr}}
# else
2020-02-19 08:13:23 +08:00
// expected-warning@-4 {{virtual constexpr functions are incompatible with C++ standards before C++20}}
2019-05-14 07:35:21 +08:00
# endif
} ;
2019-05-23 03:52:55 +08:00
struct C { int x , y , z ; } ;
static auto [ cx , cy , cz ] = C ( ) ;
# if __cplusplus <= 201703L
2020-02-19 08:13:23 +08:00
// expected-warning@-2 {{decomposition declaration declared 'static' is a C++20 extension}}
2019-05-23 03:52:55 +08:00
# else
2020-02-19 08:13:23 +08:00
// expected-warning@-4 {{decomposition declaration declared 'static' is incompatible with C++ standards before C++20}}
2019-05-23 03:52:55 +08:00
# endif
void f ( ) {
static thread_local auto [ cx , cy , cz ] = C ( ) ;
# if __cplusplus <= 201703L
2020-02-19 08:13:23 +08:00
// expected-warning@-2 {{decomposition declaration declared with 'static thread_local' specifiers is a C++20 extension}}
2019-05-23 03:52:55 +08:00
# else
2020-02-19 08:13:23 +08:00
// expected-warning@-4 {{decomposition declaration declared with 'static thread_local' specifiers is incompatible with C++ standards before C++20}}
2019-05-23 03:52:55 +08:00
# endif
}
2019-10-23 08:44:08 +08:00
struct DefaultedComparisons {
bool operator = = ( const DefaultedComparisons & ) const = default ;
bool operator ! = ( const DefaultedComparisons & ) const = default ;
# if __cplusplus <= 201703L
// expected-warning@-3 {{defaulted comparison operators are a C++20 extension}}
// expected-warning@-3 {{defaulted comparison operators are a C++20 extension}}
# else
// expected-warning@-6 {{defaulted comparison operators are incompatible with C++ standards before C++20}}
// expected-warning@-6 {{defaulted comparison operators are incompatible with C++ standards before C++20}}
# endif
bool operator < = > ( const DefaultedComparisons & ) const = default ;
# if __cplusplus <= 201703L
// expected-error@-2 {{'operator<=' cannot be the name of a variable or data member}} expected-error@-2 0+{{}} expected-warning@-2 {{}}
# else
2020-02-19 08:13:23 +08:00
// expected-warning@-4 {{'<=>' operator is incompatible with C++ standards before C++20}}
2019-10-23 08:44:08 +08:00
# endif
bool operator < ( const DefaultedComparisons & ) const = default ;
bool operator < = ( const DefaultedComparisons & ) const = default ;
bool operator > ( const DefaultedComparisons & ) const = default ;
bool operator > = ( const DefaultedComparisons & ) const = default ;
# if __cplusplus <= 201703L
// expected-error@-5 {{only special member functions}}
// expected-error@-5 {{only special member functions}}
// expected-error@-5 {{only special member functions}}
// expected-error@-5 {{only special member functions}}
# else
// expected-warning@-10 {{defaulted comparison operators are incompatible with C++ standards before C++20}}
// expected-warning@-10 {{defaulted comparison operators are incompatible with C++ standards before C++20}}
// expected-warning@-10 {{defaulted comparison operators are incompatible with C++ standards before C++20}}
// expected-warning@-10 {{defaulted comparison operators are incompatible with C++ standards before C++20}}
# endif
} ;
2020-09-21 14:16:08 +08:00
namespace NTTP {
struct A { } ;
template < A > struct Class { } ;
# if __cplusplus <= 201703L
// expected-error@-2 {{non-type template parameter cannot have type 'NTTP::A' before C++20}}
# else
// expected-warning@-4 {{non-type template parameter of type 'NTTP::A' is incompatible with C++ standards before C++20}}
# endif
}