wibar: Fix a race condition when adding new wibars

Fix #1523
This commit is contained in:
Emmanuel Lepage Vallee 2017-02-13 16:08:30 -05:00
parent 77c92d0d63
commit a158c3adab
1 changed files with 17 additions and 7 deletions

View File

@ -108,7 +108,7 @@ local function get_position(wb)
return wb._position or "top" return wb._position or "top"
end end
local function set_position(wb, position) local function set_position(wb, position, skip_reattach)
-- Detach first to avoid any uneeded callbacks -- Detach first to avoid any uneeded callbacks
if wb.detach_callback then if wb.detach_callback then
wb.detach_callback() wb.detach_callback()
@ -137,16 +137,20 @@ local function set_position(wb, position)
wb.width = math.ceil(beautiful.get_font_height(wb.font) * 1.5) wb.width = math.ceil(beautiful.get_font_height(wb.font) * 1.5)
end end
-- Changing the position will also cause the other margins to be invalidated.
-- For example, adding a wibar to the top will change the margins of any left
-- or right wibars. To solve, this, they need to be re-attached.
reattach(wb)
-- Set the new position -- Set the new position
wb._position = position wb._position = position
-- Attach to the new position -- Attach to the new position
attach(wb, position) attach(wb, position)
-- A way to skip reattach is required when first adding a wibar as it's not
-- in the `wiboxes` table yet and can't be added until it's attached.
if not skip_reattach then
-- Changing the position will also cause the other margins to be invalidated.
-- For example, adding a wibar to the top will change the margins of any left
-- or right wibars. To solve, this, they need to be re-attached.
reattach(wb)
end
end end
--- Stretch the wibar. --- Stretch the wibar.
@ -350,10 +354,16 @@ function awfulwibar.new(arg)
if arg.visible == nil then w.visible = true end if arg.visible == nil then w.visible = true end
w:set_position(position) -- `w` needs to be inserted in `wiboxes` before reattach or its own offset
-- will not be taken into account by the "older" wibars when `reattach` is
-- called. `skip_reattach` is required.
w:set_position(position, true)
table.insert(wiboxes, w) table.insert(wiboxes, w)
-- Force all the wibars to be moved
reattach(w)
w:connect_signal("property::visible", function() reattach(w) end) w:connect_signal("property::visible", function() reattach(w) end)
return w return w