Merge pull request #1240 from psychon/fix-sn-callbacks
Fix spawn callbacks
This commit is contained in:
commit
1d5f70e40d
|
@ -106,8 +106,8 @@ function spawn.spawn(cmd, sn_rules, callback)
|
||||||
enable_sn = not not enable_sn -- Force into a boolean.
|
enable_sn = not not enable_sn -- Force into a boolean.
|
||||||
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 then
|
||||||
sn_rules = sn_rules or {}
|
sn_rules = type(sn_rules) ~= "boolean" and sn_rules or {}
|
||||||
spawn.snid_buffer[snid] = { sn_rules, { callback } }
|
spawn.snid_buffer[snid] = { sn_rules, { callback } }
|
||||||
end
|
end
|
||||||
return pid, snid
|
return pid, snid
|
||||||
|
|
|
@ -79,25 +79,24 @@ local function init()
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Hack needed for awesome's Startup Notification machinery
|
-- Hack needed for awesome's Startup Notification machinery
|
||||||
local function get_snid(sn_rules)
|
local function get_snid(sn_rules, callback)
|
||||||
local success, snid = spawn({ "/bin/true" }, sn_rules)
|
local success, snid = spawn({ "/bin/true" }, sn_rules, callback)
|
||||||
assert(success)
|
assert(success)
|
||||||
assert(snid)
|
assert(snid)
|
||||||
return snid
|
return snid
|
||||||
end
|
end
|
||||||
|
|
||||||
return function(class, title, sn_rules)
|
return function(class, title, sn_rules, callback)
|
||||||
class = class or "test_app"
|
class = class or "test_app"
|
||||||
title = title or "Awesome test client"
|
title = title or "Awesome test client"
|
||||||
|
|
||||||
init()
|
init()
|
||||||
local snid = sn_rules and get_snid(sn_rules) or ""
|
local snid = (sn_rules or callback) and get_snid(sn_rules, callback) or ""
|
||||||
local data = class .. "\n" .. title .. "\n" .. snid .. "\n"
|
local data = class .. "\n" .. title .. "\n" .. snid .. "\n"
|
||||||
local success, msg = pipe:write_all(data)
|
local success, msg = pipe:write_all(data)
|
||||||
assert(success, msg)
|
assert(success, msg)
|
||||||
|
|
||||||
-- TODO: Fix the API of this function
|
return snid
|
||||||
return true, sn_rules and snid or nil
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80
|
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80
|
||||||
|
|
|
@ -12,14 +12,18 @@ client.connect_signal("manage", function(c)
|
||||||
tostring(c.machine) .. " ~= " .. tostring(awesome.hostname))
|
tostring(c.machine) .. " ~= " .. tostring(awesome.hostname))
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
local snid
|
||||||
|
local num_callbacks = 0
|
||||||
|
local function callback(c)
|
||||||
|
assert(c.startup_id == snid)
|
||||||
|
num_callbacks = num_callbacks + 1
|
||||||
|
end
|
||||||
|
|
||||||
local ret, snid
|
|
||||||
local steps = {
|
local steps = {
|
||||||
function(count)
|
function(count)
|
||||||
if count == 1 then
|
if count == 1 then
|
||||||
ret, snid = test_client("foo", "bar", true)
|
snid = test_client("foo", "bar", true)
|
||||||
elseif manage_called then
|
elseif manage_called then
|
||||||
assert(ret)
|
|
||||||
assert(snid)
|
assert(snid)
|
||||||
assert(snid == c_snid)
|
assert(snid == c_snid)
|
||||||
return true
|
return true
|
||||||
|
@ -31,14 +35,24 @@ local steps = {
|
||||||
function(count)
|
function(count)
|
||||||
if count == 1 then
|
if count == 1 then
|
||||||
manage_called = false
|
manage_called = false
|
||||||
ret, snid = test_client("bar", "foo", false)
|
test_client("bar", "foo", false)
|
||||||
elseif manage_called then
|
elseif manage_called then
|
||||||
assert(ret)
|
|
||||||
assert(snid == nil)
|
|
||||||
assert(c_snid == nil, "c.startup_snid should be nil!")
|
assert(c_snid == nil, "c.startup_snid should be nil!")
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
end
|
end,
|
||||||
|
|
||||||
|
function(count)
|
||||||
|
if count == 1 then
|
||||||
|
manage_called = false
|
||||||
|
snid = test_client("baz", "barz", false, callback)
|
||||||
|
elseif manage_called then
|
||||||
|
assert(snid)
|
||||||
|
assert(snid == c_snid)
|
||||||
|
assert(num_callbacks == 1, num_callbacks)
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end,
|
||||||
}
|
}
|
||||||
|
|
||||||
runner.run_steps(steps)
|
runner.run_steps(steps)
|
||||||
|
|
Loading…
Reference in New Issue