1 // RUN: %clang_cc1 -fsyntax-only -verify -Wvla-extension %s
15 // expected-note@* 1+{{read of non-const variable}}
16 // expected-note@* 1+{{function parameter}}
17 // expected-note@* 1+{{declared here}}
19 // We allow VLAs of POD types, only.
21 int array1
[N
]; // expected-warning{{variable length arrays in C++ are a Clang extension}}
22 POD array2
[N
]; // expected-warning{{variable length arrays in C++ are a Clang extension}}
23 NonPOD array3
[N
]; // expected-warning{{variable length arrays in C++ are a Clang extension}}
24 NonPOD2 array4
[N
][3]; // expected-warning{{variable length arrays in C++ are a Clang extension}}
27 /// Warn about VLAs in templates.
29 void vla_in_template(int N
, T t
) {
30 int array1
[N
]; // expected-warning{{variable length arrays in C++ are a Clang extension}}
33 struct HasConstantValue
{
34 static const unsigned int value
= 2;
37 struct HasNonConstantValue
{
38 static unsigned int value
;
42 void vla_in_template(T t
) {
43 int array2
[T::value
]; // expected-warning{{variable length arrays in C++ are a Clang extension}}
46 template void vla_in_template
<HasConstantValue
>(HasConstantValue
);
47 template void vla_in_template
<HasNonConstantValue
>(HasNonConstantValue
); // expected-note{{instantiation of}}
49 template<typename T
> struct X0
{ };
51 // Cannot use any variably-modified type with a template parameter or
53 void inst_with_vla(int N
) {
54 int array
[N
]; // expected-warning{{variable length arrays in C++ are a Clang extension}}
55 X0
<__typeof__(array
)> x0a
; // expected-error{{variably modified type 'typeof (array)' (aka 'int[N]') cannot be used as a template argument}}
60 template<int (&Array
)[T::value
]> // expected-error{{non-type template parameter of variably modified type 'int (&)[HasNonConstantValue::value]'}} \
61 // expected-warning{{variable length arrays in C++ are a Clang extension}}
67 X1
<HasConstantValue
> x1a
;
68 X1
<HasNonConstantValue
> x1b
; // expected-note{{in instantiation of}}
70 // Template argument deduction does not allow deducing a size from a VLA.
71 // FIXME: This diagnostic should make it clear that the two 'N's are different entities!
72 template<typename T
, unsigned N
>
73 void accept_array(T (&array
)[N
]); // expected-note{{candidate template ignored: could not match 'T[N]' against 'int[N]'}}
75 void test_accept_array(int N
) {
76 int array
[N
]; // expected-warning{{variable length arrays in C++ are a Clang extension}}
77 accept_array(array
); // expected-error{{no matching function for call to 'accept_array'}}
80 // Variably-modified types cannot be used in local classes.
81 void local_classes(int N
) {
84 int array
[N
]; // expected-error{{fields must have a constant size: 'variable length array in structure' extension will never be supported}} \
85 // expected-error{{reference to local variable 'N' declared in enclosing function 'local_classes'}} \
86 // expected-warning{{variable length arrays in C++ are a Clang extension}}
96 struct edge_info edgeInfo
[x
]; // expected-warning{{variable length arrays in C++ are a Clang extension}}
100 namespace rdar8020206
{
103 const unsigned value
= i
;
104 int array
[value
* i
]; // expected-warning 2{{variable length arrays in C++ are a Clang extension}} expected-note 2{{initializer of 'value' is not a constant}}
107 template void f
<int>(int); // expected-note{{instantiation of}}
110 namespace rdar8021385
{
112 struct A
{ typedef int my_int
; };
115 typedef typename
T::my_int my_int
;
118 my_int a
[M
]; // expected-warning{{variable length arrays in C++ are a Clang extension}}
126 typedef int vla_type
[n
]; // expected-warning{{variable length arrays in C++ are a Clang extension}}
127 (void)new vla_type
; // expected-error{{variably}}
131 namespace rdar8733881
{
133 static const int k_cVal3
= (int)(1000*0.2f
);
135 // Ok, fold to a constant size array as an extension.
136 char rgch
[k_cVal3
] = {0};
141 template<typename T
> int f(int n
) {
142 T arr
[3][n
]; // expected-warning 3 {{variable length arrays in C++ are a Clang extension}}
145 int test
= f
<int>(0); // expected-note {{instantiation of}}
151 static const int sz2
;
153 const int A1::sz2
= 11;
156 int arr
[A1::sz
]; // expected-warning{{variable length arrays in C++ are a Clang extension}} expected-note {{initializer of 'sz' is unknown}}
162 const int A1::sz
= 12;