summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorDaniel Marjamaki <daniel.marjamaki@evidente.se>2014-12-15 20:22:33 +0000
committerDaniel Marjamaki <daniel.marjamaki@evidente.se>2014-12-15 20:22:33 +0000
commit368590094a96d645cf6ac147f49e7ca4ca97a8f8 (patch)
tree688702a1adeca37c837b20d9aa6b5bfbf78b8442 /clang/lib
parent26f884aedfe37b53eafcb078380b941b2a12aa2a (diff)
downloadbcm5719-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.cpp8
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)
OpenPOWER on IntegriCloud