diff options
author | Ted Kremenek <kremenek@apple.com> | 2012-12-21 22:46:35 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2012-12-21 22:46:35 +0000 |
commit | 6487335f43e0462463a036b75eb89500f2d62b24 (patch) | |
tree | c2f0c5f56c862d826dcb1898c2ff813cf0bbb0a2 /clang/lib/Sema/SemaChecking.cpp | |
parent | e738efc95b18d328ad796225fd8d8785afc61612 (diff) | |
download | bcm5719-llvm-6487335f43e0462463a036b75eb89500f2d62b24.tar.gz bcm5719-llvm-6487335f43e0462463a036b75eb89500f2d62b24.zip |
Tweak Sema::CheckLiteralKind() to also include block literals
This simplifies some diagnostic logic in checkUnsafeAssignLiteral(),
hopefully making it less error prone.
llvm-svn: 170945
Diffstat (limited to 'clang/lib/Sema/SemaChecking.cpp')
-rw-r--r-- | clang/lib/Sema/SemaChecking.cpp | 17 |
1 files changed, 6 insertions, 11 deletions
diff --git a/clang/lib/Sema/SemaChecking.cpp b/clang/lib/Sema/SemaChecking.cpp index 7d957ec4087..f0de7becb20 100644 --- a/clang/lib/Sema/SemaChecking.cpp +++ b/clang/lib/Sema/SemaChecking.cpp @@ -5754,19 +5754,14 @@ static bool checkUnsafeAssignLiteral(Sema &S, SourceLocation Loc, // allow ObjCStringLiterals, since those are designed to never really die. RHS = RHS->IgnoreParenImpCasts(); - // Classification for diagnostic. - unsigned SelectVal = /* block literal */ 0; - if (!isa<BlockExpr>(RHS)) { - // This enum needs to match with the 'select' in - // warn_objc_arc_literal_assign (off-by-1). - Sema::ObjCLiteralKind Kind = S.CheckLiteralKind(RHS); - if (Kind == Sema::LK_String || Kind == Sema::LK_None) - return false; - SelectVal = (unsigned) Kind + 1; - } + // This enum needs to match with the 'select' in + // warn_objc_arc_literal_assign (off-by-1). + Sema::ObjCLiteralKind Kind = S.CheckLiteralKind(RHS); + if (Kind == Sema::LK_String || Kind == Sema::LK_None) + return false; S.Diag(Loc, diag::warn_arc_literal_assign) - << SelectVal + << (unsigned) Kind << (isProperty ? 0 : 1) << RHS->getSourceRange(); |