2011-10-17 02:19:28 +08:00
|
|
|
// RUN: %clang_cc1 -std=c++0x -fsyntax-only -verify %s
|
|
|
|
|
2011-11-01 23:53:09 +08:00
|
|
|
struct one { char c[1]; };
|
|
|
|
struct two { char c[2]; };
|
|
|
|
|
2011-10-17 02:19:28 +08:00
|
|
|
namespace aggregate {
|
|
|
|
// Direct list initialization does NOT allow braces to be elided!
|
|
|
|
struct S {
|
|
|
|
int ar[2];
|
|
|
|
struct T {
|
|
|
|
int i1;
|
|
|
|
int i2;
|
|
|
|
} t;
|
|
|
|
struct U {
|
|
|
|
int i1;
|
|
|
|
} u[2];
|
|
|
|
struct V {
|
|
|
|
int var[2];
|
|
|
|
} v;
|
|
|
|
};
|
|
|
|
|
2011-11-01 23:53:09 +08:00
|
|
|
void bracing() {
|
2011-10-17 02:19:28 +08:00
|
|
|
S s1 = { 1, 2, 3 ,4, 5, 6, 7, 8 }; // no-error
|
|
|
|
S s2{ {1, 2}, {3, 4}, { {5}, {6} }, { {7, 8} } }; // completely braced
|
|
|
|
S s3{ 1, 2, 3, 4, 5, 6 }; // expected-error 5 {{cannot omit braces}}
|
|
|
|
S s4{ {1, 2}, {3, 4}, {5, 6}, { {7, 8} } }; // expected-error 2 {{cannot omit braces}}
|
|
|
|
S s5{ {1, 2}, {3, 4}, { {5}, {6} }, {7, 8} }; // expected-error {{cannot omit braces}}
|
|
|
|
}
|
2011-11-01 23:53:09 +08:00
|
|
|
|
2012-02-13 02:41:05 +08:00
|
|
|
void bracing_new() {
|
|
|
|
new S{ {1, 2}, {3, 4}, { {5}, {6} }, { {7, 8} } }; // completely braced
|
|
|
|
new S{ 1, 2, 3, 4, 5, 6 }; // expected-error 5 {{cannot omit braces}}
|
|
|
|
new S{ {1, 2}, {3, 4}, {5, 6}, { {7, 8} } }; // expected-error 2 {{cannot omit braces}}
|
|
|
|
new S{ {1, 2}, {3, 4}, { {5}, {6} }, {7, 8} }; // expected-error {{cannot omit braces}}
|
|
|
|
}
|
|
|
|
|
2012-02-14 03:55:43 +08:00
|
|
|
void bracing_construct() {
|
|
|
|
(void) S{ {1, 2}, {3, 4}, { {5}, {6} }, { {7, 8} } }; // completely braced
|
|
|
|
(void) S{ 1, 2, 3, 4, 5, 6 }; // expected-error 5 {{cannot omit braces}}
|
|
|
|
(void) S{ {1, 2}, {3, 4}, {5, 6}, { {7, 8} } }; // expected-error 2 {{cannot omit braces}}
|
|
|
|
(void) S{ {1, 2}, {3, 4}, { {5}, {6} }, {7, 8} }; // expected-error {{cannot omit braces}}
|
|
|
|
}
|
|
|
|
|
2011-11-01 23:53:09 +08:00
|
|
|
struct String {
|
|
|
|
String(const char*);
|
|
|
|
};
|
|
|
|
|
|
|
|
struct A {
|
|
|
|
int m1;
|
|
|
|
int m2;
|
|
|
|
};
|
|
|
|
|
|
|
|
void function_call() {
|
|
|
|
void takes_A(A);
|
|
|
|
takes_A({1, 2});
|
|
|
|
}
|
|
|
|
|
|
|
|
struct B {
|
|
|
|
int m1;
|
|
|
|
String m2;
|
|
|
|
};
|
|
|
|
|
|
|
|
void overloaded_call() {
|
|
|
|
one overloaded(A);
|
|
|
|
two overloaded(B);
|
|
|
|
|
|
|
|
static_assert(sizeof(overloaded({1, 2})) == sizeof(one), "bad overload");
|
|
|
|
static_assert(sizeof(overloaded({1, "two"})) == sizeof(two),
|
|
|
|
"bad overload");
|
|
|
|
// String is not default-constructible
|
|
|
|
static_assert(sizeof(overloaded({1})) == sizeof(one), "bad overload");
|
|
|
|
}
|
2012-02-13 00:37:36 +08:00
|
|
|
|
2012-02-16 08:54:02 +08:00
|
|
|
struct C { int a[2]; C():a({1, 2}) { } }; // expected-error {{parenthesized initialization of a member array is a GNU extension}}
|
2011-10-17 02:19:28 +08:00
|
|
|
}
|
2012-02-29 08:00:28 +08:00
|
|
|
|
|
|
|
namespace array_explicit_conversion {
|
|
|
|
typedef int test1[2];
|
|
|
|
typedef int test2[];
|
|
|
|
template<int x> struct A { int a[x]; }; // expected-error {{'a' declared as an array with a negative size}}
|
|
|
|
typedef A<1> test3[];
|
|
|
|
typedef A<-1> test4[];
|
|
|
|
void f() {
|
|
|
|
(void)test1{1};
|
|
|
|
(void)test2{1};
|
|
|
|
(void)test3{{{1}}};
|
|
|
|
(void)test4{{{1}}}; // expected-note {{in instantiation of template class 'array_explicit_conversion::A<-1>' requested here}}
|
|
|
|
}
|
|
|
|
}
|
2012-07-07 16:35:56 +08:00
|
|
|
|
|
|
|
namespace sub_constructor {
|
|
|
|
struct DefaultConstructor { // expected-note 2 {{not viable}}
|
|
|
|
DefaultConstructor(); // expected-note {{not viable}}
|
|
|
|
int x;
|
|
|
|
};
|
|
|
|
struct NoDefaultConstructor1 { // expected-note 2 {{not viable}}
|
|
|
|
NoDefaultConstructor1(int); // expected-note {{not viable}}
|
|
|
|
int x;
|
|
|
|
};
|
|
|
|
struct NoDefaultConstructor2 { // expected-note 4 {{not viable}}
|
|
|
|
NoDefaultConstructor2(int,int); // expected-note 2 {{not viable}}
|
|
|
|
int x;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Aggr {
|
|
|
|
DefaultConstructor a;
|
|
|
|
NoDefaultConstructor1 b;
|
|
|
|
NoDefaultConstructor2 c;
|
|
|
|
};
|
|
|
|
|
|
|
|
Aggr ok1 { {}, {0} , {0,0} };
|
|
|
|
Aggr ok2 = { {}, {0} , {0,0} };
|
|
|
|
Aggr too_many { {0} , {0} , {0,0} }; // expected-error {{no matching constructor for initialization}}
|
|
|
|
Aggr too_few { {} , {0} , {0} }; // expected-error {{no matching constructor for initialization}}
|
|
|
|
Aggr invalid { {} , {&ok1} , {0,0} }; // expected-error {{no matching constructor for initialization}}
|
|
|
|
NoDefaultConstructor2 array_ok[] = { {0,0} , {0,1} };
|
|
|
|
NoDefaultConstructor2 array_error[] = { {0,0} , {0} }; // expected-error {{no matching constructor for initialization}}
|
2012-12-09 14:48:56 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace multidimensional_array {
|
|
|
|
void g(const int (&)[2][2]) {}
|
|
|
|
void g(const int (&)[2][2][2]) = delete;
|
|
|
|
|
|
|
|
void h() {
|
|
|
|
g({{1,2},{3,4}});
|
|
|
|
}
|
|
|
|
}
|
2013-02-02 10:14:45 +08:00
|
|
|
|
|
|
|
namespace array_addressof {
|
|
|
|
using T = int[5];
|
|
|
|
T *p = &T{1,2,3,4,5}; // expected-error {{taking the address of a temporary object of type 'T' (aka 'int [5]')}}
|
|
|
|
}
|