From ae5575457d205a03172104e264438e8a8bf28232 Mon Sep 17 00:00:00 2001 From: Aetf Date: Tue, 25 Jan 2022 23:26:01 -0500 Subject: [PATCH] =?UTF-8?q?=F0=9F=90=9B=20Workaround=20KWin=20scripting=20?= =?UTF-8?q?signal=20bug,=20fixes=20#14?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- contents/code/main.js | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/contents/code/main.js b/contents/code/main.js index 3bc5f86..7d9b4c0 100644 --- a/contents/code/main.js +++ b/contents/code/main.js @@ -47,6 +47,7 @@ Config.prototype.blockWMClass = function() { function State() { this.savedDesktops = {}; this.enabled = true; + this.savedHandlers = {}; // cached config values this.cachedConfig = { @@ -315,7 +316,14 @@ Main.prototype.moveToNewDesktop = function(client) { // register the client's windowClosed event // we cannot use the global clientRemoved event, which is called // after cleanGrouping of the client, and will cause crash of kwin - client.windowClosed.connect(this.handlers.closed); + + // Due to KWin bug[1], the signal handler can't get arguments. + // So we bind arguments here to a new function. + // [1]: https://bugs.kde.org/show_bug.cgi?id=449181 + // See also: issue #14 + var handler = this.handlers.closed.bind(null, client); + this.state.savedHandlers[client.windowId] = handler; + client.windowClosed.connect(handler); var next = this.state.getNextDesktop(client); this.insertDesktop(next); @@ -337,8 +345,11 @@ Main.prototype.moveBack = function(client, removed) { var saved = this.state.savedDesktops[client.windowId]; delete this.state.savedDesktops[client.windowId]; + var handler = this.state.savedHandlers[client.windowId]; + delete this.state.savedHandlers[client.windowId]; + // unregister the client's windowClosed event - client.windowClosed.disconnect(this.handlers.closed); + client.windowClosed.disconnect(handler); var toRemove = client.desktop; @@ -373,4 +384,4 @@ Main.prototype.init = function() { }; main = new Main(); -main.init(); \ No newline at end of file +main.init();