Fixed #9689 (setVarId: wrong varid when 'not' is used)

This commit is contained in:
Daniel Marjamäki 2020-04-25 14:42:31 +02:00
parent 7698de7fd3
commit 47c998e52d
2 changed files with 12 additions and 2 deletions

View File

@ -3297,7 +3297,7 @@ void Tokenizer::setVarId()
// Variable declarations can't start with "return" etc. // Variable declarations can't start with "return" etc.
#define NOTSTART_C "case", "default", "goto", "NOT", "return", "sizeof", "typedef" #define NOTSTART_C "NOT", "case", "default", "goto", "not", "return", "sizeof", "typedef"
static const std::set<std::string> notstart_c = { NOTSTART_C }; static const std::set<std::string> notstart_c = { NOTSTART_C };
static const std::set<std::string> notstart_cpp = { NOTSTART_C, static const std::set<std::string> notstart_cpp = { NOTSTART_C,
"delete", "friend", "new", "throw", "using", "virtual", "explicit", "const_cast", "dynamic_cast", "reinterpret_cast", "static_cast", "template" "delete", "friend", "new", "throw", "using", "virtual", "explicit", "const_cast", "dynamic_cast", "reinterpret_cast", "static_cast", "template"

View File

@ -167,8 +167,8 @@ private:
TEST_CASE(varid_trailing_return1); // #8889 TEST_CASE(varid_trailing_return1); // #8889
TEST_CASE(varid_trailing_return2); // #9066 TEST_CASE(varid_trailing_return2); // #9066
TEST_CASE(varid_parameter_pack); // #9383 TEST_CASE(varid_parameter_pack); // #9383
TEST_CASE(varid_for_auto_cpp17); TEST_CASE(varid_for_auto_cpp17);
TEST_CASE(varid_not); // #9689 'not x'
TEST_CASE(varidclass1); TEST_CASE(varidclass1);
TEST_CASE(varidclass2); TEST_CASE(varidclass2);
@ -2598,6 +2598,16 @@ private:
ASSERT_EQUALS(exp1, tokenize(code)); ASSERT_EQUALS(exp1, tokenize(code));
} }
void varid_not() { // #9689 'not x'
const char code1[] = "void foo(int x) const {\n"
" if (not x) {}\n"
"}";
const char exp1[] = "1: void foo ( int x@1 ) const {\n"
"2: if ( not x@1 ) { }\n"
"3: }\n";
ASSERT_EQUALS(exp1, tokenize(code1));
}
void varidclass1() { void varidclass1() {
const std::string actual = tokenize( const std::string actual = tokenize(
"class Fred\n" "class Fred\n"