diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2012-01-25 22:19:07 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2012-01-25 22:19:07 +0000 |
commit | f7f102f81a6516ea0e47370959a388eaa5f16c3c (patch) | |
tree | afa2bf51228045e20346da881f7e59fc84116dec | |
parent | 807f7e38a94e19371f0cd6966a0e5590184287ee (diff) | |
download | bcm5719-llvm-f7f102f81a6516ea0e47370959a388eaa5f16c3c.tar.gz bcm5719-llvm-f7f102f81a6516ea0e47370959a388eaa5f16c3c.zip |
Fix a crash involving a multi-dimensional dependent VLA. PR11744.
llvm-svn: 148989
-rw-r--r-- | clang/lib/Sema/TreeTransform.h | 8 | ||||
-rw-r--r-- | clang/test/SemaCXX/c99-variable-length-array.cpp | 8 |
2 files changed, 14 insertions, 2 deletions
diff --git a/clang/lib/Sema/TreeTransform.h b/clang/lib/Sema/TreeTransform.h index f5fc3b7cb84..5d761d382a7 100644 --- a/clang/lib/Sema/TreeTransform.h +++ b/clang/lib/Sema/TreeTransform.h @@ -3593,8 +3593,12 @@ TreeTransform<Derived>::TransformConstantArrayType(TypeLocBuilder &TLB, if (Result.isNull()) return QualType(); } - - ConstantArrayTypeLoc NewTL = TLB.push<ConstantArrayTypeLoc>(Result); + + // We might have either a ConstantArrayType or a VariableArrayType now: + // a ConstantArrayType is allowed to have an element type which is a + // VariableArrayType if the type is dependent. Fortunately, all array + // types have the same location layout. + ArrayTypeLoc NewTL = TLB.push<ArrayTypeLoc>(Result); NewTL.setLBracketLoc(TL.getLBracketLoc()); NewTL.setRBracketLoc(TL.getRBracketLoc()); diff --git a/clang/test/SemaCXX/c99-variable-length-array.cpp b/clang/test/SemaCXX/c99-variable-length-array.cpp index 37115abc68e..2f9bb957ec0 100644 --- a/clang/test/SemaCXX/c99-variable-length-array.cpp +++ b/clang/test/SemaCXX/c99-variable-length-array.cpp @@ -130,3 +130,11 @@ static const int k_cVal3 = (int)(1000*0.2f); char rgch[k_cVal3] = {0}; } } + +namespace PR11744 { + template<typename T> int f(int n) { + T arr[3][n]; // expected-warning 3 {{variable length arrays are a C99 feature}} + return 3; + } + int test = f<int>(0); // expected-note {{instantiation of}} +} |