forked from OSchip/llvm-project
Allow transformation of VariableArray to ConstantArray.
In the following code: struct A { static const int sz; }; template<class T> void f() { T arr[A::sz]; } the array 'arr' is represented as a variable size array in the template. If 'A::sz' gets value below in the translation unit, the array in instantiation can turn into constant size array. This change fixes PR18633. Differential Revision: http://llvm-reviews.chandlerc.com/D2688 llvm-svn: 200899
This commit is contained in:
parent
d461244972
commit
774c6d03b2
|
@ -3929,7 +3929,9 @@ TreeTransform<Derived>::TransformVariableArrayType(TypeLocBuilder &TLB,
|
|||
return QualType();
|
||||
}
|
||||
|
||||
VariableArrayTypeLoc NewTL = TLB.push<VariableArrayTypeLoc>(Result);
|
||||
// We might have constant size array now, but fortunately it has the same
|
||||
// location layout.
|
||||
ArrayTypeLoc NewTL = TLB.push<ArrayTypeLoc>(Result);
|
||||
NewTL.setLBracketLoc(TL.getLBracketLoc());
|
||||
NewTL.setRBracketLoc(TL.getRBracketLoc());
|
||||
NewTL.setSizeExpr(Size);
|
||||
|
|
|
@ -140,3 +140,24 @@ namespace PR11744 {
|
|||
}
|
||||
int test = f<int>(0); // expected-note {{instantiation of}}
|
||||
}
|
||||
|
||||
namespace pr18633 {
|
||||
struct A1 {
|
||||
static const int sz;
|
||||
static const int sz2;
|
||||
};
|
||||
const int A1::sz2 = 11;
|
||||
template<typename T>
|
||||
void func () {
|
||||
int arr[A1::sz]; // expected-warning{{variable length arrays are a C99 feature}}
|
||||
}
|
||||
template<typename T>
|
||||
void func2 () {
|
||||
int arr[A1::sz2];
|
||||
}
|
||||
const int A1::sz = 12;
|
||||
void func2() {
|
||||
func<int>();
|
||||
func2<int>();
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue