awesome-slot/init.lua

132 lines
3.3 KiB
Lua

-----
-- AwesomeWM - Slot
--
-- An OO/Declarative API to connect signals for the AwesomeWM.
-- It completes the native `gears.signal` module to make signal connection
-- easier to manage.
-----
local gtable = require "gears.table"
-- Load global awesome components from the C API
local capi = {
client = _G.client,
screen = _G.screen,
tag = _G.tag,
}
local awesome_slot = {
mt = {},
slots = require "awesome-slot.slots",
static_connect = {
client = capi.client,
screen = capi.screen,
tag = capi.tag,
ruled_client = require "ruled.client",
ruled_notification = require "ruled.notification",
},
registered_slots = {},
slot_status = {
CREATED = 1,
CONNECTED = 2,
},
}
local function generate_id(base_id)
local id = base_id
local n = 0
while awesome_slot.slots[id] ~= nil do
n = n + 1
id = base_id .. "_#" .. n
end
return id
end
local function get_slot(slot)
assert(slot)
local id = type(slot) == "string" and slot or slot.id
assert(id, "Slot not found!")
return awesome_slot.registered_slots[id]
end
function awesome_slot.create_slot(params)
local slot = {}
slot.id = generate_id(params.id or "UNNAMED_SLOT")
slot.target = params.target
slot.signal = params.signal
if params.slot_params then
slot.params = params.slot_params
slot.callback = function()
params.slot(slot.params)
end
else
slot.callback = params.slot
end
slot.status = awesome_slot.slot_status.CREATED
-- Insert the new slot into the slots list
awesome_slot.registered_slots[slot.id] = slot
return slot
end
function awesome_slot.delete_slot(params)
local slot = get_slot(params)
-- We shouldn't delete slot if its still connected
if slot.status == awesome_slot.slot_status.CONNECTED then
print "please disconnnect the slot before deleting it"
return false
end
awesome_slot.registered_slots[slot.id] = nil
return true
end
function awesome_slot.connect_slot(params)
local slot = get_slot(params)
-- Some modules expose a static connect_signals function
-- at the module level, while other tables/objects inheriting from
-- gears.object implement the signal connection API at the instance level.
if gtable.hasitem(awesome_slot.static_connect, slot.target) then
slot.target.connect_signal(slot.signal, slot.callback)
else
slot.target:connect_signal(slot.signal, slot.callback)
end
slot.status = awesome_slot.slot_status.CONNECTED
return slot
end
function awesome_slot.disconnect_slot(params)
local slot = get_slot(params)
-- Please check the `:connect_slot` method to understand why we do this.
if gtable.hasitem(awesome_slot.static_connect, slot.target) then
slot.target.disconnect_slot(slot.signal, slot.callback)
else
slot.target:disconnect_slot(slot.signal, slot.callback)
end
slot.status = awesome_slot.slot_status.CREATED
return slot
end
function awesome_slot.mt:__call(...) -- luacheck: ignore unused argument self
return awesome_slot.connect_slot(awesome_slot.create_slot(...))
end
return setmetatable(awesome_slot, awesome_slot.mt)
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80