From 0cc49188c0cfa2c5e3da239e0897d2cfbeab4382 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20Marjam=C3=A4ki?= Date: Sat, 1 Jan 2011 12:27:57 +0100 Subject: [PATCH] Memory leaks: localized variables --- lib/checkmemoryleak.cpp | 30 ++++++++++++++++-------------- 1 file changed, 16 insertions(+), 14 deletions(-) diff --git a/lib/checkmemoryleak.cpp b/lib/checkmemoryleak.cpp index f9d1cb00b..919647a78 100644 --- a/lib/checkmemoryleak.cpp +++ b/lib/checkmemoryleak.cpp @@ -1526,23 +1526,25 @@ Token *CheckMemoryLeakInFunction::getcode(const Token *tok, std::listnext()) { - if (tok2->str() == "{") - ++indentlevel; - else if (tok2->str() == "}") + // Replace "throw" that is not in a try block with "return" + int indentlevel = 0; + int trylevel = -1; + for (Token *tok2 = tok; tok2; tok2 = tok2->next()) { - --indentlevel; - if (indentlevel <= trylevel) - trylevel = -1; + if (tok2->str() == "{") + ++indentlevel; + else if (tok2->str() == "}") + { + --indentlevel; + if (indentlevel <= trylevel) + trylevel = -1; + } + else if (trylevel == -1 && tok2->str() == "try") + trylevel = indentlevel; + else if (trylevel == -1 && tok2->str() == "throw") + tok2->str("return"); } - else if (trylevel == -1 && tok2->str() == "try") - trylevel = indentlevel; - else if (trylevel == -1 && tok2->str() == "throw") - tok2->str("return"); } // Insert extra ";"