diff --git a/lib/tokenize.cpp b/lib/tokenize.cpp index 2d8a5eb9ae8..b6703f7d3c3 100644 --- a/lib/tokenize.cpp +++ b/lib/tokenize.cpp @@ -891,7 +891,8 @@ namespace { tok->deleteThis(); // Unsplit variable declarations - if (Token::Match(tok4->previous(), "] ; %name% = {") && tok4->isSplittedVarDeclEq()) { + if (tok4 && tok4->isSplittedVarDeclEq() && + ((tok4->isCpp() && Token::Match(tok4->tokAt(-2), "& %name% ;")) || Token::Match(tok4->previous(), "] ; %name% = {"))) { tok4->deleteNext(); tok4->deleteThis(); } diff --git a/test/testsimplifytypedef.cpp b/test/testsimplifytypedef.cpp index af51e0171dc..db6891bf9fe 100644 --- a/test/testsimplifytypedef.cpp +++ b/test/testsimplifytypedef.cpp @@ -210,6 +210,7 @@ class TestSimplifyTypedef : public TestFixture { TEST_CASE(simplifyTypedef145); // #9353 TEST_CASE(simplifyTypedef146); TEST_CASE(simplifyTypedef147); + TEST_CASE(simplifyTypedef148); TEST_CASE(simplifyTypedefFunction1); TEST_CASE(simplifyTypedefFunction2); // ticket #1685 @@ -3428,6 +3429,13 @@ class TestSimplifyTypedef : public TestFixture { tok(code)); } + void simplifyTypedef148() { + const char* code{}; + code = "typedef int& R;\n" // #12166 + "R r = i;\n"; + ASSERT_EQUALS("int & r = i ;", tok(code)); + } + void simplifyTypedefFunction1() { { const char code[] = "typedef void (*my_func)();\n"