]> granicus.if.org Git - clang/commitdiff
PR2044: reject declarations of functions returning variably modified
authorEli Friedman <eli.friedman@gmail.com>
Sat, 16 May 2009 12:15:55 +0000 (12:15 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Sat, 16 May 2009 12:15:55 +0000 (12:15 +0000)
types.

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

lib/Sema/SemaDecl.cpp
test/Sema/vla.c

index 1ed063ab40077b182b0d44e602f74d7c08a69665..077658c624d64785637863a3a99ae07c0d8ff532 100644 (file)
@@ -2344,6 +2344,13 @@ void Sema::CheckFunctionDeclaration(FunctionDecl *NewFD, NamedDecl *&PrevDecl,
   if (NewFD->isInvalidDecl())
     return;
 
+  if (NewFD->getResultType()->isVariablyModifiedType()) {
+    // Functions returning a variably modified type violate C99 6.7.5.2p2
+    // because all functions have linkage.
+    Diag(NewFD->getLocation(), diag::err_vm_func_decl);
+    return NewFD->setInvalidDecl();
+  }
+
   // Semantic checking for this function declaration (in isolation).
   if (getLangOptions().CPlusPlus) {
     // C++-specific checks.
index b4839143bf757366f621e1aff8b4924a86d40e50..674547297a2fec7be40e07e0dd673921390b8470 100644 (file)
@@ -46,3 +46,8 @@ static const unsigned array[((2 * (int)((((4) / 2) + 1.0/3.0) * (4) - 1e-8)) + 1
 
 int a[*]; // expected-error {{star modifier used outside of function prototype}}
 int f4(int a[*][*]);
+
+// PR2044
+int pr2044(int b) {int (*c(void))[b];**c() = 2;} // expected-error {{variably modified type}}
+int pr2044b;
+int (*pr2044c(void))[pr2044b]; // expected-error {{variably modified type}}