diff options
| author | Abramo Bagnara <abramo.bagnara@gmail.com> | 2010-04-30 09:13:03 +0000 |
|---|---|---|
| committer | Abramo Bagnara <abramo.bagnara@gmail.com> | 2010-04-30 09:13:03 +0000 |
| commit | b639ab9ffc523c979e7f03f29b835d6d9874196f (patch) | |
| tree | 04ac0f666c0190983b27a4ae9b86e4e1a1ee0938 /clang/lib/Sema/SemaDeclAttr.cpp | |
| parent | 5af1aa63935dc9da2236d3aad7dad1edccd0af8b (diff) | |
| download | bcm5719-llvm-b639ab9ffc523c979e7f03f29b835d6d9874196f.tar.gz bcm5719-llvm-b639ab9ffc523c979e7f03f29b835d6d9874196f.zip | |
Attribute noreturn is now put in declaration attributes. Fixed a double warning generation.
llvm-svn: 102705
Diffstat (limited to 'clang/lib/Sema/SemaDeclAttr.cpp')
| -rw-r--r-- | clang/lib/Sema/SemaDeclAttr.cpp | 30 |
1 files changed, 14 insertions, 16 deletions
diff --git a/clang/lib/Sema/SemaDeclAttr.cpp b/clang/lib/Sema/SemaDeclAttr.cpp index ccc0c2df989..52d9f58d372 100644 --- a/clang/lib/Sema/SemaDeclAttr.cpp +++ b/clang/lib/Sema/SemaDeclAttr.cpp @@ -467,10 +467,11 @@ static void HandleMallocAttr(Decl *d, const AttributeList &Attr, Sema &S) { } static bool HandleCommonNoReturnAttr(Decl *d, const AttributeList &Attr, - Sema &S) { + Sema &S, bool EmitDiagnostics) { // check the attribute arguments. if (Attr.getNumArgs() != 0) { - S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 0; + if (EmitDiagnostics) + S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 0; return false; } @@ -478,10 +479,11 @@ static bool HandleCommonNoReturnAttr(Decl *d, const AttributeList &Attr, ValueDecl *VD = dyn_cast<ValueDecl>(d); if (VD == 0 || (!VD->getType()->isBlockPointerType() && !VD->getType()->isFunctionPointerType())) { - S.Diag(Attr.getLoc(), - Attr.isCXX0XAttribute() ? diag::err_attribute_wrong_decl_type - : diag::warn_attribute_wrong_decl_type) - << Attr.getName() << 0 /*function*/; + if (EmitDiagnostics) + S.Diag(Attr.getLoc(), + Attr.isCXX0XAttribute() ? diag::err_attribute_wrong_decl_type + : diag::warn_attribute_wrong_decl_type) + << Attr.getName() << 0 /*function*/; return false; } } @@ -490,21 +492,17 @@ static bool HandleCommonNoReturnAttr(Decl *d, const AttributeList &Attr, } static void HandleNoReturnAttr(Decl *d, const AttributeList &Attr, Sema &S) { - // NOTE: We don't add the attribute to a FunctionDecl because the noreturn - // trait will be part of the function's type. - - // Don't apply as a decl attribute to ValueDecl. - // FIXME: probably ought to diagnose this. - if (isa<ValueDecl>(d)) - return; - - if (HandleCommonNoReturnAttr(d, Attr, S)) + /* + Do check for well-formedness, but do not emit diagnostics: + it was already emitted by Sema::ProcessFnAttr(). + */ + if (HandleCommonNoReturnAttr(d, Attr, S, /*EmitDiagnostic=*/false)) d->addAttr(::new (S.Context) NoReturnAttr()); } static void HandleAnalyzerNoReturnAttr(Decl *d, const AttributeList &Attr, Sema &S) { - if (HandleCommonNoReturnAttr(d, Attr, S)) + if (HandleCommonNoReturnAttr(d, Attr, S, true)) d->addAttr(::new (S.Context) AnalyzerNoReturnAttr()); } |

