From 15e4b8dbd51b7630d82ea472a703a81bb5266952 Mon Sep 17 00:00:00 2001 From: Reijo Tomperi Date: Thu, 15 Apr 2010 23:21:00 +0300 Subject: [PATCH] Fix #1595 (case marks improperly tokenized with macro) http://sourceforge.net/apps/trac/cppcheck/ticket/1595 --- lib/preprocessor.cpp | 8 ++++++- test/testpreprocessor.cpp | 47 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 54 insertions(+), 1 deletion(-) diff --git a/lib/preprocessor.cpp b/lib/preprocessor.cpp index 672811320..8c0ceb32a 100644 --- a/lib/preprocessor.cpp +++ b/lib/preprocessor.cpp @@ -1686,6 +1686,8 @@ public: optcomma = false; macrocode += str; if (Token::Match(tok, "%var% %var%") || + Token::Match(tok, "%var% %num%") || + Token::Match(tok, "%num% %var%") || Token::Match(tok, "> >")) macrocode += " "; } @@ -2075,7 +2077,7 @@ std::string Preprocessor::expandMacros(const std::string &code, std::string file } // make sure number of newlines remain the same.. - const std::string macrocode(std::string(numberOfNewlines, '\n') + tempMacro); + std::string macrocode(std::string(numberOfNewlines, '\n') + tempMacro); // Insert macro code.. if (macro->variadic() || macro->nopar() || !macro->params().empty()) @@ -2102,6 +2104,10 @@ std::string Preprocessor::expandMacros(const std::string &code, std::string file // erase macro line.erase(pos1, pos2 - pos1); + // Don't glue this macro into variable or number after it + if (std::isalnum(line[pos1]) || line[pos1] == '_') + macrocode.append(1,' '); + // insert expanded macro code line.insert(pos1, macrocode); diff --git a/test/testpreprocessor.cpp b/test/testpreprocessor.cpp index 21013e1d1..2543e9db2 100644 --- a/test/testpreprocessor.cpp +++ b/test/testpreprocessor.cpp @@ -139,6 +139,7 @@ private: TEST_CASE(macro_mismatch); TEST_CASE(macro_linenumbers); TEST_CASE(macro_nopar); + TEST_CASE(macro_switchCase); TEST_CASE(string1); TEST_CASE(string2); TEST_CASE(string3); @@ -1420,6 +1421,52 @@ private: ASSERT_EQUALS("\n{ NULL }\n", OurPreprocessor::expandMacros(filedata)); } + void macro_switchCase() + { + { + // Make sure "case 2" doesn't become "case2" + const char filedata[] = "#define A( b ) " + "switch( a ){ " + "case 2: " + " break; " + "}\n" + "A( 5 );\n"; + ASSERT_EQUALS("\nswitch(a){case 2:break;};\n", OurPreprocessor::expandMacros(filedata)); + } + + { + // Make sure "2 BB" doesn't become "2BB" + const char filedata[] = "#define A() AA : 2 BB\n" + "A();\n"; + ASSERT_EQUALS("\nAA : 2 BB;\n", OurPreprocessor::expandMacros(filedata)); + } + + { + const char filedata[] = "#define A }\n" + "#define B() A\n" + "#define C( a ) B() break;\n" + "{C( 2 );\n"; + ASSERT_EQUALS("\n\n\n{} break;;\n", OurPreprocessor::expandMacros(filedata)); + } + + + { + const char filedata[] = "#define A }\n" + "#define B() A\n" + "#define C( a ) B() _break;\n" + "{C( 2 );\n"; + ASSERT_EQUALS("\n\n\n{} _break;;\n", OurPreprocessor::expandMacros(filedata)); + } + + + { + const char filedata[] = "#define A }\n" + "#define B() A\n" + "#define C( a ) B() 5;\n" + "{C( 2 );\n"; + ASSERT_EQUALS("\n\n\n{} 5;;\n", OurPreprocessor::expandMacros(filedata)); + } + } void string1() {