// RUN: %clang_cc1 %s -pedantic -ast-dump -verify | FileCheck %s
__constant int g1; // expected-error {{variable in constant address space must be initialized}}
__constant int g2 = 0;
struct X {
int x;
//CHECK: CXXConstructorDecl
//CHECK-NOT: used
//CHECK-SAME: X 'void (){{.*}} __generic'
X() /*__generic*/ : x(0) {}
//CHECK: CXXConstructorDecl {{.*}} used X 'void (){{.*}} __private'
X() __private : x(0) {}
//CHECK: CXXConstructorDecl {{.*}} used X 'void (){{.*}} __global'
X() __global : x(0) {}
constexpr X() __constant : x(0) {}
constexpr X(int x) __constant : x(x) {}
};
__global X gx;
//expected-note@+2{{candidate constructor (the implicit copy constructor) not viable: no known conversion from 'int' to 'const __generic Y' for 1st argument}}
//expected-note@+1{{candidate constructor (the implicit move constructor) not viable: no known conversion from 'int' to '__generic Y' for 1st argument}}
struct Y {
int y;
Y() __generic = default; // expected-note{{candidate constructor not viable: requires 0 arguments, but 1 was provided}}
};
kernel void k() {
__constant X cx1;
__constant X cx2(1);
__local X lx;
__private X x;
__private X tx = X();
__private Y py;
__constant Y cy1; // expected-error{{variable in constant address space must be initialized}}
__constant Y cy2(1); // expected-error{{no matching constructor for initialization of '__constant Y'}}
}
struct Z {
int z;
// The address space is deduced to be __generic if omitted
Z() = default; // expected-note{{previous definition is here}}
Z() __generic = default; // expected-error {{constructor cannot be redeclared}}
Z() __private = default;
Z() __local = default;
Z() __global = default;
// Can't default constexpr constructors
constexpr Z() __constant : z(0) {}
};
struct W {
int w;
constexpr W() __constant = default; // expected-error {{defaulted definition of default constructor cannot be marked constexpr}}
};