sprintf counter improvements
This commit is contained in:
parent
ad5d87ee14
commit
5eee9af974
|
@ -771,7 +771,7 @@ void CheckBufferOverrun::bufferOverrun()
|
|||
//---------------------------------------------------------------------------
|
||||
|
||||
|
||||
int CheckBufferOverrun::countSprintfLength(const std::string &input_string, const std::list<const Token*> &/*parameters*/)
|
||||
int CheckBufferOverrun::countSprintfLength(const std::string &input_string, const std::list<const Token*> ¶meters)
|
||||
{
|
||||
|
||||
|
||||
|
@ -783,7 +783,8 @@ int CheckBufferOverrun::countSprintfLength(const std::string &input_string, cons
|
|||
std::string digits_string = "";
|
||||
int digits = 0;
|
||||
int check_for_i_d_x_f = 0;
|
||||
|
||||
std::list<const Token*>::const_iterator paramIter = parameters.begin();
|
||||
int parameterLength = 0;
|
||||
for (std::string::size_type i = 0; i != input_string.length(); i++)
|
||||
{
|
||||
|
||||
|
@ -807,12 +808,27 @@ int CheckBufferOverrun::countSprintfLength(const std::string &input_string, cons
|
|||
case 'E':
|
||||
case 'g':
|
||||
case 'o':
|
||||
case 's':
|
||||
case 'u':
|
||||
case 'p':
|
||||
case 'n':
|
||||
if (flag == 0) on_on_next = 1;
|
||||
if (flag == 0)
|
||||
{
|
||||
on_on_next = 1;
|
||||
if (paramIter != parameters.end()) ++paramIter;
|
||||
}
|
||||
break;
|
||||
case 's':
|
||||
if (flag == 0)
|
||||
{
|
||||
if (paramIter != parameters.end() && *paramIter && (*paramIter)->str()[0] == '"')
|
||||
parameterLength = Token::getStrLength(*paramIter);
|
||||
|
||||
on_on_next = 1;
|
||||
if (paramIter != parameters.end()) ++paramIter;
|
||||
}
|
||||
break;
|
||||
|
||||
|
||||
case '%':
|
||||
if (flag == 1) flag = 0;
|
||||
else
|
||||
|
@ -830,12 +846,21 @@ int CheckBufferOverrun::countSprintfLength(const std::string &input_string, cons
|
|||
|
||||
if (on_on_next == 1 && flag == 0)
|
||||
{
|
||||
//std::cout << digits_string;
|
||||
|
||||
digits_string = digits_string.substr(1, digits_string.size());
|
||||
if (check_for_i_d_x_f == 1) digits += std::max(abs(atoi(digits_string.c_str())), 1);
|
||||
int tempDigits = 0;
|
||||
if (check_for_i_d_x_f == 1)
|
||||
tempDigits = std::max(abs(atoi(digits_string.c_str())), 1);
|
||||
else
|
||||
digits += abs(atoi(digits_string.c_str()));
|
||||
tempDigits = abs(atoi(digits_string.c_str()));
|
||||
|
||||
if (tempDigits < parameterLength)
|
||||
digits += parameterLength;
|
||||
else if (parameterLength <= tempDigits)
|
||||
digits += tempDigits;
|
||||
else
|
||||
digits += parameterLength - tempDigits;
|
||||
|
||||
parameterLength = 0;
|
||||
|
||||
digits_string = "";
|
||||
check_for_i_d_x_f = 0;
|
||||
|
@ -863,7 +888,6 @@ int CheckBufferOverrun::countSprintfLength(const std::string &input_string, cons
|
|||
continue;
|
||||
}
|
||||
j++;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -1031,43 +1031,29 @@ private:
|
|||
ASSERT_EQUALS(10, CheckBufferOverrun::countSprintfLength("\\\\\\\\Hello%d \0Text\\\\\\\\", unknownParameter));
|
||||
ASSERT_EQUALS(4, CheckBufferOverrun::countSprintfLength("%%%%%d", unknownParameter));
|
||||
|
||||
|
||||
Token strTok;
|
||||
strTok.str("\"12345\"");
|
||||
std::list<const Token*> stringAsParameter;
|
||||
{
|
||||
Token tok;
|
||||
tok.str("\"12345\"");
|
||||
stringAsParameter.push_back(&tok);
|
||||
}
|
||||
|
||||
TODO_ASSERT_EQUALS(9, CheckBufferOverrun::countSprintfLength("str%s", stringAsParameter));
|
||||
TODO_ASSERT_EQUALS(6, CheckBufferOverrun::countSprintfLength("%-4s", stringAsParameter));
|
||||
stringAsParameter.push_back(&strTok);
|
||||
ASSERT_EQUALS(9, CheckBufferOverrun::countSprintfLength("str%s", stringAsParameter));
|
||||
ASSERT_EQUALS(6, CheckBufferOverrun::countSprintfLength("%-4s", stringAsParameter));
|
||||
ASSERT_EQUALS(6, CheckBufferOverrun::countSprintfLength("%-5s", stringAsParameter));
|
||||
ASSERT_EQUALS(7, CheckBufferOverrun::countSprintfLength("%-6s", stringAsParameter));
|
||||
|
||||
std::list<const Token*> intAsParameter;
|
||||
{
|
||||
Token tok;
|
||||
tok.str("12345");
|
||||
stringAsParameter.push_back(&tok);
|
||||
}
|
||||
|
||||
Token numTok;
|
||||
numTok.str("12345");
|
||||
stringAsParameter.push_back(&numTok);
|
||||
TODO_ASSERT_EQUALS(6, CheckBufferOverrun::countSprintfLength("%02ld", intAsParameter));
|
||||
ASSERT_EQUALS(9, CheckBufferOverrun::countSprintfLength("%08ld", intAsParameter));
|
||||
|
||||
std::list<const Token*> multipleParams;
|
||||
{
|
||||
Token tok;
|
||||
tok.str("\"12345\"");
|
||||
multipleParams.push_back(&tok);
|
||||
|
||||
multipleParams.push_back(&strTok);
|
||||
multipleParams.push_back(0);
|
||||
|
||||
tok.str("12345");
|
||||
multipleParams.push_back(&tok);
|
||||
}
|
||||
|
||||
multipleParams.push_back(&numTok);
|
||||
TODO_ASSERT_EQUALS(15, CheckBufferOverrun::countSprintfLength("str%s%d%d", multipleParams));
|
||||
ASSERT_EQUALS(26, CheckBufferOverrun::countSprintfLength("str%-6s%08ld%08ld", multipleParams));
|
||||
|
||||
}
|
||||
|
||||
void strncpy1()
|
||||
|
|
Loading…
Reference in New Issue