Skip to content

Commit 4cb4901

Browse files
Fix #11374 FP danglingTemporaryLifetime with std::string_view (danmar#4602)
1 parent 52264b9 commit 4cb4901

3 files changed

Lines changed: 10 additions & 2 deletions

File tree

lib/astutils.cpp

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2178,8 +2178,6 @@ T* getTokenArgumentFunctionImpl(T* tok, int& argn)
21782178
return nullptr;
21792179
if (Token::simpleMatch(argtok, ","))
21802180
argtok = argtok->astOperand1();
2181-
if (Token::simpleMatch(argtok, "(") && argtok->astOperand2())
2182-
argtok = argtok->astOperand2();
21832181
tok = argtok;
21842182
while (Token::Match(tok->astParent(), ",|(|{")) {
21852183
tok = tok->astParent();

test/testastutils.cpp

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -326,6 +326,8 @@ class TestAstUtils : public TestFixture {
326326
ASSERT(Result::True == isUsedAsBool("void f(bool b); void f() { int i; f(i); }","i )"));
327327
ASSERT(Result::True == isUsedAsBool("void f() { int *i; if (*i) {} }", "i )"));
328328
ASSERT(Result::True == isUsedAsBool("void f() { int *i; if (*i) {} }", "* i )"));
329+
ASSERT(Result::True == isUsedAsBool("int g(); void h(bool); void f() { h(g()); }", "( ) )"));
330+
ASSERT(Result::True == isUsedAsBool("int g(int); void h(bool); void f() { h(g(0)); }", "( 0 ) )"));
329331
}
330332
};
331333

test/testautovariables.cpp

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2749,6 +2749,14 @@ class TestAutoVariables : public TestFixture {
27492749
" v.data();\n"
27502750
"}\n");
27512751
ASSERT_EQUALS("[test.cpp:2] -> [test.cpp:2] -> [test.cpp:3]: (error) Using object that is a temporary.\n", errout.str());
2752+
2753+
check("std::string convert(std::string_view sv) { return std::string{ sv }; }\n" // #11374
2754+
"auto f() {\n"
2755+
" std::vector<std::string> v;\n"
2756+
" v.push_back(convert(\"foo\"));\n"
2757+
" return v[0];\n"
2758+
"}\n");
2759+
ASSERT_EQUALS("", errout.str());
27522760
}
27532761

27542762
void danglingLifetimeUniquePtr()

0 commit comments

Comments
 (0)