awful.spawn: Separate rules from callbacks (#1186)

When adding callbacks as a `callback` entry in a property, the callback
is run by `awful.rules`, because it does `c.callback =
result_of_function`. This is obviously not intended. Also, this causes
the callbacks to run twice, because the code already handled this
`callback` property specially.

Fix this by just not merging callbacks with the normal rules at all.

Fixes: https://github.com/awesomeWM/awesome/issues/1159
Signed-off-by: Uli Schlachter <psychon@znc.in>
This commit is contained in:
Uli Schlachter 2016-10-25 00:22:36 +02:00 committed by Daniel Hahler
parent 80832601fc
commit 70d4961a3e
2 changed files with 9 additions and 12 deletions

View File

@ -491,9 +491,8 @@ function rules.execute(c, props, callbacks)
end end
end end
function rules.completed_with_payload_callback(c, props) function rules.completed_with_payload_callback(c, props, callbacks)
rules.execute(c, props, type(props.callback) == "function" and rules.execute(c, props, callbacks)
{props.callback} or props.callback )
end end
client.connect_signal("spawn::completed_with_payload", rules.completed_with_payload_callback) client.connect_signal("spawn::completed_with_payload", rules.completed_with_payload_callback)

View File

@ -70,9 +70,11 @@ end
spawn.snid_buffer = {} spawn.snid_buffer = {}
function spawn.on_snid_callback(c) function spawn.on_snid_callback(c)
local props = spawn.snid_buffer[c.startup_id] local entry = spawn.snid_buffer[c.startup_id]
if props then if entry then
c:emit_signal("spawn::completed_with_payload", props) local props = entry[1]
local callback = entry[2]
c:emit_signal("spawn::completed_with_payload", props, callback)
spawn.snid_buffer[c.startup_id] = nil spawn.snid_buffer[c.startup_id] = nil
end end
end end
@ -102,15 +104,11 @@ function spawn.spawn(cmd, sn_rules, callback)
if cmd and cmd ~= "" then if cmd and cmd ~= "" then
local enable_sn = (sn_rules ~= false or callback) local enable_sn = (sn_rules ~= false or callback)
enable_sn = not not enable_sn -- Force into a boolean. enable_sn = not not enable_sn -- Force into a boolean.
if not sn_rules and callback then
sn_rules = {callback=callback}
elseif callback then
sn_rules.callback = callback
end
local pid, snid = capi.awesome.spawn(cmd, enable_sn) local pid, snid = capi.awesome.spawn(cmd, enable_sn)
-- The snid will be nil in case of failure -- The snid will be nil in case of failure
if snid and type(sn_rules) == "table" then if snid and type(sn_rules) == "table" then
spawn.snid_buffer[snid] = sn_rules sn_rules = sn_rules or {}
spawn.snid_buffer[snid] = { sn_rules, { callback } }
end end
return pid, snid return pid, snid
end end