diff options
author | David Blaikie <dblaikie@gmail.com> | 2011-12-09 21:42:37 +0000 |
---|---|---|
committer | David Blaikie <dblaikie@gmail.com> | 2011-12-09 21:42:37 +0000 |
commit | 10eb4b67d8c7503a3df9a19efad1df4e37437f1b (patch) | |
tree | 8afd91de13729e141f836d1f42b81b1831c78020 /clang/lib | |
parent | 66af99eb3487f046e4073d368f2e2077ef380935 (diff) | |
download | bcm5719-llvm-10eb4b67d8c7503a3df9a19efad1df4e37437f1b.tar.gz bcm5719-llvm-10eb4b67d8c7503a3df9a19efad1df4e37437f1b.zip |
Add notes for suppressing and (if it's a zero-arg function returning bool) fixing the function-to-bool conversion warning.
llvm-svn: 146280
Diffstat (limited to 'clang/lib')
-rw-r--r-- | clang/lib/Sema/SemaChecking.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaChecking.cpp b/clang/lib/Sema/SemaChecking.cpp index a0138d8723a..db60f2388aa 100644 --- a/clang/lib/Sema/SemaChecking.cpp +++ b/clang/lib/Sema/SemaChecking.cpp @@ -3771,6 +3771,16 @@ void CheckImplicitConversion(Sema &S, Expr *E, QualType T, if (FunctionDecl* F = dyn_cast<FunctionDecl>(D)) { S.Diag(E->getExprLoc(), diag::warn_impcast_function_to_bool) << F << E->getSourceRange() << SourceRange(CC); + S.Diag(E->getExprLoc(), diag::note_function_to_bool_silence) + << FixItHint::CreateInsertion(E->getExprLoc(), "&"); + QualType ReturnType; + UnresolvedSet<4> NonTemplateOverloads; + S.isExprCallable(*E, ReturnType, NonTemplateOverloads); + if (!ReturnType.isNull() + && ReturnType->isSpecificBuiltinType(BuiltinType::Bool)) + S.Diag(E->getExprLoc(), diag::note_function_to_bool_call) + << FixItHint::CreateInsertion( + S.getPreprocessor().getLocForEndOfToken(E->getLocEnd()), "()"); return; } } |