naughty.box: Allow constructor arguments to be passed to `wibox()`.

Because it was using a metatable proxy instead of a full copy,
`pairs()` wasn't working and thus any code based on it was
blind to the `args`.

Fixes #2956
This commit is contained in:
Emmanuel Lepage Vallee 2020-01-12 19:34:39 -05:00
parent 21caa19a21
commit ef7e4ce967
1 changed files with 7 additions and 5 deletions

View File

@ -274,15 +274,15 @@ local function new(args)
border_color = args.border_color or beautiful.notification_border_color, border_color = args.border_color or beautiful.notification_border_color,
} }
-- The C code needs `pairs` to work, so a full copy is required.
gtable.crush(new_args, args, true)
-- Add a weak-table layer for the screen. -- Add a weak-table layer for the screen.
local weak_args = setmetatable({ local weak_args = setmetatable({
screen = args.notification and args.notification.screen or nil screen = args.notification and args.notification.screen or nil
}, {__index = args, __mode = "v"}) }, {__mode="v"})
-- This will cascade from the overriden `new_args` to the weak `weak_args` setmetatable(new_args, {__index = weak_args})
-- to the original arguments. This way the original wont be modified and
-- the screen wont leak.
new_args = setmetatable(new_args, {__index = weak_args})
-- Generate the box before the popup is created to avoid the size changing -- Generate the box before the popup is created to avoid the size changing
new_args.widget = generate_widget(new_args, new_args.notification) new_args.widget = generate_widget(new_args, new_args.notification)
@ -316,6 +316,8 @@ local function new(args)
abutton({ }, 3, hide) abutton({ }, 3, hide)
)) ))
gtable.crush(ret, box, false)
return ret return ret
end end