awful.rules: apply accumulated rule properties (FS#669)

To avoid the screen flickering, when two rules have different tags
with true switchtotag.

Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
Anton Bobrov 2009-10-25 00:05:09 +11:00 committed by Julien Danjou
parent 3f565f1a3d
commit ad50440d5c
1 changed files with 26 additions and 22 deletions

View File

@ -81,34 +81,38 @@ end
--- Apply rules to a client. --- Apply rules to a client.
-- @param c The client. -- @param c The client.
function apply(c) function apply(c)
local props = {}
for _, entry in ipairs(rules) do for _, entry in ipairs(rules) do
if match(c, entry.rule) then if match(c, entry.rule) then
for property, value in pairs(entry.properties) do for property, value in pairs(entry.properties) do
if property == "floating" then props[property] = value
aclient.floating.set(c, value)
elseif property == "tag" then
aclient.movetotag(value, c)
elseif property == "switchtotag" and value
and entry.properties["tag"] then
atag.viewonly(entry.properties["tag"])
elseif property == "height" or property == "width" or
property == "x" or property == "y" then
local geo = c:geometry();
geo[property] = value
c:geometry(geo);
elseif type(c[property]) == "function" then
c[property](c, value)
else
c[property] = value
end
end
-- Do this at last so we do not erase things done by the focus
-- signal.
if entry.properties.focus then
client.focus = c
end end
end end
end end
for property, value in pairs(props) do
if property == "floating" then
aclient.floating.set(c, value)
elseif property == "tag" then
aclient.movetotag(value, c)
elseif property == "switchtotag" and value and props.tag then
atag.viewonly(props.tag)
elseif property == "height" or property == "width" or
property == "x" or property == "y" then
local geo = c:geometry();
geo[property] = value
c:geometry(geo);
elseif type(c[property]) == "function" then
c[property](c, value)
else
c[property] = value
end
end
-- Do this at last so we do not erase things done by the focus
-- signal.
if props.focus then
client.focus = c
end
end end
client.add_signal("manage", apply) client.add_signal("manage", apply)