From abf6ec45cd6454c1c3c9e29aa3367c219ddc3b7d Mon Sep 17 00:00:00 2001 From: Richard Trieu Date: Wed, 27 Aug 2014 22:15:10 +0000 Subject: More -Wuninitialized updates Fix r216438 to catch more complicated self-initialized in std::move. For instance, "Foo f = std::move(cond ? OtherFoo : (UNUSED_VALUE, f));" Make sure that BinaryConditionalOperator, ConditionalOperator, BinaryOperator with comma operator, and OpaqueValueExpr perform the correct usage forwarding across the three uninitialized value checkers. llvm-svn: 216627 --- clang/lib/Sema/SemaDeclCXX.cpp | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) (limited to 'clang/lib/Sema/SemaDeclCXX.cpp') diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index 1332eac840b..081d91e0506 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -2279,11 +2279,15 @@ namespace { if (BinaryConditionalOperator *BCO = dyn_cast(E)) { - HandleValue(BCO->getCommon()); HandleValue(BCO->getFalseExpr()); return; } + if (OpaqueValueExpr *OVE = dyn_cast(E)) { + HandleValue(OVE->getSourceExpr()); + return; + } + if (BinaryOperator *BO = dyn_cast(E)) { switch (BO->getOpcode()) { default: @@ -2342,9 +2346,7 @@ namespace { if (E->getNumArgs() == 1) { if (FunctionDecl *FD = E->getDirectCallee()) { if (FD->getIdentifier() && FD->getIdentifier()->isStr("move")) { - if (MemberExpr *ME = dyn_cast(E->getArg(0))) { - HandleMemberExpr(ME, false /*CheckReferenceOnly*/); - } + HandleValue(E->getArg(0)); } } } -- cgit v1.2.3