// RUN: %clang_cc1 -fsyntax-only -verify %s // RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 %s // RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s char *const_cast_test(const char *var) { return const_cast<char*>(var); } struct A { virtual ~A() {} }; struct B : public A { }; struct B *dynamic_cast_test(struct A *a) { return dynamic_cast<struct B*>(a); } char *reinterpret_cast_test() { return reinterpret_cast<char*>(0xdeadbeef); } double static_cast_test(int i) { return static_cast<double>(i); } char postfix_expr_test() { return reinterpret_cast<char*>(0xdeadbeef)[0]; } // This was being incorrectly tentatively parsed. namespace test1 { template <class T> class A {}; // expected-note 2{{here}} void foo() { A<int>(*(A<int>*)0); } // expected-warning {{binding dereferenced null pointer to reference has undefined behavior}} } typedef char* c; typedef A* a; void test2(char x, struct B * b) { (void)const_cast<::c>(&x); #if __cplusplus <= 199711L // expected-error@-2 {{found '<::' after a const_cast which forms the digraph '<:' (aka '[') and a ':', did you mean '< ::'?}} #endif (void)dynamic_cast<::a>(b); #if __cplusplus <= 199711L // expected-error@-2 {{found '<::' after a dynamic_cast which forms the digraph '<:' (aka '[') and a ':', did you mean '< ::'?}} #endif (void)reinterpret_cast<::c>(x); #if __cplusplus <= 199711L // expected-error@-2 {{found '<::' after a reinterpret_cast which forms the digraph '<:' (aka '[') and a ':', did you mean '< ::'?}} #endif (void)static_cast<::c>(&x); #if __cplusplus <= 199711L // expected-error@-2 {{found '<::' after a static_cast which forms the digraph '<:' (aka '[') and a ':', did you mean '< ::'?}} #endif // Do not do digraph correction. (void)static_cast<: :c>(&x); //\ expected-error {{expected '<' after 'static_cast'}} \ expected-error {{expected expression}}\ expected-error {{expected ']'}}\ expected-note {{to match this '['}} (void)static_cast<: // expected-error {{expected '<' after 'static_cast'}} \ expected-note {{to match this '['}} :c>(&x); // expected-error {{expected expression}} \ expected-error {{expected ']'}} #define LC <: #define C : test1::A LC:B> c; // expected-error {{class template 'test1::A' requires template arguments}} expected-error 2{{}} (void)static_cast LC:c>(&x); // expected-error {{expected '<' after 'static_cast'}} expected-error 2{{}} expected-note{{}} test1::A<:C B> d; // expected-error {{class template 'test1::A' requires template arguments}} expected-error 2{{}} (void)static_cast<:C c>(&x); // expected-error {{expected '<' after 'static_cast'}} expected-error 2{{}} expected-note{{}} #define LCC <:: test1::A LCC B> e; #if __cplusplus <= 199711L // expected-error@-2 {{found '<::' after a template name which forms the digraph '<:' (aka '[') and a ':', did you mean '< ::'?}} #endif (void)static_cast LCC c>(&x); #if __cplusplus <= 199711L // expected-error@-2 {{found '<::' after a static_cast which forms the digraph '<:' (aka '[') and a ':', did you mean '< ::'?}} #endif } // This note comes from "::D[:F> A5;" template <class T> class D {}; // expected-note{{template is declared here}} template <class T> void E() {}; class F {}; void test3() { ::D<::F> A1; #if __cplusplus <= 199711L // expected-error@-2 {{found '<::' after a template name which forms the digraph '<:' (aka '[') and a ':', did you mean '< ::'?}} #endif D<::F> A2; #if __cplusplus <= 199711L // expected-error@-2 {{found '<::' after a template name which forms the digraph '<:' (aka '[') and a ':', did you mean '< ::'?}} #endif ::E<::F>(); #if __cplusplus <= 199711L // expected-error@-2 {{found '<::' after a template name which forms the digraph '<:' (aka '[') and a ':', did you mean '< ::'?}} #endif E<::F>(); #if __cplusplus <= 199711L // expected-error@-2 {{found '<::' after a template name which forms the digraph '<:' (aka '[') and a ':', did you mean '< ::'?}} #endif ::D< ::F> A3; D< ::F> A4; ::E< ::F>(); E< ::F>(); // Make sure that parser doesn't expand '[:' to '< ::' ::D[:F> A5; // expected-error {{class template '::D' requires template arguments}} \ // expected-error {{expected expression}} \ // expected-error {{expected unqualified-id}} } // Ensure that a C-style cast doesn't turn off colon protection. void PR19748() { struct A {}; int A = 0, b; int test1 = true ? (int)A : b; struct f {}; extern B f(), (*p)(); (true ? (B(*)())f : p)(); } void PR19751(int n) { struct T { void operator++(int); }; (T())++; // ok, not an ill-formed cast to function type (T())++n; // expected-error {{C-style cast from 'int' to 'T ()' is not allowed}} } // PR13619. Must be at end of file. int n = reinterpret_cast // expected-error {{expected '<'}} expected-error {{expected ';'}}