diff --git a/lib/checkother.cpp b/lib/checkother.cpp index e2fa8eabb..802eb3059 100644 --- a/lib/checkother.cpp +++ b/lib/checkother.cpp @@ -2112,6 +2112,8 @@ void CheckOther::checkDoubleFree() const SymbolDatabase* symbolDatabase = _tokenizer->getSymbolDatabase(); const std::size_t functions = symbolDatabase->functionScopes.size(); for (std::size_t i = 0; i < functions; ++i) { + freedVariables.clear(); + closeDirVariables.clear(); const Scope * scope = symbolDatabase->functionScopes[i]; for (const Token* tok = scope->classStart->next(); tok != scope->classEnd; tok = tok->next()) { // Keep track of any variables passed to "free()", "g_free()" or "closedir()", diff --git a/test/testother.cpp b/test/testother.cpp index c18c9145e..08b0d4cc3 100644 --- a/test/testother.cpp +++ b/test/testother.cpp @@ -5146,7 +5146,21 @@ private: ); ASSERT_EQUALS("", errout.str()); - + check( // #6252 + "struct Wrapper {\n" + " Thing* m_thing;\n" + " Wrapper() : m_thing(0) {\n" + " }\n" + " ~Wrapper() {\n" + " delete m_thing;\n" + " }\n" + " void changeThing() {\n" + " delete m_thing;\n" + " m_thing = new Thing;\n" + " }\n" + "};\n" + ); + ASSERT_EQUALS("", errout.str()); }