awful.client: Refactor all marked function into a property

This is unused internally since Awesome 3.2. There is probably 0 users
of this left, but I don't want to break the API.
This commit is contained in:
Emmanuel Lepage Vallee 2016-04-03 03:50:04 -04:00
parent 43f1561f26
commit d44d83fdb6
1 changed files with 60 additions and 40 deletions

View File

@ -439,78 +439,98 @@ function client.object.move_to_screen(self, s)
end end
end end
--- Mark a client, and then call 'marked' hook. --- If a client is marked or not.
-- @client c The client to mark, the focused one if not specified. --
-- @return True if the client has been marked. False if the client was already marked. -- **Signal:**
function client.mark(c) --
local cl = c or capi.client.focus -- * *marked* (for legacy reasons, use `property::marked`)
if cl then -- * *unmarked* (for legacy reasons, use `property::marked`)
for _, v in pairs(client.data.marked) do -- * *property::marked*
if cl == v then --
return false -- @property marked
-- @param boolean
--- The border color when the client is focused.
--
-- @beautiful beautiful.border_marked
-- @param string
--
function client.object.set_marked(self, value)
local is_marked = self.marked
if value == false and is_marked then
for k, v in pairs(client.data.marked) do
if self == v then
table.remove(client.data.marked, k)
end end
end end
self:emit_signal("unmarked")
elseif not is_marked and value then
self:emit_signal("marked")
table.insert(client.data.marked, self)
end
table.insert(client.data.marked, cl) client.property.set(self, "marked", value)
-- Call callback
cl:emit_signal("marked")
return true
end
end end
function client.object.get_marked(self)
return client.property.get(self, "marked")
end
--- Mark a client, and then call 'marked' hook.
-- @deprecated awful.client.mark
-- @client c The client to mark, the focused one if not specified.
function client.mark(c)
util.deprecate "Use c.marked = true instead of awful.client.mark"
client.object.set_marked(c or capi.client.focus, true)
end
--- Unmark a client and then call 'unmarked' hook. --- Unmark a client and then call 'unmarked' hook.
-- @deprecated awful.client.unmark
-- @client c The client to unmark, or the focused one if not specified. -- @client c The client to unmark, or the focused one if not specified.
-- @return True if the client has been unmarked. False if the client was not marked.
function client.unmark(c) function client.unmark(c)
local cl = c or capi.client.focus util.deprecate "Use c.marked = false instead of awful.client.unmark"
for k, v in pairs(client.data.marked) do client.object.set_marked(c or capi.client.focus, false)
if cl == v then
table.remove(client.data.marked, k)
cl:emit_signal("unmarked")
return true
end
end
return false
end end
--- Check if a client is marked. --- Check if a client is marked.
-- @deprecated awful.client.ismarked
-- @client c The client to check, or the focused one otherwise. -- @client c The client to check, or the focused one otherwise.
function client.ismarked(c) function client.ismarked(c)
local cl = c or capi.client.focus util.deprecate "Use c.marked instead of awful.client.ismarked"
if cl then
for _, v in pairs(client.data.marked) do return client.object.get_marked(c or capi.client.focus)
if cl == v then
return true
end
end
end
return false
end end
--- Toggle a client as marked. --- Toggle a client as marked.
-- @deprecated awful.client.togglemarked
-- @client c The client to toggle mark. -- @client c The client to toggle mark.
function client.togglemarked(c) function client.togglemarked(c)
util.deprecate "Use c.marked = not c.marked instead of awful.client.togglemarked"
c = c or capi.client.focus c = c or capi.client.focus
if not client.mark(c) then if c then
client.unmark(c) c.marked = not c.marked
end end
end end
--- Return the marked clients and empty the marked table. --- Return the marked clients and empty the marked table.
-- @function awful.client.getmarked
-- @return A table with all marked clients. -- @return A table with all marked clients.
function client.getmarked() function client.getmarked()
for _, v in pairs(client.data.marked) do local copy = util.table.clone(client.data.marked, false)
for _, v in pairs(copy) do
client.property.set(v, "marked", false)
v:emit_signal("unmarked") v:emit_signal("unmarked")
end end
local t = client.data.marked
client.data.marked = {} client.data.marked = {}
return t
return copy
end end
--- Set a client floating state, overriding auto-detection. --- Set a client floating state, overriding auto-detection.