// RUN: %clang_cc1 -fsyntax-only -verify %s -std=c++11 -pedantic -triple=x86_64-linux-gnu -Wno-invalid-utf8 int f(); // expected-note {{declared here}} static_assert(f(), "f"); // expected-error {{static assertion expression is not an integral constant expression}} expected-note {{non-constexpr function 'f' cannot be used in a constant expression}} static_assert(true, "true is not false"); static_assert(false, "false is false"); // expected-error {{static assertion failed: false is false}} void g() { static_assert(false, "false is false"); // expected-error {{static assertion failed: false is false}} } class C { static_assert(false, "false is false"); // expected-error {{static assertion failed: false is false}} }; template struct T { static_assert(N == 2, "N is not 2!"); // expected-error {{static assertion failed due to requirement '1 == 2': N is not 2!}} }; T<1> t1; // expected-note {{in instantiation of template class 'T<1>' requested here}} T<2> t2; template struct S { static_assert(sizeof(T) > sizeof(char), "Type not big enough!"); // expected-error {{static assertion failed due to requirement 'sizeof(char) > sizeof(char)': Type not big enough!}} \ // expected-note {{1 > 1}} }; S s1; // expected-note {{in instantiation of template class 'S' requested here}} S s2; static_assert(false, L"\xFFFFFFFF"); // expected-warning {{encoding prefix 'L' on an unevaluated string literal has no effect and is incompatible with c++2c}} \ // expected-error {{invalid escape sequence '\xFFFFFFFF' in an unevaluated string literal}} \ // expected-error {{hex escape sequence out of range}} static_assert(false, u"\U000317FF"); // expected-warning {{encoding prefix 'u' on an unevaluated string literal has no effect and is incompatible with c++2c}} \ // expected-error {{static assertion failed}} static_assert(false, u8"Ω"); // expected-warning {{encoding prefix 'u8' on an unevaluated string literal has no effect and is incompatible with c++2c}} \ // expected-error {{static assertion failed: Ω}} static_assert(false, L"\u1234"); // expected-warning {{encoding prefix 'L' on an unevaluated string literal has no effect and is incompatible with c++2c}} \ // expected-error {{static assertion failed: ሴ}} static_assert(false, L"\x1ff" // expected-warning {{encoding prefix 'L' on an unevaluated string literal has no effect and is incompatible with c++2c}} \ // expected-error {{hex escape sequence out of range}} \ // expected-error {{invalid escape sequence '\x1ff' in an unevaluated string literal}} "0\x123" // expected-error {{invalid escape sequence '\x123' in an unevaluated string literal}} "fx\xfffff" // expected-error {{invalid escape sequence '\xfffff' in an unevaluated string literal}} "goop"); static_assert(false, "\'\"\?\\\a\b\f\n\r\t\v"); // expected-error {{'"?\}} static_assert(true, "\xFF"); // expected-error {{invalid escape sequence '\xFF' in an unevaluated string literal}} static_assert(true, "\123"); // expected-error {{invalid escape sequence '\123' in an unevaluated string literal}} static_assert(true, "\pOh no, a Pascal string!"); // expected-warning {{unknown escape sequence '\p'}} \ // expected-error {{invalid escape sequence '\p' in an unevaluated string literal}} static_assert(false, R"(a \tb c )"); // expected-error@-3 {{static assertion failed: a\n\tb\nc\n}} static_assert(false, "\u0080\u0081\u0082\u0083\u0099\u009A\u009B\u009C\u009D\u009E\u009F"); // expected-error@-1 {{static assertion failed: }} //! Contains RTL/LTR marks static_assert(false, "\u200Eabc\u200Fdef\u200Fgh"); // expected-error {{static assertion failed: ‎abc‏def‏gh}} //! Contains ZWJ/regional indicators static_assert(false, "🏳️‍🌈 🏴󠁧󠁢󠁥󠁮󠁧󠁿 🇪🇺"); // expected-error {{static assertion failed: 🏳️‍🌈 🏴󠁧󠁢󠁥󠁮󠁧󠁿 🇪🇺}} template struct AlwaysFails { // Only give one error here. static_assert(false, ""); // expected-error 2{{static assertion failed}} }; AlwaysFails alwaysFails; // expected-note {{instantiation}} AlwaysFails alwaysFails2; // expected-note {{instantiation}} template struct StaticAssertProtected { static_assert(__is_literal(T), ""); // expected-error {{static assertion failed}} static constexpr T t = {}; // no error here }; struct X { ~X(); }; StaticAssertProtected sap1; StaticAssertProtected sap2; // expected-note {{instantiation}} static_assert(true); // expected-warning {{C++17 extension}} static_assert(false); // expected-error-re {{failed{{$}}}} expected-warning {{extension}} // Diagnostics for static_assert with multiple conditions template struct first_trait { static const bool value = false; }; template<> struct first_trait { static const bool value = true; }; template struct second_trait { static const bool value = false; }; static_assert(first_trait::value && second_trait::value, "message"); // expected-error{{static assertion failed due to requirement 'second_trait::value': message}} namespace std { template struct integral_constant { static const Tp value = v; typedef Tp value_type; typedef integral_constant type; constexpr operator value_type() const noexcept { return value; } constexpr value_type operator()() const noexcept { return value; } }; template const Tp integral_constant::value; typedef integral_constant true_type; typedef integral_constant false_type; template struct is_const : public false_type {}; template struct is_const : public true_type {}; // We do not define is_same in terms of integral_constant to check that both implementations are supported. template struct is_same { static const bool value = false; }; template struct is_same { static const bool value = true; }; } // namespace std struct ExampleTypes { explicit ExampleTypes(int); using T = int; using U = float; }; static_assert(std::is_same::value, "message"); // expected-error@-1{{static assertion failed due to requirement 'std::is_same::value': message}} static_assert(std::is_const::value, "message"); // expected-error@-1{{static assertion failed due to requirement 'std::is_const::value': message}} static_assert(!std::is_const::value, "message"); // expected-error@-1{{static assertion failed due to requirement '!std::is_const::value': message}} static_assert(!(std::is_const::value), "message"); // expected-error@-1{{static assertion failed due to requirement '!(std::is_const::value)': message}} static_assert(std::is_const::value == false, "message"); // expected-error@-1{{static assertion failed due to requirement 'std::is_const::value == false': message}} static_assert(!(std::is_const::value == true), "message"); // expected-error@-1{{static assertion failed due to requirement '!(std::is_const::value == true)': message}} static_assert(std::is_const(), "message"); // expected-error@-1{{static assertion failed due to requirement 'std::is_const()': message}} static_assert(!(std::is_const()()), "message"); // expected-error@-1{{static assertion failed due to requirement '!(std::is_const()())': message}} static_assert(std::is_same()), int>::value, "message"); // expected-error@-1{{static assertion failed due to requirement 'std::is_same, int>::value': message}} static_assert(std::is_const::value, "message"); // expected-error@-1{{static assertion failed due to requirement 'std::is_const::value': message}} static_assert(std::is_const::value, "message"); // expected-error@-1{{static assertion failed due to requirement 'std::is_const::value': message}} static_assert(std::is_const::value, "message"); // expected-error@-1{{static assertion failed due to requirement 'std::is_const::value': message}} struct BI_tag {}; struct RAI_tag : BI_tag {}; struct MyIterator { using tag = BI_tag; }; struct MyContainer { using iterator = MyIterator; }; template void foo() { static_assert(std::is_same::value, "message"); // expected-error@-1{{static assertion failed due to requirement 'std::is_same::value': message}} } template void foo(); // expected-note@-1{{in instantiation of function template specialization 'foo' requested here}} namespace ns { template struct NestedTemplates1 { struct NestedTemplates2 { template struct NestedTemplates3 : public std::is_same {}; }; }; } // namespace ns template void foo2() { static_assert(::ns::NestedTemplates1::NestedTemplates2::template NestedTemplates3::value, "message"); // expected-error@-1{{static assertion failed due to requirement '::ns::NestedTemplates1::NestedTemplates2::NestedTemplates3::value': message}} } template void foo2(); // expected-note@-1{{in instantiation of function template specialization 'foo2' requested here}} template void foo3(T t) { static_assert(std::is_const::value, "message"); // expected-error-re@-1{{static assertion failed due to requirement 'std::is_const<(lambda at {{.*}}static-assert.cpp:{{[0-9]*}}:{{[0-9]*}})>::value': message}} static_assert(std::is_const::value, "message"); // expected-error-re@-1{{static assertion failed due to requirement 'std::is_const<(lambda at {{.*}}static-assert.cpp:{{[0-9]*}}:{{[0-9]*}})>::value': message}} } void callFoo3() { foo3([]() {}); // expected-note@-1{{in instantiation of function template specialization 'foo3<(lambda at }} } template void foo4(T t) { static_assert(std::is_const::value, "message"); // expected-error@-1{{type 'int' cannot be used prior to '::' because it has no members}} } void callFoo4() { foo4(42); } // expected-note@-1{{in instantiation of function template specialization 'foo4' requested here}} static_assert(42, "message"); static_assert(42.0, "message"); // expected-warning {{implicit conversion from 'double' to 'bool' changes value from 42 to true}} constexpr int *p = 0; static_assert(p, "message"); // expected-error {{static assertion failed}} struct NotBool { } notBool; constexpr NotBool constexprNotBool; static_assert(notBool, "message"); // expected-error {{value of type 'struct NotBool' is not contextually convertible to 'bool'}} static_assert(constexprNotBool, "message"); // expected-error {{value of type 'const NotBool' is not contextually convertible to 'bool'}} static_assert(1 , "") // expected-error {{expected ';' after 'static_assert'}} namespace DependentAlwaysFalse { template struct S { static_assert(false); // expected-error{{static assertion failed}} \ // expected-warning {{C++17 extension}} }; template struct T { static_assert(false, "test"); // expected-error{{static assertion failed: test}} }; int f() { S s; //expected-note {{in instantiation of template class 'DependentAlwaysFalse::S' requested here}} T t; //expected-note {{in instantiation of template class 'DependentAlwaysFalse::T' requested here}} } } namespace Diagnostics { /// No notes for literals. static_assert(false, ""); // expected-error {{failed}} static_assert(1.0 > 2.0, ""); // expected-error {{failed}} static_assert('c' == 'd', ""); // expected-error {{failed}} static_assert(1 == 2, ""); // expected-error {{failed}} /// Simple things are ignored. static_assert(1 == (-(1)), ""); //expected-error {{failed}} /// Chars are printed as chars. constexpr char getChar() { return 'c'; } static_assert(getChar() == 'a', ""); // expected-error {{failed}} \ // expected-note {{evaluates to ''c' (0x63, 99) == 'a' (0x61, 97)'}} static_assert((char)9 == '\x61', ""); // expected-error {{failed}} \ // expected-note {{evaluates to ''\t' (0x09, 9) == 'a' (0x61, 97)'}} static_assert((char)10 == '\0', ""); // expected-error {{failed}} \ // expected-note {{n' (0x0A, 10) == '' (0x00, 0)'}} // The note above is intended to match "evaluates to '\n' (0x0A, 10) == '' (0x00, 0)'", but if we write it as it is, // the "\n" cannot be consumed by the diagnostic consumer. static_assert((signed char)10 == (char)-123, ""); // expected-error {{failed}} \ // expected-note {{evaluates to '10 == '<85>' (0x85, -123)'}} static_assert((char)-4 == (unsigned char)-8, ""); // expected-error {{failed}} \ // expected-note {{evaluates to ''' (0xFC, -4) == 248'}} static_assert((char)-128 == (char)-123, ""); // expected-error {{failed}} \ // expected-note {{evaluates to ''<80>' (0x80, -128) == '<85>' (0x85, -123)'}} static_assert('\xA0' == (char)'\x20', ""); // expected-error {{failed}} \ // expected-note {{evaluates to ''' (0xA0, -96) == ' ' (0x20, 32)'}} static_assert((char16_t)L'ゆ' == L"C̵̭̯̠̎͌ͅť̺"[1], ""); // expected-error {{failed}} \ // expected-note {{evaluates to 'u'ゆ' (0x3086, 12422) == L'̵' (0x335, 821)'}} static_assert(L"\/"[1] == u'\xFFFD', ""); // expected-error {{failed}} \ // expected-note {{evaluates to 'L'/' (0xFF0F, 65295) == u'�' (0xFFFD, 65533)'}} static_assert(L"⚾"[0] == U'🌍', ""); // expected-error {{failed}} \ // expected-note {{evaluates to 'L'⚾' (0x26BE, 9918) == U'🌍' (0x1F30D, 127757)'}} static_assert(U"\a"[0] == (wchar_t)9, ""); // expected-error {{failed}} \ // expected-note {{evaluates to 'U'\a' (0x07, 7) == L'\t' (0x09, 9)'}} static_assert(L"§"[0] == U'Ö', ""); // expected-error {{failed}} \ // expected-note {{evaluates to 'L'§' (0xA7, 167) == U'Ö' (0xD6, 214)'}} /// Bools are printed as bools. constexpr bool invert(bool b) { return !b; } static_assert(invert(true) || invert(true), ""); // expected-error {{static assertion failed due to requirement 'invert(true) || invert(true)'}} static_assert(invert(true) == invert(false), ""); // expected-error {{static assertion failed due to requirement 'invert(true) == invert(false)'}} \ // expected-note {{evaluates to 'false == true'}} static_assert(true && false, ""); // expected-error {{static assertion failed due to requirement 'true && false'}} static_assert(invert(true) || invert(true) || false, ""); // expected-error {{static assertion failed due to requirement 'invert(true) || invert(true) || false'}} static_assert((true && invert(true)) || false, ""); // expected-error {{static assertion failed due to requirement '(true && invert(true)) || false'}} static_assert(true && invert(false) && invert(true), ""); // expected-error {{static assertion failed due to requirement 'invert(true)'}} /// No notes here since we compare a bool expression with a bool literal. static_assert(invert(true) == true, ""); // expected-error {{failed}} #pragma clang diagnostic push #pragma clang diagnostic ignored "-Wc99-extensions" constexpr _Complex float com = {5,6}; constexpr _Complex float com2 = {1, 9}; static_assert(com == com2, ""); // expected-error {{failed}} \ // expected-note {{evaluates to '(5 + 6i) == (1 + 9i)'}} #pragma clang diagnostic pop #define CHECK_4(x) ((x) == 4) #define A_IS_B (a == b) static_assert(CHECK_4(5), ""); // expected-error {{failed}} constexpr int a = 4; constexpr int b = 5; static_assert(CHECK_4(a) && A_IS_B, ""); // expected-error {{failed}} \ // expected-note {{evaluates to '4 == 5'}} static_assert( false, // expected-error {{static assertion failed}} "" ); static_assert( true && false, // expected-error {{static assertion failed due to requirement 'true && false'}} "" ); static_assert( // with a comment here true && false, // expected-error {{static assertion failed due to requirement 'true && false'}} "" ); static_assert( // with a comment here (true && // expected-error {{static assertion failed due to requirement '(true && false) || false'}} false) || false, "" ); static_assert(1 + 1 != 2, ""); // expected-error {{failed}} \ // expected-note {{evaluates to '2 != 2'}} static_assert(1 - 1 == 2, ""); // expected-error {{failed}} \ // expected-note {{evaluates to '0 == 2'}} static_assert(1 * 1 == 2, ""); // expected-error {{failed}} \ // expected-note {{evaluates to '1 == 2'}} static_assert(1 / 1 == 2, ""); // expected-error {{failed}} \ // expected-note {{evaluates to '1 == 2'}} static_assert(1 << 3 != 8, ""); // expected-error {{failed}} \ // expected-note {{evaluates to '8 != 8'}} }