From: David Majnemer Date: Sat, 2 Nov 2013 09:22:44 +0000 (+0000) Subject: Sema: Flexible array members were introduced in C99, diagnose their use in C++ X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=6f6dc158ee2fbe5b9b8685dad45be02cba0873f5;p=clang Sema: Flexible array members were introduced in C99, diagnose their use in C++ The declaration of a flexible array member was correctly diagnosed as an extension in C89 mode but not in C++. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@193918 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/Basic/DiagnosticParseKinds.td b/include/clang/Basic/DiagnosticParseKinds.td index c9eb2ad588..932732402c 100644 --- a/include/clang/Basic/DiagnosticParseKinds.td +++ b/include/clang/Basic/DiagnosticParseKinds.td @@ -74,7 +74,7 @@ def ext_c99_variable_decl_in_for_loop : Extension< def ext_c99_compound_literal : Extension< "compound literals are a C99-specific feature">, InGroup; def ext_c99_flexible_array_member : Extension< - "Flexible array members are a C99-specific feature">, InGroup; + "flexible array members are a C99-specific feature">, InGroup; def ext_enumerator_list_comma_c : Extension< "commas at the end of enumerator lists are a C99-specific " "feature">, InGroup; diff --git a/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp index 4c2c7d66ec..6c8b36c6cc 100644 --- a/lib/Sema/SemaDecl.cpp +++ b/lib/Sema/SemaDecl.cpp @@ -11829,6 +11829,9 @@ void Sema::ActOnFields(Scope *S, SourceLocation RecLoc, Decl *EnclosingDecl, else if (Fields.size() == 1) Diag(FD->getLocation(), diag::ext_flexible_array_empty_aggregate_ms) << FD->getDeclName() << Record->getTagKind(); + else + Diag(FD->getLocation(), diag::ext_c99_flexible_array_member) + << FD->getDeclName() << Record->getTagKind(); } else if (getLangOpts().CPlusPlus) { if (Record->isUnion()) Diag(FD->getLocation(), diag::ext_flexible_array_union_gnu) @@ -11836,6 +11839,9 @@ void Sema::ActOnFields(Scope *S, SourceLocation RecLoc, Decl *EnclosingDecl, else if (Fields.size() == 1) Diag(FD->getLocation(), diag::ext_flexible_array_empty_aggregate_gnu) << FD->getDeclName() << Record->getTagKind(); + else + Diag(FD->getLocation(), diag::ext_c99_flexible_array_member) + << FD->getDeclName() << Record->getTagKind(); } else if (!getLangOpts().C99) { if (Record->isUnion()) Diag(FD->getLocation(), diag::ext_flexible_array_union_gnu) diff --git a/test/Sema/c89.c b/test/Sema/c89.c index 2ab00b6ff0..0c42ec291f 100644 --- a/test/Sema/c89.c +++ b/test/Sema/c89.c @@ -90,7 +90,7 @@ 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}} */ +struct x { int x,y[]; }; /* expected-warning {{flexible array members are a C99-specific feature}} */ /* Duplicated type-qualifiers aren't allowed by C90 */ const const int c_i; /* expected-warning {{duplicate 'const' declaration specifier}} */ diff --git a/test/SemaCXX/c99.cpp b/test/SemaCXX/c99.cpp index 13918dcf5e..3383d595f0 100644 --- a/test/SemaCXX/c99.cpp +++ b/test/SemaCXX/c99.cpp @@ -2,7 +2,7 @@ void f1(int i[static 5]) { // expected-error{{C99}} } -struct Point { int x; int y; }; +struct Point { int x; int y; int z[]; }; // expected-warning{{flexible array members are a C99-specific feature}} Point p1 = { .x = 17, // expected-warning{{designated initializers are a C99 feature}} y: 25 }; // expected-warning{{designated initializers are a C99 feature}} \