]> granicus.if.org Git - clang/commitdiff
Warn on flexible array members when in C89 mode, with -pedantic.
authorDavid Chisnall <csdavec@swan.ac.uk>
Fri, 16 Mar 2012 12:15:37 +0000 (12:15 +0000)
committerDavid Chisnall <csdavec@swan.ac.uk>
Fri, 16 Mar 2012 12:15:37 +0000 (12:15 +0000)
This fixes PR 4307.

Patch by Eitan Adler!

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

include/clang/Basic/DiagnosticParseKinds.td
lib/Sema/SemaDecl.cpp
test/Sema/c89.c

index 95522189e190a6121c0dfdf125150a14127dc4c6..1f03a0777cf5a54301f6c4b1fa3b922156cdbd18 100644 (file)
@@ -56,6 +56,8 @@ def ext_c99_variable_decl_in_for_loop : Extension<
   "variable declaration in for loop is a C99-specific feature">, InGroup<C99>;
 def ext_c99_compound_literal : Extension<
   "compound literals are a C99-specific feature">, InGroup<C99>;
+def ext_c99_flexible_array_member : Extension<
+  "Flexible array members are a C99-specific feature">, InGroup<C99>;
 def ext_enumerator_list_comma : Extension<
   "commas at the end of enumerator lists are a %select{C99|C++11}0-specific "
   "feature">;
index ab1a1b40251cff212ef3d6dede80bd801b5fdc8a..574c18c2e39da931f74664067aee0bbee391d068 100644 (file)
@@ -9483,6 +9483,13 @@ void Sema::ActOnFields(Scope* S,
         else if (Fields.size() == 1) 
           Diag(FD->getLocation(), diag::ext_flexible_array_empty_aggregate_gnu)
             << FD->getDeclName() << Record->getTagKind();
+      } else if (!getLangOpts().C99) {
+      if (Record->isUnion())
+        Diag(FD->getLocation(), diag::ext_flexible_array_union_gnu)
+          << FD->getDeclName();
+      else
+        Diag(FD->getLocation(), diag::ext_c99_flexible_array_member)
+          << FD->getDeclName() << Record->getTagKind();
       } else if (NumNamedMembers < 1) {
         Diag(FD->getLocation(), diag::err_flexible_array_empty_struct)
           << FD->getDeclName();
index ac8c6e0b7b740541eaa9a5b9840bfab5e35fe841..25a10481e9234d140f342afa63295f8fceec0cfa 100644 (file)
@@ -90,4 +90,6 @@ void test16() {
   printg("Hello, world!\n"); /* expected-warning {{implicit declaration of function 'printg'}} */
 }
 
+struct x { int x,y[]; }; /* expected-warning {{Flexible array members are a C99-specific feature}} */
+
 void main() {} /* expected-error {{'main' must return 'int'}} */