From 65825bdd2264673391c305769642b1b31dc7831c Mon Sep 17 00:00:00 2001 From: Julien Danjou Date: Tue, 11 Aug 2009 15:27:31 +0200 Subject: [PATCH] awful: move hooks to signals Signed-off-by: Julien Danjou --- lib/awful/client.lua.in | 18 ++--- lib/awful/layout/init.lua.in | 115 +++++++++++++++--------------- lib/awful/screen.lua.in | 6 +- lib/awful/tag.lua.in | 6 +- lib/awful/wibox.lua.in | 30 ++++---- lib/awful/widget/layoutbox.lua.in | 8 ++- lib/awful/widget/taglist.lua.in | 36 +++++++--- lib/awful/widget/tasklist.lua.in | 42 ++++++----- 8 files changed, 141 insertions(+), 120 deletions(-) diff --git a/lib/awful/client.lua.in b/lib/awful/client.lua.in index 67b84c7f..829e7f53 100644 --- a/lib/awful/client.lua.in +++ b/lib/awful/client.lua.in @@ -19,9 +19,7 @@ local capi = client = client, mouse = mouse, screen = screen, - hooks = hooks } -local hooks = require("awful.hooks") --- Client module for awful module("awful.client") @@ -42,10 +40,6 @@ floating = {} dockable = {} property = {} --- User hooks -hooks.user.create('marked') -hooks.user.create('unmarked') - --- Get the first client that got the urgent hint. -- @return The first urgent client. function urgent.get() @@ -493,7 +487,7 @@ function mark(c) table.insert(data.marked, cl) -- Call callback - hooks.user.call('marked', cl) + cl:emit_signal("marked") return true end end @@ -507,7 +501,7 @@ function unmark(c) for k, v in pairs(data.marked) do if cl == v then table.remove(data.marked, k) - hooks.user.call('unmarked', cl) + cl:emit_signal("unmarked") return true end end @@ -543,7 +537,7 @@ end -- @return A table with all marked clients. function getmarked() for k, v in pairs(data.marked) do - hooks.user.call('unmarked', v) + v:emit_signal("unmarked") end t = data.marked @@ -761,7 +755,7 @@ function setwfact(wfact, c) end end - hooks.user.call("property", t, "windowfact") + t:emit_signal("property::windowfact") end --- Increment a client's window factor @@ -784,7 +778,7 @@ function incwfact(add, c) -- keep our ratios normalized normalize(colfact, w.num) - hooks.user.call("property", t, "windowfact") + t:emit_signal("property::windowfact") end --- Get a client dockable state. @@ -836,7 +830,7 @@ function property.set(c, prop, value) data.properties[c] = {} end data.properties[c][prop] = value - hooks.user.call("property", c, prop) + c:emit_signal("property::floating") end -- Register standards signals diff --git a/lib/awful/layout/init.lua.in b/lib/awful/layout/init.lua.in index 2a80891d..3955c14b 100644 --- a/lib/awful/layout/init.lua.in +++ b/lib/awful/layout/init.lua.in @@ -13,9 +13,9 @@ local util = require("awful.util") local suit = require("awful.layout.suit") local wibox = require("awful.wibox") local ascreen = require("awful.screen") -local hooks = require("awful.hooks") local capi = { screen = screen, + awesome = awesome, client = client } local client = require("awful.client") @@ -23,9 +23,6 @@ local client = require("awful.client") --- Layout module for awful module("awful.layout") --- Create a hook to call when changing layout -hooks.user.create("layout") - --- Get the current layout. -- @param screen The screen number. -- @return The layout function. @@ -61,11 +58,11 @@ end function set(layout, t) t = t or tag.selected() tag.setproperty(t, "layout", layout) - hooks.user.call("layout", t, layout) end --- Register an arrange hook. -local function on_arrange (screen) +--- Arrange a screen using its current layout. +-- @param screen The screen to arrange. +function arrange(screen) local p = {} p.workarea = wibox.get_workarea(screen) -- Handle padding @@ -90,62 +87,68 @@ function getname(layout) return layout.name end -hooks.property.register(function (obj, prop) - local objtype = type(obj) - if objtype == "client" then - if prop == "size_hints_honor" - or prop == "struts" - or prop == "minimized" - or prop == "sticky" - or prop == "fullscreen" - or prop == "maximized_horizontal" - or prop == "maximized_vertical" - or prop == "border_width" - or prop == "hide" - or prop == "titlebar" - or prop == "floating" then - on_arrange(obj.screen) - elseif prop == "screen" then - -- If prop is screen, we do not know what was the previous screen, so - -- let's arrange all screens :-( - for screen = 1, capi.screen.count() do - on_arrange(screen) - end - end - elseif objtype == "wibox" then - if prop == "screen" - or prop == "visible" then - on_arrange(obj.screen) - end - elseif objtype == "tag" then - if prop == "mwfact" - or prop == "nmaster" - or prop == "ncol" - or prop == "layout" - or prop == "windowfact" then - on_arrange(obj.screen) - end - end -end) -hooks.wibox_position.register(function(wibox) - on_arrange(wibox.screen) +local function arrange_prop(obj) arrange(obj.screen) end + +capi.client.add_signal("new", function(c) + c:add_signal("property::size_hints_honor", arrange_prop) + c:add_signal("property::struts", arrange_prop) + c:add_signal("property::minimized", arrange_prop) + c:add_signal("property::sticky", arrange_prop) + c:add_signal("property::fullscreen", arrange_prop) + c:add_signal("property::maximized_horizontal", arrange_prop) + c:add_signal("property::maximized_vertical", arrange_prop) + c:add_signal("property::border_width", arrange_prop) + c:add_signal("property::hidden", arrange_prop) + c:add_signal("property::titlebar", arrange_prop) + c:add_signal("property::floating", arrange_prop) + -- If prop is screen, we do not know what was the previous screen, so + -- let's arrange all screens :-( + c:add_signal("property::screen", function(c) + for screen = 1, capi.screen.count() do arrange(screen) end end) end) -hooks.padding.register(function(screen) on_arrange(screen) end) -capi.client.add_signal("focus", function(c) on_arrange(c.screen) end) -capi.client.add_signal("list", function() - for screen = 1, capi.screen.count() do - on_arrange(screen) - end - end) -hooks.tags.register(function(screen, tag, action) on_arrange(screen) end) -hooks.tagged.register(function(c, tag) +local function arrange_on_tagged(c, tag) if not tag.screen then return end - on_arrange(tag.screen) + arrange(tag.screen) if not capi.client.focus or not capi.client.focus:isvisible() then local c = client.focus.history.get(tag.screen, 0) if c then capi.client.focus = c end end +end + +for s = 1, capi.screen.count() do + capi.screen[s]:add_signal("tag::attach", function (screen, tag) + arrange(screen.index) + tag:add_signal("property::mwfact", arrange_prop) + tag:add_signal("property::nmaster", arrange_prop) + tag:add_signal("property::ncol", arrange_prop) + tag:add_signal("property::layout", arrange_prop) + tag:add_signal("property::windowfact", arrange_prop) + tag:add_signal("property::selected", arrange_prop) + tag:add_signal("tagged", arrange_on_tagged) + end) + capi.screen[s]:add_signal("tag::detach", function (screen, tag) + arrange(screen.index) + tag:remove_signal("property::mwfact", arrange_prop) + tag:remove_signal("property::nmaster", arrange_prop) + tag:remove_signal("property::ncol", arrange_prop) + tag:remove_signal("property::layout", arrange_prop) + tag:remove_signal("property::windowfact", arrange_prop) + tag:remove_signal("property::selected", arrange_prop) + tag:remove_signal("tagged", arrange_on_tagged) + end) + capi.screen[s]:add_signal("padding", arrange) +end + +capi.awesome.add_signal("arrange", function(screen) + arrange(screen) end) +capi.client.add_signal("focus", function(c) arrange(c.screen) end) +capi.client.add_signal("list", function() + for screen = 1, capi.screen.count() do + arrange(screen) + end + end) + -- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80 diff --git a/lib/awful/screen.lua.in b/lib/awful/screen.lua.in index e6ef1c83..44a6b031 100644 --- a/lib/awful/screen.lua.in +++ b/lib/awful/screen.lua.in @@ -13,7 +13,6 @@ local capi = } local util = require("awful.util") local client = require("awful.client") -local hooks = require("awful.hooks") --- Screen module for awful module("awful.screen") @@ -21,9 +20,6 @@ module("awful.screen") local data = {} data.padding = {} --- Create a hook for padding event -hooks.user.create("padding") - --- Give the focus to a screen, and move pointer. -- @param i Relative screen number. function focus(i) @@ -41,7 +37,7 @@ end function padding(i, padding) if padding then data.padding[i] = padding - hooks.user.call("padding", i) + capi.screen[i]:emit_signal("padding") end return data.padding[i] end diff --git a/lib/awful/tag.lua.in b/lib/awful/tag.lua.in index 8885d91f..2f06bc5a 100644 --- a/lib/awful/tag.lua.in +++ b/lib/awful/tag.lua.in @@ -16,7 +16,6 @@ local capi = mouse = mouse, client = client } -local hooks = require("awful.hooks") --- Tag module for awful module("awful.tag") @@ -267,7 +266,7 @@ function setproperty(tag, prop, value) data.tags[tag] = {} end data.tags[tag][prop] = value - hooks.user.call("property", tag, prop) + tag:emit_signal("property::" .. prop) end --- Tag a client with the set of current tags. @@ -285,8 +284,7 @@ function withcurrent(c, startup) end end --- Register standards hooks -hooks.tags.register(history.update) +-- Register standards signals capi.client.add_signal("manage", withcurrent) -- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80 diff --git a/lib/awful/wibox.lua.in b/lib/awful/wibox.lua.in index e91a2655..4a87f117 100644 --- a/lib/awful/wibox.lua.in +++ b/lib/awful/wibox.lua.in @@ -17,7 +17,6 @@ local ipairs = ipairs local table = table local type = type local image = image -local hooks = require("awful.hooks") --- Wibox module for awful. module("awful.wibox") @@ -26,8 +25,6 @@ module("awful.wibox") -- It's an array so it is ordered. local wiboxes = {} -hooks.user.create("wibox_position") - --- Get the workarea space without wiboxes geometry. -- @param s The screen number. -- @return The screen workarea. @@ -127,10 +124,15 @@ end local function update_all_wiboxes_position() for _, wprop in ipairs(wiboxes) do set_position(wprop.wibox, wprop.position) - hooks.user.call("wibox_position", wprop.wibox) + capi.awesome.emit_signal("arrange", wprop.wibox.screen) end end +local function call_wibox_position_hook_on_prop_update(w) + capi.awesome.emit_signal("arrange", w.screen) + update_all_wiboxes_position() +end + --- Attach a wibox to a screen. -- If a wibox is attached, it will be automatically be moved when other wiboxes -- will be attached. @@ -166,6 +168,9 @@ function attach(wibox, position) if wibox.screen and wibox.visible then update_all_wiboxes_position() end + + wibox:add_signal("property::screen", call_wibox_position_hook_on_prop_update) + wibox:add_signal("property::visible", call_wibox_position_hook_on_prop_update) end --- Align a wibox. @@ -338,17 +343,6 @@ function rounded_corners(wibox, corner_size) wibox.shape_bounding = do_rounded_corners(wibox.width + border * 2, wibox.height + border * 2, corner_size + border) end -local function update_wiboxes_position(obj, prop) - if (type(obj) == "wibox" - and (prop == nil - or prop == "visible" - or prop == "screen")) - or (type(obj) == "client" - and prop == "struts") then - update_all_wiboxes_position() - end -end - local function update_wiboxes_on_struts(c) local struts = c:struts() if struts.left ~= 0 or struts.right ~= 0 @@ -358,8 +352,10 @@ local function update_wiboxes_on_struts(c) end -- Hook registered to reset all wiboxes position. -hooks.property.register(update_wiboxes_position) -capi.client.add_signal("manage", update_wiboxes_on_struts) +capi.client.add_signal("manage", function(c) + update_wiboxes_on_struts(c) + c:add_signal("property::struts", update_wiboxes_on_struts) +end) capi.client.add_signal("unmanage", update_wiboxes_on_struts) setmetatable(_M, { __call = function(_, ...) return new(...) end }) diff --git a/lib/awful/widget/layoutbox.lua.in b/lib/awful/widget/layoutbox.lua.in index 1a893721..5017796a 100644 --- a/lib/awful/widget/layoutbox.lua.in +++ b/lib/awful/widget/layoutbox.lua.in @@ -5,6 +5,7 @@ --------------------------------------------------------------------------- local setmetatable = setmetatable +local ipairs = ipairs local button = require("awful.button") local layout = require("awful.layout") local beautiful = require("beautiful") @@ -37,7 +38,7 @@ function new(screen, args) update(w, screen) local function update_on_tag_selection(tag) - return update(w, tag) + return update(w, tag.screen) end capi.screen[screen]:add_signal("tag::attach", function(s, tag) @@ -48,6 +49,11 @@ function new(screen, args) tag:remove_signal("property::selected", update_on_tag_selection) tag:remove_signal("property::layout", update_on_tag_selection) end) + + for _, tag in ipairs(capi.screen[screen]:tags()) do + tag:add_signal("property::selected", update_on_tag_selection) + tag:add_signal("property::layout", update_on_tag_selection) + end return w end diff --git a/lib/awful/widget/taglist.lua.in b/lib/awful/widget/taglist.lua.in index ae704ab6..fd192777 100644 --- a/lib/awful/widget/taglist.lua.in +++ b/lib/awful/widget/taglist.lua.in @@ -14,7 +14,6 @@ local setmetatable = setmetatable local pairs = pairs local ipairs = ipairs local table = table -local hooks = require("awful.hooks") local common = require("awful.widget.common") local util = require("awful.util") local tag = require("awful.tag") @@ -67,15 +66,34 @@ function new(screen, label, buttons) local uc = function (c) return u(c.screen) end capi.client.add_signal("focus", uc) capi.client.add_signal("unfocus", uc) - hooks.tags.register(u) - hooks.tagged.register(uc) - hooks.property.register(function (c, prop) - if (type(c) == "client" and prop == "urgent") - or (type(c) == "tag" and - (prop == "icon" or prop == "hide")) then - u(c.screen) - end + capi.screen[screen]:add_signal("tag::attach", function(screen, tag) + taglist_update(s, w, label, buttons, data, widgets) + tag:add_signal("property::selected", uc) + tag:add_signal("property::icon", uc) + tag:add_signal("property::hide", uc) + end) + capi.screen[screen]:add_signal("tag::detach", function(screen, tag) + taglist_update(s, w, label, buttons, data, widgets) + tag:remove_signal("property::selected", uc) + tag:remove_signal("property::icon", uc) + tag:remove_signal("property::hide", uc) + end) + for _, tag in ipairs(capi.screen[screen]:tags()) do + tag:add_signal("property::selected", uc) + tag:add_signal("property::icon", uc) + tag:add_signal("property::hide", uc) + end + capi.client.add_signal("new", function(c) + c:add_signal("property::urgent", uc) + c:add_signal("property::screen", function(c) + -- If client change screen, refresh it anyway since we don't from + -- which screen it was coming :-) + u(screen) + end) + c:add_signal("tagged", uc) + c:add_signal("untagged", uc) end) + capi.client.add_signal("unmanage", uc) u(screen) return w end diff --git a/lib/awful/widget/tasklist.lua.in b/lib/awful/widget/tasklist.lua.in index e018d634..90ff8dea 100644 --- a/lib/awful/widget/tasklist.lua.in +++ b/lib/awful/widget/tasklist.lua.in @@ -12,7 +12,6 @@ local ipairs = ipairs local type = type local setmetatable = setmetatable local table = table -local hooks = require("awful.hooks") local common = require("awful.widget.common") local beautiful = require("beautiful") local client = require("awful.client") @@ -55,24 +54,35 @@ function new(label, buttons) } local data = setmetatable({}, { __mode = 'k' }) local u = function () tasklist_update(w, buttons, label, data, widgets) end - hooks.tags.register(u) + for s = 1, capi.screen.count() do + capi.screen[s]:add_signal("tag::attach", function (s, t) + u() + t:add_signal("property::selected", u) + end) + capi.screen[s]:add_signal("tag::detach", function (s, t) + u() + t:remove_signal("property::selected", u) + end) + for _, tag in ipairs(capi.screen[s]:tags()) do + tag:add_signal("property::selected", u) + end + end + capi.client.add_signal("new", function (c) + c:add_signal("property::urgent", u) + c:add_signal("property::floating", u) + c:add_signal("property::maximized_horizontal", u) + c:add_signal("property::maximized_vertical", u) + c:add_signal("property::name", u) + c:add_signal("property::name", u) + c:add_signal("property::icon_name", u) + c:add_signal("property::skip_taskbar", u) + c:add_signal("tagged", u) + c:add_signal("untagged", u) + end) + capi.client.add_signal("unmanage", u) capi.client.add_signal("list", u) - hooks.tagged.register(u) capi.client.add_signal("focus", u) capi.client.add_signal("unfocus", u) - hooks.property.register(function (c, prop) - if type(c) ~= "client" then return end - if prop == "urgent" - or prop == "floating" - or prop == "maximized_horizontal" - or prop == "maximized_vertical" - or prop == "icon" - or prop == "name" - or prop == "icon_name" - or prop == "skip_taskbar" then - u() - end - end) u() return w end