// RUN: %clang_cc1 -fsyntax-only -verify %s void test0() { char variable = (void)0; // expected-error@-1{{cannot initialize a variable}} } void test1(int x = (void)0) {} // expected-error@-1{{cannot initialize a parameter}} // expected-note@-2{{here}} int test2() { return (void)0; // expected-error@-1{{cannot initialize return object}} } struct S4 { S4() : x((void)0) {}; // expected-error@-1{{cannot initialize a member subobject}} int x; }; void test5() { int foo[2] = {1, (void)0}; // expected-error@-1{{cannot initialize an array element}} } void test6() { new int((void)0); // expected-error@-1{{cannot initialize a new value}} } typedef short short2 __attribute__ ((__vector_size__ (2))); void test10() { short2 V = { (void)0 }; // expected-error@-1{{cannot initialize a vector element}} } typedef float float2 __attribute__((ext_vector_type(2))); typedef float float4 __attribute__((ext_vector_type(4))); void test14(const float2 in, const float2 out) { const float4 V = (float4){ in, out }; // expected-error@-1{{cannot initialize a compound literal initializer}} } namespace template_test { class S { public: void foo(int); }; template struct S2 { void (P::*a)(const int &); }; void test_15() { S2 X = {&S::foo}; // expected-error-re@-1{{cannot initialize a member subobject of type 'void (template_test::S::*)(const int &){{( __attribute__\(\(thiscall\)\))?}}' with an rvalue of type 'void (template_test::S::*)(int){{( __attribute__\(\(thiscall\)\))?}}': type mismatch at 1st parameter ('const int &' vs 'int')}} } }