]> granicus.if.org Git - clang/commitdiff
Add warning when a tentative array definition is assumed to have one element.
authorDaniel Dunbar <daniel@zuster.org>
Wed, 15 Apr 2009 21:35:27 +0000 (21:35 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Wed, 15 Apr 2009 21:35:27 +0000 (21:35 +0000)
 - Also, fixed one to actually be one (instead of zero). :)

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@69226 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/Basic/DiagnosticSemaKinds.td
lib/Sema/Sema.cpp
test/Parser/recovery.c
test/Sema/incomplete-decl.c

index a77045e437ffe9e3a34f7a8a6d8ec562d1485bf1..a6586a8246b43862db9c74d2a23cf91f3d693f9b 100644 (file)
@@ -944,6 +944,8 @@ def err_tentative_def_incomplete_type : Error<
   "tentative definition has type %0 that is never completed">;
 def err_tentative_def_incomplete_type_arr : Error<
   "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_typecheck_sclass_fscope : Error<
index 403e8f60f56175dc202ff37a78c9433620b7bbf8..ed5c431da82f94f0fa063282664a3341a33b12f6 100644 (file)
@@ -253,8 +253,9 @@ void Sema::ActOnEndOfTranslationUnit() {
               VD->setInvalidDecl();
             else {
               // Set the length of the array to 1 (C99 6.9.2p5).
-              llvm::APSInt One(Context.getTypeSize(Context.getSizeType()), 
-                               true);
+              Diag(VD->getLocation(),  diag::warn_tentative_incomplete_array);
+              llvm::APInt One(Context.getTypeSize(Context.getSizeType()), 
+                              true);
               QualType T 
                 = Context.getConstantArrayType(ArrayT->getElementType(),
                                                One, ArrayType::Normal, 0);
index 1d49525f3b66e730651394ad3efe908a418e1a57..3f2d48d0f70d97cf06e9b4f9214497676913736a 100644 (file)
@@ -1,7 +1,7 @@
 // RUN: clang-cc -fsyntax-only -verify -pedantic -fblocks %s
 
 // PR2241
-float test2241[] = { 
+float test2241[2] = { 
   1e,            // expected-error {{exponent}}
   1ee0           // expected-error {{exponent}}
 };
index c4183ca72fab4c3ad4f919d48a973a6d55b0cd84..eb93e8e380310d38cbe0a1d33676a4c7e5e6afa2 100644 (file)
@@ -11,7 +11,7 @@ static struct foo g;  // expected-error {{variable has incomplete type 'struct f
 extern void d;
 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'}}
 
 void func() {
@@ -20,7 +20,7 @@ void func() {
   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 (*)[]'}}
 
 struct bar j = {1}; // expected-error {{variable has incomplete type 'struct bar'}} \