ExprEngine: Clarify verificationIntegerOverflow message

This commit is contained in:
Daniel Marjamäki 2019-10-14 11:54:43 +02:00
parent bf61bcf402
commit c7a56529bb
1 changed files with 2 additions and 2 deletions

View File

@ -1415,11 +1415,11 @@ void ExprEngine::runChecks(ErrorLogger *errorLogger, const Tokenizer *tokenizer,
if (tok->valueType()->sign == ::ValueType::Sign::SIGNED) { if (tok->valueType()->sign == ::ValueType::Sign::SIGNED) {
MathLib::bigint v = 1LL << (bits - 1); MathLib::bigint v = 1LL << (bits - 1);
if (b->isGreaterThan(dataBase, v-1)) if (b->isGreaterThan(dataBase, v-1))
errorMessage = "greater than " + std::to_string(v); errorMessage = "greater than " + std::to_string(v - 1);
if (b->isLessThan(dataBase, -v)) { if (b->isLessThan(dataBase, -v)) {
if (!errorMessage.empty()) if (!errorMessage.empty())
errorMessage += " or "; errorMessage += " or ";
errorMessage += "less than " + std::to_string(v); errorMessage += "less than " + std::to_string(-v);
} }
} else { } else {
MathLib::bigint maxValue = (1LL << bits) - 1; MathLib::bigint maxValue = (1LL << bits) - 1;