| // RUN: %clang_cc1 -fsyntax-only -verify %s |
| // expected-error@-1{{cannot initialize a variable}} |
| void test1(int x = (void)0) {} |
| // expected-error@-1{{cannot initialize a parameter}} |
| // expected-note@-2{{here}} |
| // expected-error@-1{{cannot initialize return object}} |
| // expected-error@-1{{cannot initialize a member subobject}} |
| int foo[2] = {1, (void)0}; |
| // expected-error@-1{{cannot initialize an array element}} |
| // expected-error@-1{{cannot initialize a new value}} |
| typedef short short2 __attribute__ ((__vector_size__ (2))); |
| // 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 { |
| template <class P> struct S2 { |
| void (P::*a)(const int &); |
| // 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')}} |