Fix library data platform type (#3084)
This commit is contained in:
parent
99d9abee41
commit
f17d5b719a
|
@ -271,6 +271,29 @@ static CppcheckLibraryData::PodType loadPodType(const QXmlStreamReader &xmlReade
|
||||||
return podtype;
|
return podtype;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static CppcheckLibraryData::PlatformType loadPlatformType(QXmlStreamReader &xmlReader)
|
||||||
|
{
|
||||||
|
CppcheckLibraryData::PlatformType platformType;
|
||||||
|
platformType.name = xmlReader.attributes().value("name").toString();
|
||||||
|
platformType.value = xmlReader.attributes().value("value").toString();
|
||||||
|
|
||||||
|
QXmlStreamReader::TokenType type;
|
||||||
|
while ((type = xmlReader.readNext()) != QXmlStreamReader::EndElement ||
|
||||||
|
xmlReader.name().toString() != "platformtype") {
|
||||||
|
if (type != QXmlStreamReader::StartElement)
|
||||||
|
continue;
|
||||||
|
const QString elementName = xmlReader.name().toString();
|
||||||
|
if (QStringList({"unsigned", "long", "pointer", "const_ptr", "ptr_ptr"}).contains(elementName)) {
|
||||||
|
platformType.types.append(elementName);
|
||||||
|
} else if (elementName == "platform") {
|
||||||
|
platformType.platforms.append(xmlReader.attributes().value("type").toString());
|
||||||
|
} else {
|
||||||
|
unhandledElement(xmlReader);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return platformType;
|
||||||
|
}
|
||||||
|
|
||||||
QString CppcheckLibraryData::open(QIODevice &file)
|
QString CppcheckLibraryData::open(QIODevice &file)
|
||||||
{
|
{
|
||||||
clear();
|
clear();
|
||||||
|
@ -305,6 +328,8 @@ QString CppcheckLibraryData::open(QIODevice &file)
|
||||||
smartPointers.append(loadSmartPointer(xmlReader));
|
smartPointers.append(loadSmartPointer(xmlReader));
|
||||||
else if (elementName == "type-checks")
|
else if (elementName == "type-checks")
|
||||||
typeChecks.append(loadTypeChecks(xmlReader));
|
typeChecks.append(loadTypeChecks(xmlReader));
|
||||||
|
else if (elementName == "platformtype")
|
||||||
|
platformTypes.append(loadPlatformType(xmlReader));
|
||||||
else
|
else
|
||||||
unhandledElement(xmlReader);
|
unhandledElement(xmlReader);
|
||||||
} catch (std::runtime_error &e) {
|
} catch (std::runtime_error &e) {
|
||||||
|
@ -545,6 +570,25 @@ static void writeTypeChecks(QXmlStreamWriter &xmlWriter, const CppcheckLibraryDa
|
||||||
xmlWriter.writeEndElement();
|
xmlWriter.writeEndElement();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void writePlatformType (QXmlStreamWriter &xmlWriter, const CppcheckLibraryData::PlatformType &pt)
|
||||||
|
{
|
||||||
|
xmlWriter.writeStartElement("platformtype");
|
||||||
|
xmlWriter.writeAttribute("name", pt.name);
|
||||||
|
xmlWriter.writeAttribute("value", pt.value);
|
||||||
|
foreach (const QString type, pt.types) {
|
||||||
|
xmlWriter.writeStartElement(type);
|
||||||
|
xmlWriter.writeEndElement();
|
||||||
|
}
|
||||||
|
foreach (const QString platform, pt.platforms) {
|
||||||
|
xmlWriter.writeStartElement("platform");
|
||||||
|
if (!platform.isEmpty()) {
|
||||||
|
xmlWriter.writeAttribute("type", platform);
|
||||||
|
}
|
||||||
|
xmlWriter.writeEndElement();
|
||||||
|
}
|
||||||
|
xmlWriter.writeEndElement();
|
||||||
|
}
|
||||||
|
|
||||||
QString CppcheckLibraryData::toString() const
|
QString CppcheckLibraryData::toString() const
|
||||||
{
|
{
|
||||||
QString outputString;
|
QString outputString;
|
||||||
|
@ -602,6 +646,10 @@ QString CppcheckLibraryData::toString() const
|
||||||
xmlWriter.writeEndElement();
|
xmlWriter.writeEndElement();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
foreach (const PlatformType &pt, platformTypes) {
|
||||||
|
writePlatformType(xmlWriter, pt);
|
||||||
|
}
|
||||||
|
|
||||||
xmlWriter.writeEndElement();
|
xmlWriter.writeEndElement();
|
||||||
|
|
||||||
return outputString;
|
return outputString;
|
||||||
|
|
|
@ -171,6 +171,13 @@ public:
|
||||||
QString sign;
|
QString sign;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct PlatformType {
|
||||||
|
QString name;
|
||||||
|
QString value;
|
||||||
|
QStringList types; // Keeps element names w/o attribute (e.g. unsigned)
|
||||||
|
QStringList platforms; // Keeps "type" attribute of each "platform" element
|
||||||
|
};
|
||||||
|
|
||||||
using TypeChecks = QList<QPair<QString, QString>>;
|
using TypeChecks = QList<QPair<QString, QString>>;
|
||||||
|
|
||||||
void clear() {
|
void clear() {
|
||||||
|
@ -182,6 +189,7 @@ public:
|
||||||
podtypes.clear();
|
podtypes.clear();
|
||||||
smartPointers.clear();
|
smartPointers.clear();
|
||||||
typeChecks.clear();
|
typeChecks.clear();
|
||||||
|
platformTypes.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void swap(CppcheckLibraryData &other) {
|
void swap(CppcheckLibraryData &other) {
|
||||||
|
@ -193,6 +201,7 @@ public:
|
||||||
podtypes.swap(other.podtypes);
|
podtypes.swap(other.podtypes);
|
||||||
smartPointers.swap(other.smartPointers);
|
smartPointers.swap(other.smartPointers);
|
||||||
typeChecks.swap(other.typeChecks);
|
typeChecks.swap(other.typeChecks);
|
||||||
|
platformTypes.swap(other.platformTypes);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString open(QIODevice &file);
|
QString open(QIODevice &file);
|
||||||
|
@ -204,6 +213,7 @@ public:
|
||||||
QList<struct MemoryResource> memoryresource;
|
QList<struct MemoryResource> memoryresource;
|
||||||
QList<struct PodType> podtypes;
|
QList<struct PodType> podtypes;
|
||||||
QList<TypeChecks> typeChecks;
|
QList<TypeChecks> typeChecks;
|
||||||
|
QList<struct PlatformType> platformTypes;
|
||||||
QStringList undefines;
|
QStringList undefines;
|
||||||
QStringList smartPointers;
|
QStringList smartPointers;
|
||||||
};
|
};
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
<?xml version="1.0"?>
|
||||||
|
<def format="2">
|
||||||
|
<memory>
|
||||||
|
<alloc init="false" buffer-size="malloc">malloc</alloc>
|
||||||
|
<!-- error: invalid element aloc -->
|
||||||
|
<aloc init="true" buffer-size="calloc">calloc</alloc>
|
||||||
|
<alloc init="false" buffer-size="malloc:2">aligned_alloc</alloc>
|
||||||
|
<realloc init="false" buffer-size="malloc:2">realloc</realloc>
|
||||||
|
<realloc init="false" buffer-size="calloc:2,3">reallocarray</realloc>
|
||||||
|
<dealloc>free</dealloc>
|
||||||
|
</memory>
|
||||||
|
</def>
|
|
@ -0,0 +1,15 @@
|
||||||
|
<?xml version="1.0"?>
|
||||||
|
<def format="2">
|
||||||
|
<memory>
|
||||||
|
<alloc init="false" buffer-size="malloc">malloc</alloc>
|
||||||
|
<alloc init="true" buffer-size="calloc">calloc</alloc>
|
||||||
|
<realloc init="false" buffer-size="malloc:2">realloc</realloc>
|
||||||
|
<alloc arg="2">UuidToString</alloc>
|
||||||
|
<dealloc arg="3">HeapFree</dealloc>
|
||||||
|
</memory>
|
||||||
|
|
||||||
|
<resource>
|
||||||
|
<dealloc>fclose</dealloc>
|
||||||
|
<alloc init="true" arg="1">_wfopen_s</alloc>
|
||||||
|
</resource>
|
||||||
|
</def>
|
|
@ -0,0 +1,8 @@
|
||||||
|
<?xml version="1.0"?>
|
||||||
|
<def format="2">
|
||||||
|
<platformtype name="unhandled element" value="">
|
||||||
|
<!-- error: invalid element ptr -->
|
||||||
|
<ptr/>
|
||||||
|
<platform type="win32"/>
|
||||||
|
</platformtype>
|
||||||
|
</def>
|
|
@ -0,0 +1,19 @@
|
||||||
|
<?xml version="1.0"?>
|
||||||
|
<def format="2">
|
||||||
|
<platformtype name="platform" value="with attribute and empty">
|
||||||
|
<platform type="win64"/>
|
||||||
|
<platform/>
|
||||||
|
</platformtype>
|
||||||
|
<platformtype name="types" value="all">
|
||||||
|
<unsigned/>
|
||||||
|
<long/>
|
||||||
|
<pointer/>
|
||||||
|
<const_ptr/>
|
||||||
|
<ptr_ptr/>
|
||||||
|
</platformtype>
|
||||||
|
<platformtype name="types and platform" value="">
|
||||||
|
<pointer/>
|
||||||
|
<platform type="win32"/>
|
||||||
|
<ptr_ptr/>
|
||||||
|
</platformtype>
|
||||||
|
</def>
|
|
@ -6,5 +6,9 @@
|
||||||
<file>files/typechecks_valid.cfg</file>
|
<file>files/typechecks_valid.cfg</file>
|
||||||
<file>files/podtype_valid.cfg</file>
|
<file>files/podtype_valid.cfg</file>
|
||||||
<file>files/smartptr_valid.cfg</file>
|
<file>files/smartptr_valid.cfg</file>
|
||||||
|
<file>files/platform_type_valid.cfg</file>
|
||||||
|
<file>files/platform_type_unhandled_element.cfg</file>
|
||||||
|
<file>files/memory_resource_unhandled_element.cfg</file>
|
||||||
|
<file>files/memory_resource_valid.cfg</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
|
|
@ -39,6 +39,14 @@ void TestCppcheckLibraryData::unhandledElement()
|
||||||
loadCfgFile(":/files/unhandled_element.cfg", fileLibraryData, result);
|
loadCfgFile(":/files/unhandled_element.cfg", fileLibraryData, result);
|
||||||
QCOMPARE(result.isNull(), false);
|
QCOMPARE(result.isNull(), false);
|
||||||
qDebug() << result;
|
qDebug() << result;
|
||||||
|
|
||||||
|
loadCfgFile(":/files/platform_type_unhandled_element.cfg", fileLibraryData, result);
|
||||||
|
QCOMPARE(result.isNull(), false);
|
||||||
|
qDebug() << result;
|
||||||
|
|
||||||
|
loadCfgFile(":/files/memory_resource_unhandled_element.cfg", fileLibraryData, result);
|
||||||
|
QCOMPARE(result.isNull(), false);
|
||||||
|
qDebug() << result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TestCppcheckLibraryData::mandatoryAttributeMissing()
|
void TestCppcheckLibraryData::mandatoryAttributeMissing()
|
||||||
|
@ -134,11 +142,8 @@ void TestCppcheckLibraryData::typechecksValid()
|
||||||
for (int idx=0; idx < libraryData.typeChecks.size(); idx++) {
|
for (int idx=0; idx < libraryData.typeChecks.size(); idx++) {
|
||||||
CppcheckLibraryData::TypeChecks lhs = libraryData.typeChecks[idx];
|
CppcheckLibraryData::TypeChecks lhs = libraryData.typeChecks[idx];
|
||||||
CppcheckLibraryData::TypeChecks rhs = fileLibraryData.typeChecks[idx];
|
CppcheckLibraryData::TypeChecks rhs = fileLibraryData.typeChecks[idx];
|
||||||
QCOMPARE(lhs.size(), lhs.size());
|
QCOMPARE(lhs.size(), rhs.size());
|
||||||
for (int num=0; num < lhs.size(); num++) {
|
QCOMPARE(lhs, rhs);
|
||||||
QCOMPARE(lhs[num].first, rhs[num].first);
|
|
||||||
QCOMPARE(lhs[num].second, rhs[num].second);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -171,8 +176,164 @@ void TestCppcheckLibraryData::smartPointerValid()
|
||||||
// Verify no data got lost or modified
|
// Verify no data got lost or modified
|
||||||
QCOMPARE(libraryData.smartPointers.size(), fileLibraryData.smartPointers.size());
|
QCOMPARE(libraryData.smartPointers.size(), fileLibraryData.smartPointers.size());
|
||||||
QCOMPARE(libraryData.smartPointers.size(), 3);
|
QCOMPARE(libraryData.smartPointers.size(), 3);
|
||||||
for (int i=0; i < libraryData.smartPointers.size(); i++) {
|
QCOMPARE(libraryData.smartPointers, fileLibraryData.smartPointers);
|
||||||
QCOMPARE(libraryData.smartPointers[i], fileLibraryData.smartPointers[i]);
|
}
|
||||||
|
|
||||||
|
void TestCppcheckLibraryData::platformTypeValid()
|
||||||
|
{
|
||||||
|
// Load library data from file
|
||||||
|
loadCfgFile(":/files/platform_type_valid.cfg", fileLibraryData, result);
|
||||||
|
QCOMPARE(result.isNull(), true);
|
||||||
|
|
||||||
|
// Swap libray data read from file to other object
|
||||||
|
libraryData.swap(fileLibraryData);
|
||||||
|
|
||||||
|
// Do size and content checks against swapped data.
|
||||||
|
QCOMPARE(libraryData.platformTypes.size(), 3);
|
||||||
|
|
||||||
|
QCOMPARE(libraryData.platformTypes[0].name, "platform");
|
||||||
|
QCOMPARE(libraryData.platformTypes[0].value, "with attribute and empty");
|
||||||
|
QCOMPARE(libraryData.platformTypes[0].types.size(), 0);
|
||||||
|
QCOMPARE(libraryData.platformTypes[0].platforms.size(), 2);
|
||||||
|
QCOMPARE(libraryData.platformTypes[0].platforms[0], "win64");
|
||||||
|
QCOMPARE(libraryData.platformTypes[0].platforms[1].isEmpty(), true);
|
||||||
|
|
||||||
|
QCOMPARE(libraryData.platformTypes[1].name, "types");
|
||||||
|
QCOMPARE(libraryData.platformTypes[1].value, "all");
|
||||||
|
QCOMPARE(libraryData.platformTypes[1].types.size(), 5);
|
||||||
|
QCOMPARE(libraryData.platformTypes[1].types,
|
||||||
|
QStringList({"unsigned", "long", "pointer", "const_ptr", "ptr_ptr"}));
|
||||||
|
QCOMPARE(libraryData.platformTypes[1].platforms.isEmpty(), true);
|
||||||
|
|
||||||
|
QCOMPARE(libraryData.platformTypes[2].name, "types and platform");
|
||||||
|
QCOMPARE(libraryData.platformTypes[2].value.isEmpty(), true);
|
||||||
|
QCOMPARE(libraryData.platformTypes[2].types.size(), 2);
|
||||||
|
QCOMPARE(libraryData.platformTypes[2].types, QStringList({"pointer", "ptr_ptr"}));
|
||||||
|
QCOMPARE(libraryData.platformTypes[2].platforms.size(), 1);
|
||||||
|
QCOMPARE(libraryData.platformTypes[2].platforms[0], "win32");
|
||||||
|
|
||||||
|
// Save library data to file
|
||||||
|
saveCfgFile(TempCfgFile, libraryData);
|
||||||
|
|
||||||
|
fileLibraryData.clear();
|
||||||
|
QCOMPARE(fileLibraryData.platformTypes.size(), 0);
|
||||||
|
|
||||||
|
// Reload library data from file
|
||||||
|
loadCfgFile(TempCfgFile, fileLibraryData, result, true);
|
||||||
|
QCOMPARE(result.isNull(), true);
|
||||||
|
|
||||||
|
// Verify no data got lost or modified
|
||||||
|
QCOMPARE(libraryData.platformTypes.size(), fileLibraryData.platformTypes.size());
|
||||||
|
QCOMPARE(libraryData.platformTypes.size(), 3);
|
||||||
|
for (int idx=0; idx < libraryData.platformTypes.size(); idx++) {
|
||||||
|
CppcheckLibraryData::PlatformType lhs = libraryData.platformTypes[idx];
|
||||||
|
CppcheckLibraryData::PlatformType rhs = fileLibraryData.platformTypes[idx];
|
||||||
|
QCOMPARE(lhs.name, rhs.name);
|
||||||
|
QCOMPARE(lhs.value, rhs.value);
|
||||||
|
QCOMPARE(lhs.types.size(), rhs.types.size());
|
||||||
|
QCOMPARE(lhs.types, rhs.types);
|
||||||
|
QCOMPARE(lhs.platforms.size(), rhs.platforms.size());
|
||||||
|
QCOMPARE(lhs.platforms, rhs.platforms);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void TestCppcheckLibraryData::memoryResourceValid()
|
||||||
|
{
|
||||||
|
// Load library data from file
|
||||||
|
loadCfgFile(":/files/memory_resource_valid.cfg", fileLibraryData, result);
|
||||||
|
QCOMPARE(result.isNull(), true);
|
||||||
|
|
||||||
|
// Swap libray data read from file to other object
|
||||||
|
libraryData.swap(fileLibraryData);
|
||||||
|
|
||||||
|
// Do size and content checks against swapped data.
|
||||||
|
QCOMPARE(libraryData.memoryresource.size(), 2);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].type, "memory");
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc.size(), 4);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].dealloc.size(), 1);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].use.size(), 0);
|
||||||
|
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[0].name, "malloc");
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[0].bufferSize, "malloc");
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[0].isRealloc, false);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[0].init, false);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[0].arg, -1);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[0].reallocArg, -1);
|
||||||
|
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[1].name, "calloc");
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[1].bufferSize, "calloc");
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[1].isRealloc, false);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[1].init, true);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[1].arg, -1);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[1].reallocArg, -1);
|
||||||
|
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[2].name, "realloc");
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[2].bufferSize, "malloc:2");
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[2].isRealloc, true);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[2].init, false);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[2].arg, -1);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[2].reallocArg, -1);
|
||||||
|
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[3].name, "UuidToString");
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[3].bufferSize.isEmpty(), true);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[3].isRealloc, false);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[3].init, false);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[3].arg, 2);
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].alloc[3].reallocArg, -1);
|
||||||
|
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].dealloc[0].name, "HeapFree");
|
||||||
|
QCOMPARE(libraryData.memoryresource[0].dealloc[0].arg, 3);
|
||||||
|
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].type, "resource");
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].alloc.size(), 1);
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].dealloc.size(), 1);
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].use.size(), 0);
|
||||||
|
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].alloc[0].name, "_wfopen_s");
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].alloc[0].bufferSize.isEmpty(), true);
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].alloc[0].isRealloc, false);
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].alloc[0].init, true);
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].alloc[0].arg, 1);
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].alloc[0].reallocArg, -1);
|
||||||
|
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].dealloc[0].name, "fclose");
|
||||||
|
QCOMPARE(libraryData.memoryresource[1].dealloc[0].arg, -1);
|
||||||
|
|
||||||
|
// Save library data to file
|
||||||
|
saveCfgFile(TempCfgFile, libraryData);
|
||||||
|
|
||||||
|
fileLibraryData.clear();
|
||||||
|
QCOMPARE(fileLibraryData.memoryresource.size(), 0);
|
||||||
|
|
||||||
|
// Reload library data from file
|
||||||
|
loadCfgFile(TempCfgFile, fileLibraryData, result, true);
|
||||||
|
QCOMPARE(result.isNull(), true);
|
||||||
|
|
||||||
|
// Verify no data got lost or modified
|
||||||
|
QCOMPARE(libraryData.memoryresource.size(), fileLibraryData.memoryresource.size());
|
||||||
|
QCOMPARE(libraryData.memoryresource.size(), 2);
|
||||||
|
|
||||||
|
for (int idx=0; idx < libraryData.memoryresource.size(); idx++) {
|
||||||
|
CppcheckLibraryData::MemoryResource lhs = libraryData.memoryresource[idx];
|
||||||
|
CppcheckLibraryData::MemoryResource rhs = fileLibraryData.memoryresource[idx];
|
||||||
|
|
||||||
|
QCOMPARE(lhs.type, rhs.type);
|
||||||
|
QCOMPARE(lhs.alloc.size(), rhs.alloc.size());
|
||||||
|
QCOMPARE(lhs.dealloc.size(), rhs.dealloc.size());
|
||||||
|
QCOMPARE(lhs.use, rhs.use);
|
||||||
|
|
||||||
|
for (int num=0; num < lhs.alloc.size(); num++) {
|
||||||
|
QCOMPARE(lhs.alloc[num].name, rhs.alloc[num].name);
|
||||||
|
QCOMPARE(lhs.alloc[num].bufferSize, rhs.alloc[num].bufferSize);
|
||||||
|
QCOMPARE(lhs.alloc[num].isRealloc, rhs.alloc[num].isRealloc);
|
||||||
|
QCOMPARE(lhs.alloc[num].init, rhs.alloc[num].init);
|
||||||
|
QCOMPARE(lhs.alloc[num].arg, rhs.alloc[num].arg);
|
||||||
|
QCOMPARE(lhs.alloc[num].reallocArg, rhs.alloc[num].reallocArg);
|
||||||
|
}
|
||||||
|
for (int num=0; num < lhs.dealloc.size(); num++) {
|
||||||
|
QCOMPARE(lhs.dealloc[num].name, rhs.dealloc[num].name);
|
||||||
|
QCOMPARE(lhs.dealloc[num].arg, rhs.dealloc[num].arg);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -32,6 +32,8 @@ private slots:
|
||||||
void podtypeValid();
|
void podtypeValid();
|
||||||
void typechecksValid();
|
void typechecksValid();
|
||||||
void smartPointerValid();
|
void smartPointerValid();
|
||||||
|
void platformTypeValid();
|
||||||
|
void memoryResourceValid();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void loadCfgFile(QString filename, CppcheckLibraryData &data, QString &result, bool removeFile = false);
|
void loadCfgFile(QString filename, CppcheckLibraryData &data, QString &result, bool removeFile = false);
|
||||||
|
|
Loading…
Reference in New Issue