From 0f22a06b4de75d4d02741b9f39d39df1cd4e8066 Mon Sep 17 00:00:00 2001 From: Artem Dergachev Date: Tue, 10 Oct 2017 11:55:56 +0000 Subject: [analyzer] MisusedMovedObject: Fix state-resetting a base-class sub-object. If a method is resetting the state of an object that was moved from, it should be safe to use this object again. However if the method was defined in a parent class, but used in a child class, the reset didn't happen from the checker's perspective. Differential Revision: https://reviews.llvm.org/D31538 llvm-svn: 315301 --- clang/lib/StaticAnalyzer/Checkers/MisusedMovedObjectChecker.cpp | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) (limited to 'clang/lib/StaticAnalyzer/Checkers/MisusedMovedObjectChecker.cpp') diff --git a/clang/lib/StaticAnalyzer/Checkers/MisusedMovedObjectChecker.cpp b/clang/lib/StaticAnalyzer/Checkers/MisusedMovedObjectChecker.cpp index 70da66dba47..4b69a1bd1ed 100644 --- a/clang/lib/StaticAnalyzer/Checkers/MisusedMovedObjectChecker.cpp +++ b/clang/lib/StaticAnalyzer/Checkers/MisusedMovedObjectChecker.cpp @@ -416,7 +416,14 @@ void MisusedMovedObjectChecker::checkPreCall(const CallEvent &Call, return; if (isStateResetMethod(MethodDecl)) { - State = State->remove(ThisRegion); + // A state reset method resets the whole object, not only sub-object + // of a parent class in which it is defined. + const MemRegion *WholeObjectRegion = ThisRegion; + while (const CXXBaseObjectRegion *BR = + dyn_cast(WholeObjectRegion)) + WholeObjectRegion = BR->getSuperRegion(); + + State = State->remove(WholeObjectRegion); C.addTransition(State); return; } -- cgit v1.2.3