diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2014-07-18 22:59:10 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2014-07-18 22:59:10 +0000 |
| commit | ac6b4efaab360171a5872f991913d1dc5a97e1ca (patch) | |
| tree | 9e1dc1956aee442bfaf81656d3013888613d9438 /clang/lib/Sema/SemaStmt.cpp | |
| parent | 1c29a657c76beed5d970e531f67ab610d13366a1 (diff) | |
| download | bcm5719-llvm-ac6b4efaab360171a5872f991913d1dc5a97e1ca.tar.gz bcm5719-llvm-ac6b4efaab360171a5872f991913d1dc5a97e1ca.zip | |
Objective-C. Patch to warn if the result of calling a property getter
is unused (this is match behavior when property-dot syntax is used to
use same getter). rdar://17514245
Patch by Anders Carlsson with minor refactoring by me.
llvm-svn: 213423
Diffstat (limited to 'clang/lib/Sema/SemaStmt.cpp')
| -rw-r--r-- | clang/lib/Sema/SemaStmt.cpp | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaStmt.cpp b/clang/lib/Sema/SemaStmt.cpp index dc5619db9a4..1ddb3694cbe 100644 --- a/clang/lib/Sema/SemaStmt.cpp +++ b/clang/lib/Sema/SemaStmt.cpp @@ -253,9 +253,15 @@ void Sema::DiagnoseUnusedExprResult(const Stmt *S) { return; } const ObjCMethodDecl *MD = ME->getMethodDecl(); - if (MD && MD->hasAttr<WarnUnusedResultAttr>()) { - Diag(Loc, diag::warn_unused_result) << R1 << R2; - return; + if (MD) { + if (MD->hasAttr<WarnUnusedResultAttr>()) { + Diag(Loc, diag::warn_unused_result) << R1 << R2; + return; + } + if (MD->isPropertyAccessor()) { + Diag(Loc, diag::warn_unused_property_expr); + return; + } } } else if (const PseudoObjectExpr *POE = dyn_cast<PseudoObjectExpr>(E)) { const Expr *Source = POE->getSyntacticForm(); |

