diff options
author | Daniel Marjamaki <daniel.marjamaki@evidente.se> | 2014-12-15 20:22:33 +0000 |
---|---|---|
committer | Daniel Marjamaki <daniel.marjamaki@evidente.se> | 2014-12-15 20:22:33 +0000 |
commit | 368590094a96d645cf6ac147f49e7ca4ca97a8f8 (patch) | |
tree | 688702a1adeca37c837b20d9aa6b5bfbf78b8442 /clang/lib | |
parent | 26f884aedfe37b53eafcb078380b941b2a12aa2a (diff) | |
download | bcm5719-llvm-368590094a96d645cf6ac147f49e7ca4ca97a8f8.tar.gz bcm5719-llvm-368590094a96d645cf6ac147f49e7ca4ca97a8f8.zip |
Sema: Cleanup and improve string-plus-char checking.
Patch by Anders Rönnholm
llvm-svn: 224268
Diffstat (limited to 'clang/lib')
-rw-r--r-- | clang/lib/Sema/SemaExpr.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index 876e5b71e01..ad4fea84d3e 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -7312,13 +7312,13 @@ static void diagnoseStringPlusInt(Sema &Self, SourceLocation OpLoc, /// \brief Emit a warning when adding a char literal to a string. static void diagnoseStringPlusChar(Sema &Self, SourceLocation OpLoc, Expr *LHSExpr, Expr *RHSExpr) { - const DeclRefExpr *StringRefExpr = - dyn_cast<DeclRefExpr>(LHSExpr->IgnoreImpCasts()); + const Expr *StringRefExpr = LHSExpr; const CharacterLiteral *CharExpr = dyn_cast<CharacterLiteral>(RHSExpr->IgnoreImpCasts()); - if (!StringRefExpr) { - StringRefExpr = dyn_cast<DeclRefExpr>(RHSExpr->IgnoreImpCasts()); + + if (!CharExpr) { CharExpr = dyn_cast<CharacterLiteral>(LHSExpr->IgnoreImpCasts()); + StringRefExpr = RHSExpr; } if (!CharExpr || !StringRefExpr) |