signed int overflow: warn about intmax+1
This commit is contained in:
parent
2885a75ea6
commit
f280061ff8
|
@ -117,7 +117,7 @@ void CheckType::checkIntegerOverflow()
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// max int value according to platform settings.
|
// max int value according to platform settings.
|
||||||
const MathLib::bigint maxint = (1LL << (_settings->int_bit - 1)) - 1;
|
const MathLib::bigint maxint = (1LL << (_settings->int_bit - 2)) - 1;
|
||||||
|
|
||||||
const SymbolDatabase *symbolDatabase = _tokenizer->getSymbolDatabase();
|
const SymbolDatabase *symbolDatabase = _tokenizer->getSymbolDatabase();
|
||||||
const std::size_t functions = symbolDatabase->functionScopes.size();
|
const std::size_t functions = symbolDatabase->functionScopes.size();
|
||||||
|
|
|
@ -88,10 +88,10 @@ private:
|
||||||
|
|
||||||
// Ticket #6793
|
// Ticket #6793
|
||||||
check("template<int I> int foo(int x) { return x << I; }\n"
|
check("template<int I> int foo(int x) { return x << I; }\n"
|
||||||
"const int f = foo<31>(1);\n"
|
"const int f = foo<31>(0);\n"
|
||||||
"const int g = foo<100>(1);\n"
|
"const int g = foo<100>(0);\n"
|
||||||
"template<int I> int hoo(int x) { return x << 32; }\n"
|
"template<int I> int hoo(int x) { return x << 32; }\n"
|
||||||
"const int h = hoo<100>(1);", &settings);
|
"const int h = hoo<100>(0);", &settings);
|
||||||
ASSERT_EQUALS("[test.cpp:4]: (error) Shifting 32-bit value by 32 bits is undefined behaviour\n"
|
ASSERT_EQUALS("[test.cpp:4]: (error) Shifting 32-bit value by 32 bits is undefined behaviour\n"
|
||||||
"[test.cpp:1]: (error) Shifting 32-bit value by 100 bits is undefined behaviour\n", errout.str());
|
"[test.cpp:1]: (error) Shifting 32-bit value by 100 bits is undefined behaviour\n", errout.str());
|
||||||
|
|
||||||
|
@ -107,6 +107,12 @@ private:
|
||||||
settings.platform(Settings::Unix32);
|
settings.platform(Settings::Unix32);
|
||||||
settings.addEnabled("warning");
|
settings.addEnabled("warning");
|
||||||
|
|
||||||
|
check("void foo() {\n"
|
||||||
|
" int intmax = 0x7fffffff;\n"
|
||||||
|
" return intmax + 1;\n"
|
||||||
|
"}",&settings);
|
||||||
|
ASSERT_EQUALS("[test.cpp:3]: (error) Signed integer overflow for expression 'intmax+1'.\n", errout.str());
|
||||||
|
|
||||||
check("int foo(signed int x) {\n"
|
check("int foo(signed int x) {\n"
|
||||||
" if (x==123456) {}\n"
|
" if (x==123456) {}\n"
|
||||||
" return x * x;\n"
|
" return x * x;\n"
|
||||||
|
|
Loading…
Reference in New Issue