blob: c8d22b731076eb116248165a2ffca6059ccd57b8 [file] [log] [blame]
Richard Smith79c88c32018-09-26 19:00:16 +00001// RUN: %clang_cc1 -fsyntax-only -std=c++17 -Wc++2a-compat-pedantic -verify %s
2// RUN: %clang_cc1 -fsyntax-only -std=c++2a -pedantic -verify %s
3
4struct A { // expected-note 0+{{candidate}}
5 A() = default; // expected-note 0+{{candidate}}
6 int x, y;
7};
8A a1 = {1, 2};
9#if __cplusplus <= 201703L
10 // expected-warning@-2 {{aggregate initialization of type 'A' with user-declared constructors is incompatible with C++2a}}
11#else
12 // expected-error@-4 {{no matching constructor}}
13#endif
14A a2 = {};
15
16struct B : A { A a; };
17B b1 = {{}, {}}; // ok
18B b2 = {1, 2, 3, 4};
19#if __cplusplus <= 201703L
20 // expected-warning@-2 2{{aggregate initialization of type 'A' with user-declared constructors is incompatible with C++2a}}
21#else
22 // expected-error@-4 2{{no viable conversion from 'int' to 'A'}}
23#endif
Richard Smith28ddb912018-11-14 21:04:34 +000024
25// Essentially any use of a u8 string literal in C++<=17 is broken by C++20.
26// Just warn on all such string literals.
27struct string { string(const char*); }; // expected-note 0+{{candidate}}
28char u8arr[] = u8"hello";
29const char *u8ptr = "wo" u8"rld";
30string u8str = u8"test" u8"test";
31#if __cplusplus <= 201703L
32// expected-warning@-4 {{type of UTF-8 string literal will change}} expected-note@-4 {{remove 'u8' prefix}}
33// expected-warning@-4 {{type of UTF-8 string literal will change}} expected-note@-4 {{remove 'u8' prefix}}
34// expected-warning@-4 {{type of UTF-8 string literal will change}} expected-note@-4 {{remove 'u8' prefix}}
35#else
36// expected-error@-8 {{ISO C++20 does not permit initialization of char array with UTF-8 string literal}}
37// expected-error@-8 {{cannot initialize a variable of type 'const char *' with an lvalue of type 'const char8_t [6]'}}
38// expected-error@-8 {{no viable conversion from 'const char8_t [9]' to 'string'}}
39#endif
Richard Smith76b90272019-05-09 03:59:21 +000040
41template<bool b>
42struct C {
43 explicit(C)(int);
44};
45#if __cplusplus <= 201703L
46// expected-warning@-3 {{this expression will be parsed as explicit(bool) in C++2a}}
47#if defined(__cpp_conditional_explicit)
48#error "the feature test macro __cpp_conditional_explicit isn't correct"
49#endif
50#else
51// expected-error@-8 {{does not refer to a value}}
52// expected-error@-9 {{expected member name or ';'}}
53// expected-error@-10 {{expected ')'}}
54// expected-note@-12 {{declared here}}
55// expected-note@-12 {{to match this '('}}
56#if !defined(__cpp_conditional_explicit) || __cpp_conditional_explicit != 201806L
57#error "the feature test macro __cpp_conditional_explicit isn't correct"
58#endif
Gauthier Harnisch796ed032019-06-14 08:56:20 +000059#endif
60
61auto l = []() consteval {};
62int consteval();
63#if __cplusplus <= 201703L
64// expected-warning@-3 {{'consteval' is a keyword in C++2a}}
65// expected-error@-4 {{expected body of lambda expression}}
66#else
67// expected-error@-5 {{expected unqualified-id}}
Richard Smith76b90272019-05-09 03:59:21 +000068#endif