cppcheck/test/testincompletestatement.cpp

218 lines
5.2 KiB
C++
Raw Normal View History

2008-12-18 22:28:57 +01:00
/*
* Cppcheck - A tool for static C/C++ code analysis
* Copyright (C) 2007-2011 Daniel Marjamäki and Cppcheck team.
2008-12-18 22:28:57 +01:00
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
2008-12-18 22:28:57 +01:00
*/
// Check for unused variables..
2008-12-18 22:28:57 +01:00
#include "testsuite.h"
2009-10-25 12:49:06 +01:00
#include "tokenize.h"
#include "checkother.h"
2008-12-18 22:28:57 +01:00
#include <sstream>
extern std::ostringstream errout;
class TestIncompleteStatement : public TestFixture
{
public:
TestIncompleteStatement() : TestFixture("TestIncompleteStatement")
{ }
private:
void check(const char code[])
2008-12-18 22:28:57 +01:00
{
// Clear the error buffer..
errout.str("");
Settings settings;
settings.addEnabled("style");
2008-12-18 22:28:57 +01:00
// Tokenize..
Tokenizer tokenizer(&settings, this);
2008-12-18 22:28:57 +01:00
std::istringstream istr(code);
tokenizer.tokenize(istr, "test.cpp");
2008-12-18 22:28:57 +01:00
tokenizer.simplifyTokenList();
// Check for incomplete statements..
2009-03-20 18:16:21 +01:00
CheckOther checkOther(&tokenizer, &settings, this);
checkOther.checkIncompleteStatement();
2008-12-18 22:28:57 +01:00
}
void run()
{
TEST_CASE(test1);
TEST_CASE(test2);
2009-02-05 19:57:53 +01:00
TEST_CASE(test3);
TEST_CASE(test4);
TEST_CASE(test5);
TEST_CASE(test_numeric);
TEST_CASE(intarray);
TEST_CASE(structarraynull);
TEST_CASE(structarray);
TEST_CASE(conditionalcall); // ; 0==x ? X() : Y();
TEST_CASE(structinit); // #2462 : ABC abc{1,2,3};
TEST_CASE(returnstruct);
TEST_CASE(cast); // #3009 : (struct Foo *)123.a = 1;
2008-12-18 22:28:57 +01:00
}
void test1()
{
check("void foo()\n"
"{\n"
" const char def[] =\n"
"#ifdef ABC\n"
" \"abc\";\n"
"#else\n"
" \"not abc\";\n"
"#endif\n"
"}\n");
ASSERT_EQUALS("", errout.str());
2008-12-18 22:28:57 +01:00
}
void test2()
{
check("void foo()\n"
"{\n"
2009-02-05 19:57:53 +01:00
" \"abc\";\n"
"}\n");
2008-12-18 22:28:57 +01:00
ASSERT_EQUALS("[test.cpp:3]: (warning) Redundant code: Found a statement that begins with string constant\n", errout.str());
2008-12-18 22:28:57 +01:00
}
2009-02-05 19:57:53 +01:00
void test3()
{
check("void foo()\n"
"{\n"
" const char *str[] = { \"abc\" };\n"
"}\n");
ASSERT_EQUALS("", errout.str());
2009-02-05 19:57:53 +01:00
}
void test4()
{
check("void foo()\n"
"{\n"
"const char *a =\n"
"{\n"
"\"hello \"\n"
"\"more \"\n"
"\"world\"\n"
"};\n"
"}\n");
ASSERT_EQUALS("", errout.str());
}
void test5()
{
check("void foo()\n"
"{\n"
" 50;\n"
"}\n");
ASSERT_EQUALS("[test.cpp:3]: (warning) Redundant code: Found a statement that begins with numeric constant\n", errout.str());
}
void test_numeric()
{
check("struct P\n"
"{\n"
"double a;\n"
"double b;\n"
"};\n"
"void f()\n"
"{\n"
"const P values[2] =\n"
"{\n"
"{ 346.1,114.1 }, { 347.1,111.1 }\n"
"};\n"
"}\n");
ASSERT_EQUALS("", errout.str());
}
void intarray()
{
check("int arr[] = { 100/2, 1*100 };\n");
ASSERT_EQUALS("", errout.str());
}
void structarraynull()
{
check("struct st arr[] = {\n"
" { 100/2, 1*100 }\n"
" { 90, 70 }\n"
"}\n");
ASSERT_EQUALS("", errout.str());
}
void structarray()
{
check("struct st arr[] = {\n"
" { 100/2, 1*100 }\n"
" { 90, 70 }\n"
"};\n");
ASSERT_EQUALS("", errout.str());
}
void conditionalcall()
{
check("void f() {\n"
" 0==x ? X() : Y();\n"
"}\n");
ASSERT_EQUALS("", errout.str());
}
void structinit()
{
2011-01-19 20:41:46 +01:00
// #2462 - C++0x struct initialization
check("void f() {\n"
" ABC abc{1,2,3};\n"
"}\n");
ASSERT_EQUALS("", errout.str());
2011-01-19 20:41:46 +01:00
// #2482 - false positive for empty struct
check("struct A {};");
ASSERT_EQUALS("", errout.str());
}
void returnstruct()
{
check("struct s foo() {\n"
" return (struct s){0,0};\n"
"}");
ASSERT_EQUALS("", errout.str());
}
void cast()
{
check("void f() {\n"
" ((struct foo *)(0x1234))->xy = 1;\n"
"}");
ASSERT_EQUALS("", errout.str());
}
2008-12-18 22:28:57 +01:00
};
REGISTER_TEST(TestIncompleteStatement)
2008-12-18 22:28:57 +01:00