Fix <rdar://problem/5733511> clang doesn't emit error for const array.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@46905 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Steve Naroff 2008-02-09 16:59:44 +00:00
Родитель 472778eb4f
Коммит 336ed0b79b
2 изменённых файлов: 19 добавлений и 2 удалений

Просмотреть файл

@ -904,8 +904,17 @@ void Sema::DefaultFunctionArrayConversion(Expr *&e) {
}
if (t->isFunctionType())
ImpCastExprToType(e, Context.getPointerType(t));
else if (const ArrayType *ary = t->getAsArrayType())
ImpCastExprToType(e, Context.getPointerType(ary->getElementType()));
else if (const ArrayType *ary = t->getAsArrayType()) {
// Make sure we don't loose qualifiers when dealing with typedefs. Example:
// typedef int arr[10];
// void test2() {
// const arr b;
// b[4] = 1;
// }
QualType ELT = ary->getElementType();
ELT = ELT.getQualifiedType(t.getQualifiers()|ELT.getQualifiers());
ImpCastExprToType(e, Context.getPointerType(ELT));
}
}
/// UsualUnaryConversions - Performs various conversions that are common to most

Просмотреть файл

@ -5,3 +5,11 @@ void *test1(void) { return 0; }
void test2 (const struct {int a;} *x) {
x->a = 10; // expected-error {{read-only variable is not assignable}}
}
typedef int arr[10];
void test3() {
const arr b;
const int b2[10];
b[4] = 1; // expected-error {{read-only variable is not assignable}}
b2[4] = 1; // expected-error {{read-only variable is not assignable}}
}