Ticket #6959: Properly handle arrays of pointers in CheckClass::constructors.
This commit is contained in:
parent
08413f0112
commit
b4b636b6a2
|
@ -160,7 +160,7 @@ void CheckClass::constructors()
|
|||
}
|
||||
|
||||
// Check if type can't be copied
|
||||
if (!var->isPointer() && var->typeScope()) {
|
||||
if (!var->isPointer() && !var->isPointerArray() && var->typeScope()) {
|
||||
if (func->type == Function::eMoveConstructor) {
|
||||
if (canNotMove(var->typeScope()))
|
||||
continue;
|
||||
|
|
|
@ -148,7 +148,7 @@ private:
|
|||
TEST_CASE(uninitVarArray6);
|
||||
TEST_CASE(uninitVarArray7);
|
||||
TEST_CASE(uninitVarArray8);
|
||||
TEST_CASE(uninitVarArray9); // ticket #6957
|
||||
TEST_CASE(uninitVarArray9); // ticket #6957, #6959
|
||||
TEST_CASE(uninitVarArray2D);
|
||||
TEST_CASE(uninitVarArray3D);
|
||||
TEST_CASE(uninitVarCpp11Init1);
|
||||
|
@ -2414,6 +2414,15 @@ private:
|
|||
" IxExprListT() {}\n"
|
||||
"};");
|
||||
ASSERT_EQUALS("[test.cpp:6]: (warning) Member variable 'IxExprListT::eArr' is not initialized in the constructor.\n", errout.str());
|
||||
check("struct sRAIUnitDefBL {\n"
|
||||
" sRAIUnitDefBL();\n"
|
||||
" ~sRAIUnitDefBL();\n"
|
||||
"};\n"
|
||||
"struct sRAIUnitDef {\n"
|
||||
" sRAIUnitDef() {}\n"
|
||||
" sRAIUnitDefBL *List[35];\n"
|
||||
"};");
|
||||
ASSERT_EQUALS("[test.cpp:6]: (warning) Member variable 'sRAIUnitDef::List' is not initialized in the constructor.\n", errout.str());
|
||||
}
|
||||
|
||||
void uninitVarArray2D() {
|
||||
|
|
Loading…
Reference in New Issue