#5844 False positive: returnReference fp for inner lambda function

This commit is contained in:
Alexander Mai 2016-05-20 23:46:56 +02:00
parent 80f445bf6f
commit d492500f34
2 changed files with 39 additions and 3 deletions

View File

@ -423,6 +423,33 @@ static bool astHasAutoResult(const Token *tok)
return false; return false;
} }
/*!
* Skip over a lambda expression
* \return next token - or next token beyond lambda
* \todo handle explicit return type
*/
static const Token* skipLambda(const Token* first)
{
if (!first)
return nullptr;
if (first->str() != "[")
return first;
const Token* tok = first->link()->next();
if (!tok)
return nullptr;
if (tok->str() == "(") {
tok = tok->link()->next();
}
if (tok->str() == "constexpr")
tok = tok->next();
if (tok->str() == "mutable")
tok = tok->next();
if (tok->str() == "{") {
tok = tok->link()->next();
}
return tok;
}
void CheckAutoVariables::returnReference() void CheckAutoVariables::returnReference()
{ {
if (_tokenizer->isC()) if (_tokenizer->isC())
@ -447,10 +474,9 @@ void CheckAutoVariables::returnReference()
} }
// Skip over lambdas // Skip over lambdas
if (tok2->str() == "[" && tok2->link()->strAt(1) == "(" && tok2->link()->linkAt(1)->strAt(1) == "{") tok2 = skipLambda(tok2);
tok2 = tok2->link()->linkAt(1)->linkAt(1);
if (tok2->str() != "return") if (!tok2 || tok2->str() != "return")
continue; continue;
// return.. // return..

View File

@ -1023,6 +1023,16 @@ private:
" });\n" " });\n"
"}"); "}");
ASSERT_EQUALS("", errout.str()); ASSERT_EQUALS("", errout.str());
// #5844
check("map<string,string> const &getVariableTable() {\n"
"static map<string,string> const s_var = []{\n"
" map<string,string> var;\n"
" return var;\n"
" }();\n"
"return s_var;\n"
"}");
ASSERT_EQUALS("", errout.str());
} }
void returnReferenceInnerScope() { void returnReferenceInnerScope() {