diff options
| author | Steve Naroff <snaroff@apple.com> | 2008-03-19 23:07:49 +0000 |
|---|---|---|
| committer | Steve Naroff <snaroff@apple.com> | 2008-03-19 23:07:49 +0000 |
| commit | c5f8120ad028a62d3d21c209d9b8ee3729b41137 (patch) | |
| tree | af6cfbc845bd286fd09a49bcd2638a5ac28b37cf /clang/lib/Sema/SemaDecl.cpp | |
| parent | b727960f786225dec877f9a12f4aeeb45d7aaace (diff) | |
| download | bcm5719-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.cpp | 15 |
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); } } |

