Tokenizer: Simplify numeric comparisons
This commit is contained in:
parent
c6ed868009
commit
3820a26e1c
|
@ -45,6 +45,8 @@ private:
|
|||
TEST_CASE( dupfuncname );
|
||||
|
||||
TEST_CASE( const_and_volatile_functions );
|
||||
|
||||
TEST_CASE( numeric_true_condition );
|
||||
}
|
||||
|
||||
|
||||
|
@ -185,6 +187,27 @@ private:
|
|||
ASSERT_EQUALS( std::string("c"), tokenizer._functionList[2]->str() );
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void numeric_true_condition()
|
||||
{
|
||||
const char code[] = "void f()\n"
|
||||
"{\n"
|
||||
" if (5==5);\n"
|
||||
"}\n";
|
||||
|
||||
// tokenize..
|
||||
Tokenizer tokenizer;
|
||||
std::istringstream istr(code);
|
||||
tokenizer.tokenize(istr, "test.cpp");
|
||||
|
||||
tokenizer.simplifyTokenList();
|
||||
|
||||
std::ostringstream ostr;
|
||||
for (const TOKEN *tok = tokenizer.tokens(); tok; tok = tok->next)
|
||||
ostr << " " << tok->str();
|
||||
ASSERT_EQUALS( std::string(" void f ( ) { if ( true ) ; }"), ostr.str() );
|
||||
}
|
||||
};
|
||||
|
||||
REGISTER_TEST( TestTokenizer )
|
||||
|
|
37
tokenize.cpp
37
tokenize.cpp
|
@ -1005,6 +1005,43 @@ bool Tokenizer::simplifyConditions()
|
|||
tok->next->setstr((strcmp(tok->next->aaaa(), "0")!=0) ? "true" : "false");
|
||||
ret = false;
|
||||
}
|
||||
|
||||
// Reduce "(%num% == %num%)" => "(true)"/"(false)"
|
||||
if ( (TOKEN::Match(tok, "&&") || TOKEN::Match(tok, "||") || TOKEN::Match(tok, "(")) &&
|
||||
TOKEN::Match(tok->tokAt(1), "%num%") &&
|
||||
TOKEN::Match(tok->tokAt(3), "%num%") &&
|
||||
(TOKEN::Match(tok->tokAt(4), "&&") || TOKEN::Match(tok->tokAt(4), "||") || TOKEN::Match(tok->tokAt(4), ")")) )
|
||||
{
|
||||
double op1 = (strstr(tok->strAt(1), "0x")) ? strtol(tok->strAt(1),0,16) : atof( tok->strAt(1) );
|
||||
double op2 = (strstr(tok->strAt(3), "0x")) ? strtol(tok->strAt(3),0,16) : atof( tok->strAt(3) );
|
||||
std::string cmp = tok->strAt(2);
|
||||
|
||||
bool result = false;
|
||||
if ( cmp == "==" )
|
||||
result = (op1 == op2);
|
||||
else if ( cmp == "!=" )
|
||||
result = (op1 != op2);
|
||||
else if ( cmp == ">=" )
|
||||
result = (op1 >= op2);
|
||||
else if ( cmp == ">" )
|
||||
result = (op1 > op2);
|
||||
else if ( cmp == "<=" )
|
||||
result = (op1 <= op2);
|
||||
else if ( cmp == "<" )
|
||||
result = (op1 < op2);
|
||||
else
|
||||
cmp = "";
|
||||
|
||||
if ( ! cmp.empty() )
|
||||
{
|
||||
tok = tok->next;
|
||||
tok->deleteNext();
|
||||
tok->deleteNext();
|
||||
|
||||
tok->setstr( result ? "true" : "false" );
|
||||
ret = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
|
|
Loading…
Reference in New Issue