diff options
| author | John McCall <rjmccall@apple.com> | 2012-01-11 00:14:46 +0000 | 
|---|---|---|
| committer | John McCall <rjmccall@apple.com> | 2012-01-11 00:14:46 +0000 | 
| commit | 9b80c2186f5ecdd25436adc513e4d18e81f18049 (patch) | |
| tree | 1219070e86858a8d19c4ad2c4b9de7054356d42d | |
| parent | c79155192d25a35cfbae5d9d474aa24713be8098 (diff) | |
| download | bcm5719-llvm-9b80c2186f5ecdd25436adc513e4d18e81f18049.tar.gz bcm5719-llvm-9b80c2186f5ecdd25436adc513e4d18e81f18049.zip | |
Do placeholder conversions on array bounds in both declarators and
new-expressions.
llvm-svn: 147900
| -rw-r--r-- | clang/lib/Sema/SemaExprCXX.cpp | 11 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaType.cpp | 7 | ||||
| -rw-r--r-- | clang/test/SemaObjC/property.m | 7 | ||||
| -rw-r--r-- | clang/test/SemaObjCXX/properties.mm | 9 | 
4 files changed, 30 insertions, 4 deletions
| diff --git a/clang/lib/Sema/SemaExprCXX.cpp b/clang/lib/Sema/SemaExprCXX.cpp index 5e7fb33d054..d4efa78b237 100644 --- a/clang/lib/Sema/SemaExprCXX.cpp +++ b/clang/lib/Sema/SemaExprCXX.cpp @@ -1010,10 +1010,13 @@ Sema::BuildCXXNew(SourceLocation StartLoc, bool UseGlobal,    // C++ 5.3.4p6: "The expression in a direct-new-declarator shall have integral    //   or enumeration type with a non-negative value."    if (ArraySize && !ArraySize->isTypeDependent()) { +    // Eliminate placeholders. +    ExprResult ConvertedSize = CheckPlaceholderExpr(ArraySize); +    if (ConvertedSize.isInvalid()) +      return ExprError(); +    ArraySize = ConvertedSize.take(); -    QualType SizeType = ArraySize->getType(); - -    ExprResult ConvertedSize = ConvertToIntegralOrEnumerationType( +    ConvertedSize = ConvertToIntegralOrEnumerationType(        StartLoc, ArraySize,        PDiag(diag::err_array_size_not_integral),        PDiag(diag::err_array_size_incomplete_type) @@ -1029,7 +1032,7 @@ Sema::BuildCXXNew(SourceLocation StartLoc, bool UseGlobal,        return ExprError();      ArraySize = ConvertedSize.take(); -    SizeType = ArraySize->getType(); +    QualType SizeType = ArraySize->getType();      if (!SizeType->isIntegralOrUnscopedEnumerationType())        return ExprError(); diff --git a/clang/lib/Sema/SemaType.cpp b/clang/lib/Sema/SemaType.cpp index 3bdb3b6d2c9..654bed270bf 100644 --- a/clang/lib/Sema/SemaType.cpp +++ b/clang/lib/Sema/SemaType.cpp @@ -1267,6 +1267,13 @@ QualType Sema::BuildArrayType(QualType T, ArrayType::ArraySizeModifier ASM,      return QualType();    } +  // Do placeholder conversions on the array size expression. +  if (ArraySize && ArraySize->hasPlaceholderType()) { +    ExprResult Result = CheckPlaceholderExpr(ArraySize); +    if (Result.isInvalid()) return QualType(); +    ArraySize = Result.take(); +  } +    // Do lvalue-to-rvalue conversions on the array size expression.    if (ArraySize && !ArraySize->isRValue()) {      ExprResult Result = DefaultLvalueConversion(ArraySize); diff --git a/clang/test/SemaObjC/property.m b/clang/test/SemaObjC/property.m index a43811d8242..29f84daef9c 100644 --- a/clang/test/SemaObjC/property.m +++ b/clang/test/SemaObjC/property.m @@ -74,3 +74,10 @@ Class test6_getClass();  + (float) globalValue { return 5.0f; }  + (float) gv { return test6_getClass().globalValue; }  @end + +@interface Test7 +@property unsigned length; +@end +void test7(Test7 *t) { +  char data[t.length] = {}; // expected-error {{variable-sized object may not be initialized}} +} diff --git a/clang/test/SemaObjCXX/properties.mm b/clang/test/SemaObjCXX/properties.mm index 0b9c63e30dc..1b6c0c54cdd 100644 --- a/clang/test/SemaObjCXX/properties.mm +++ b/clang/test/SemaObjCXX/properties.mm @@ -31,3 +31,12 @@ void test2(Test2 *a) {    auto y = a.y; // expected-error {{expected getter method not found on object of type 'Test2 *'}} expected-error {{variable 'y' with type 'auto' has incompatible initializer of type}}    auto z = a.z;  } + +// rdar://problem/10672108 +@interface Test3 +- (int) length; +@end +void test3(Test3 *t) { +  char vla[t.length] = {}; +  char *heaparray = new char[t.length]; // expected-error {{variable-sized object may not be initialized}} +} | 

