moc: remove useless cast in qt_static_metacall generated code

_a[1] was reinterpret_casted twice in a row, which triggers
clang's warning undefined-reinterpret-cast:
"dereference of type '_t *' (aka ...) that was reinterpret_cast
from type 'void **' has undefined behavior "
only the last reinterpret_cast is kept

Change-Id: I71d52c5ff08c674003aec29f8a907c90905c0d4c
Reviewed-by: Olivier Goffart (Woboq GmbH) <ogoffart@woboq.com>
This commit is contained in:
Eric Lemanissier 2017-09-26 11:45:56 +02:00
parent 33693473d4
commit 3d0fa4d4fb

View File

@ -1237,7 +1237,6 @@ void Generator::generateStaticMetacall()
Q_ASSERT(needElse); // if there is signal, there was method. Q_ASSERT(needElse); // if there is signal, there was method.
fprintf(out, " else if (_c == QMetaObject::IndexOfMethod) {\n"); fprintf(out, " else if (_c == QMetaObject::IndexOfMethod) {\n");
fprintf(out, " int *result = reinterpret_cast<int *>(_a[0]);\n"); fprintf(out, " int *result = reinterpret_cast<int *>(_a[0]);\n");
fprintf(out, " void **func = reinterpret_cast<void **>(_a[1]);\n");
bool anythingUsed = false; bool anythingUsed = false;
for (int methodindex = 0; methodindex < cdef->signalList.size(); ++methodindex) { for (int methodindex = 0; methodindex < cdef->signalList.size(); ++methodindex) {
const FunctionDef &f = cdef->signalList.at(methodindex); const FunctionDef &f = cdef->signalList.at(methodindex);
@ -1263,14 +1262,14 @@ void Generator::generateStaticMetacall()
fprintf(out, ") const;\n"); fprintf(out, ") const;\n");
else else
fprintf(out, ");\n"); fprintf(out, ");\n");
fprintf(out, " if (*reinterpret_cast<_t *>(func) == static_cast<_t>(&%s::%s)) {\n", fprintf(out, " if (*reinterpret_cast<_t *>(_a[1]) == static_cast<_t>(&%s::%s)) {\n",
cdef->classname.constData(), f.name.constData()); cdef->classname.constData(), f.name.constData());
fprintf(out, " *result = %d;\n", methodindex); fprintf(out, " *result = %d;\n", methodindex);
fprintf(out, " return;\n"); fprintf(out, " return;\n");
fprintf(out, " }\n }\n"); fprintf(out, " }\n }\n");
} }
if (!anythingUsed) if (!anythingUsed)
fprintf(out, " Q_UNUSED(result);\n Q_UNUSED(func);\n"); fprintf(out, " Q_UNUSED(result);\n");
fprintf(out, " }"); fprintf(out, " }");
needElse = true; needElse = true;
} }