// 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 <class P> struct S2 {
void (P::*a)(const int &);
};
void test_15() {
S2<S> 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')}}
}
}