summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaDecl.cpp
diff options
context:
space:
mode:
authorSteve Naroff <snaroff@apple.com>2008-03-19 23:07:49 +0000
committerSteve Naroff <snaroff@apple.com>2008-03-19 23:07:49 +0000
commitc5f8120ad028a62d3d21c209d9b8ee3729b41137 (patch)
treeaf6cfbc845bd286fd09a49bcd2638a5ac28b37cf /clang/lib/Sema/SemaDecl.cpp
parentb727960f786225dec877f9a12f4aeeb45d7aaace (diff)
downloadbcm5719-llvm-c5f8120ad028a62d3d21c209d9b8ee3729b41137.tar.gz
bcm5719-llvm-c5f8120ad028a62d3d21c209d9b8ee3729b41137.zip
Fix http://llvm.org/bugs/show_bug.cgi?id=2161.
llvm-svn: 48568
Diffstat (limited to 'clang/lib/Sema/SemaDecl.cpp')
-rw-r--r--clang/lib/Sema/SemaDecl.cpp15
1 files changed, 13 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp
index 84fe08198f9..02b5f31c874 100644
--- a/clang/lib/Sema/SemaDecl.cpp
+++ b/clang/lib/Sema/SemaDecl.cpp
@@ -1089,8 +1089,19 @@ Sema::DeclTy *Sema::ActOnStartOfFunctionDef(Scope *FnBodyScope, Declarator &D) {
// empty arg list, don't push any params.
} else {
for (unsigned i = 0, e = FTI.NumArgs; i != e; ++i) {
- Params.push_back(ActOnParamDeclarator(D.getTypeObject(0).Fun.ArgInfo[i],
- FnBodyScope));
+ ParmVarDecl *parmDecl;
+
+ parmDecl = ActOnParamDeclarator(D.getTypeObject(0).Fun.ArgInfo[i],
+ FnBodyScope);
+ // C99 6.7.5.3p4: the parameters in a parameter type list in a function
+ // declarator that is part of a function definition of that function
+ // shall not have incomplete type.
+ if (parmDecl->getType()->isIncompleteType()) {
+ Diag(parmDecl->getLocation(), diag::err_typecheck_decl_incomplete_type,
+ parmDecl->getType().getAsString());
+ parmDecl->setInvalidDecl();
+ }
+ Params.push_back(parmDecl);
}
}
OpenPOWER on IntegriCloud