This revision was automatically updated to reflect the committed changes. Closed by commit rGc3e3c762098e: [clang-tidy] Fix `bugprone-use-after-move` check to also consider moves in… (authored by fwolff, committed by carlosgalvezp).
Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D113708/new/ https://reviews.llvm.org/D113708 Files: clang-tools-extra/clang-tidy/bugprone/UseAfterMoveCheck.cpp clang-tools-extra/test/clang-tidy/checkers/bugprone-use-after-move.cpp Index: clang-tools-extra/test/clang-tidy/checkers/bugprone-use-after-move.cpp =================================================================== --- clang-tools-extra/test/clang-tidy/checkers/bugprone-use-after-move.cpp +++ clang-tools-extra/test/clang-tidy/checkers/bugprone-use-after-move.cpp @@ -1338,3 +1338,15 @@ Foo Other{std::move(Bar)}; } } // namespace UnevalContext + +class PR38187 { +public: + PR38187(std::string val) : val_(std::move(val)) { + val.empty(); + // CHECK-NOTES: [[@LINE-1]]:5: warning: 'val' used after it was moved + // CHECK-NOTES: [[@LINE-3]]:30: note: move occurred here + } + +private: + std::string val_; +}; Index: clang-tools-extra/clang-tidy/bugprone/UseAfterMoveCheck.cpp =================================================================== --- clang-tools-extra/clang-tidy/bugprone/UseAfterMoveCheck.cpp +++ clang-tools-extra/clang-tidy/bugprone/UseAfterMoveCheck.cpp @@ -129,8 +129,12 @@ Visited.clear(); const CFGBlock *Block = BlockMap->blockContainingStmt(MovingCall); - if (!Block) - return false; + if (!Block) { + // This can happen if MovingCall is in a constructor initializer, which is + // not included in the CFG because the CFG is built only from the function + // body. + Block = &TheCFG->getEntry(); + } return findInternal(Block, MovingCall, MovedVariable, TheUseAfterMove); }
Index: clang-tools-extra/test/clang-tidy/checkers/bugprone-use-after-move.cpp =================================================================== --- clang-tools-extra/test/clang-tidy/checkers/bugprone-use-after-move.cpp +++ clang-tools-extra/test/clang-tidy/checkers/bugprone-use-after-move.cpp @@ -1338,3 +1338,15 @@ Foo Other{std::move(Bar)}; } } // namespace UnevalContext + +class PR38187 { +public: + PR38187(std::string val) : val_(std::move(val)) { + val.empty(); + // CHECK-NOTES: [[@LINE-1]]:5: warning: 'val' used after it was moved + // CHECK-NOTES: [[@LINE-3]]:30: note: move occurred here + } + +private: + std::string val_; +}; Index: clang-tools-extra/clang-tidy/bugprone/UseAfterMoveCheck.cpp =================================================================== --- clang-tools-extra/clang-tidy/bugprone/UseAfterMoveCheck.cpp +++ clang-tools-extra/clang-tidy/bugprone/UseAfterMoveCheck.cpp @@ -129,8 +129,12 @@ Visited.clear(); const CFGBlock *Block = BlockMap->blockContainingStmt(MovingCall); - if (!Block) - return false; + if (!Block) { + // This can happen if MovingCall is in a constructor initializer, which is + // not included in the CFG because the CFG is built only from the function + // body. + Block = &TheCFG->getEntry(); + } return findInternal(Block, MovingCall, MovedVariable, TheUseAfterMove); }
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits