Automatically close fds for inert resources
If the plasma window resource is inert, the associated get_icon handler won't be invoked. This results in leaked file descriptors. With this change, the corresponding close() function call will be generated to avoid leaking file descriptors and potentially crashing the session due to kwin running out of fds. BUG: 438097
This commit is contained in:
parent
ba0d099e38
commit
48d9e4cc0e
1 changed files with 7 additions and 0 deletions
|
@ -487,6 +487,9 @@ bool Scanner::process()
|
||||||
printf("#include <QMultiMap>\n");
|
printf("#include <QMultiMap>\n");
|
||||||
printf("#include <QString>\n");
|
printf("#include <QString>\n");
|
||||||
|
|
||||||
|
printf("\n");
|
||||||
|
printf("#include <unistd.h>\n");
|
||||||
|
|
||||||
printf("\n");
|
printf("\n");
|
||||||
printf("#ifndef WAYLAND_VERSION_CHECK\n");
|
printf("#ifndef WAYLAND_VERSION_CHECK\n");
|
||||||
printf("#define WAYLAND_VERSION_CHECK(major, minor, micro) \\\n");
|
printf("#define WAYLAND_VERSION_CHECK(major, minor, micro) \\\n");
|
||||||
|
@ -946,6 +949,10 @@ bool Scanner::process()
|
||||||
printf(" Q_UNUSED(client);\n");
|
printf(" Q_UNUSED(client);\n");
|
||||||
printf(" Resource *r = Resource::fromResource(resource);\n");
|
printf(" Resource *r = Resource::fromResource(resource);\n");
|
||||||
printf(" if (Q_UNLIKELY(!r->%s_object)) {\n", interfaceNameStripped);
|
printf(" if (Q_UNLIKELY(!r->%s_object)) {\n", interfaceNameStripped);
|
||||||
|
for (const WaylandArgument &a : e.arguments) {
|
||||||
|
if (a.type == QByteArrayLiteral("fd"))
|
||||||
|
printf(" close(%s);\n", a.name.constData());
|
||||||
|
}
|
||||||
if (e.type == "destructor")
|
if (e.type == "destructor")
|
||||||
printf(" wl_resource_destroy(resource);\n");
|
printf(" wl_resource_destroy(resource);\n");
|
||||||
printf(" return;\n");
|
printf(" return;\n");
|
||||||
|
|
Loading…
Reference in a new issue