Add warning when a tentative array definition is assumed to have one element.

- Also, fixed one to actually be one (instead of zero). :)

llvm-svn: 69226
This commit is contained in:
Daniel Dunbar 2009-04-15 21:35:27 +00:00
parent bc8a78d5a4
commit c7ba533378
4 changed files with 8 additions and 5 deletions

View File

@ -944,6 +944,8 @@ def err_tentative_def_incomplete_type : Error<
"tentative definition has type %0 that is never completed">; "tentative definition has type %0 that is never completed">;
def err_tentative_def_incomplete_type_arr : Error< def err_tentative_def_incomplete_type_arr : Error<
"tentative definition has array of type %0 that is never completed">; "tentative definition has array of type %0 that is never completed">;
def warn_tentative_incomplete_array : Warning<
"tentative array definition assumed to have one element">;
def err_realimag_invalid_type : Error<"invalid type %0 to %1 operator">; def err_realimag_invalid_type : Error<"invalid type %0 to %1 operator">;
def err_typecheck_sclass_fscope : Error< def err_typecheck_sclass_fscope : Error<

View File

@ -253,8 +253,9 @@ void Sema::ActOnEndOfTranslationUnit() {
VD->setInvalidDecl(); VD->setInvalidDecl();
else { else {
// Set the length of the array to 1 (C99 6.9.2p5). // Set the length of the array to 1 (C99 6.9.2p5).
llvm::APSInt One(Context.getTypeSize(Context.getSizeType()), Diag(VD->getLocation(), diag::warn_tentative_incomplete_array);
true); llvm::APInt One(Context.getTypeSize(Context.getSizeType()),
true);
QualType T QualType T
= Context.getConstantArrayType(ArrayT->getElementType(), = Context.getConstantArrayType(ArrayT->getElementType(),
One, ArrayType::Normal, 0); One, ArrayType::Normal, 0);

View File

@ -1,7 +1,7 @@
// RUN: clang-cc -fsyntax-only -verify -pedantic -fblocks %s // RUN: clang-cc -fsyntax-only -verify -pedantic -fblocks %s
// PR2241 // PR2241
float test2241[] = { float test2241[2] = {
1e, // expected-error {{exponent}} 1e, // expected-error {{exponent}}
1ee0 // expected-error {{exponent}} 1ee0 // expected-error {{exponent}}
}; };

View File

@ -11,7 +11,7 @@ static struct foo g; // expected-error {{variable has incomplete type 'struct f
extern void d; extern void d;
extern struct foo e; extern struct foo e;
int ary[]; int ary[]; // expected-warning {{tentative array definition assumed to have one element}}
struct foo bary[]; // expected-error {{array has incomplete element type 'struct foo'}} struct foo bary[]; // expected-error {{array has incomplete element type 'struct foo'}}
void func() { void func() {
@ -20,7 +20,7 @@ void func() {
struct foo f; // expected-error {{variable has incomplete type 'struct foo'}} struct foo f; // expected-error {{variable has incomplete type 'struct foo'}}
} }
int h[]; int h[]; // expected-warning {{tentative array definition assumed to have one element}}
int (*i)[] = &h+1; // expected-error {{arithmetic on pointer to incomplete type 'int (*)[]'}} int (*i)[] = &h+1; // expected-error {{arithmetic on pointer to incomplete type 'int (*)[]'}}
struct bar j = {1}; // expected-error {{variable has incomplete type 'struct bar'}} \ struct bar j = {1}; // expected-error {{variable has incomplete type 'struct bar'}} \