1 // RUN: %clang_cc1 -fsyntax-only -std=c++98 -Wc++11-compat-pedantic -verify %s
2 // RUN: %clang_cc1 -fsyntax-only -std=c++17 -Wc++11-compat-pedantic -verify %s
4 #if __cplusplus < 201103L
7 template<typename T
> void f(T
) {} // expected-note 2{{here}}
9 template void ::N::f
<int>(int); // expected-warning {{explicit instantiation of 'f' not in a namespace enclosing 'N'}}
13 template void f
<char>(char); // expected-warning {{explicit instantiation of 'N::f' must occur in namespace 'N'}}
15 template<typename T
> void g(T
) {} // expected-note 2{{here}}
17 template void g
<int>(int); // expected-warning {{explicit instantiation of 'g' must occur at global scope}}
18 template void ::g
<char>(char); // expected-warning {{explicit instantiation of 'g' must occur at global scope}}
21 template inline void g
<double>(double); // expected-warning {{explicit instantiation cannot be 'inline'}}
24 auto int n
= 0; // expected-warning {{'auto' storage class specifier is redundant and incompatible with C++11}}
31 s
= { n
}, // expected-warning {{non-constant-expression cannot be narrowed from type 'int' to 'char' in initializer list in C++11}} expected-note {{explicit cast}}
32 t
= { 1234 }; // expected-warning {{constant expression evaluates to 1234 which cannot be narrowed to type 'char' in C++11}} expected-warning {{changes value}} expected-note {{explicit cast}}
35 int printf(const char *, ...);
36 typedef __typeof(sizeof(int)) size_t;
37 void h(size_t foo
, size_t bar
) {
38 printf("foo is %"PRIuS
", bar is %"PRIuS
, foo
, bar
); // expected-warning 2{{identifier after literal will be treated as a reserved user-defined literal suffix in C++11}}
42 char c
= 'x'_x
; // expected-warning {{will be treated as a user-defined literal suffix}}
44 template<int ...N
> int f() { // expected-warning {{C++11 extension}}
45 return (N
+ ...); // expected-warning {{C++17 extension}}
50 decltype(auto) x
= 0; // expected-warning {{'decltype(auto)' type specifier is incompatible}}
52 auto init_capture
= [a(0)] {}; // expected-warning {{initialized lambda captures are incompatible with C++ standards before C++14}}
56 auto // expected-warning {{generic lambdas are incompatible}}
59 auto deduced_return_type(); // expected-warning {{incompatible with C++ standards before C++14}}
60 auto *another_deduced_return_type(); // expected-warning {{incompatible with C++ standards before C++14}}
61 decltype(auto) also_deduced_return_type(); // expected-warning {{return type deduction}} expected-warning {{'decltype(auto)' type specifier is incompatible}}
63 auto (*not_deduced_return_type
)() = f
;
65 auto deduced_lambda_return_type
= []() ->
66 auto // expected-warning {{return type deduction is incompatible}}
69 auto trailing_non_deduced_return_type() -> int;
70 auto trailing_deduced_return_type() -> auto; // expected-warning {{incompatible with C++ standards before C++14}}
73 operator auto(); // expected-warning {{return type deduction is incompatible}}