layoutbox: Modernize the constructor.

Another step in the long running project to unify all constructors
design.
This commit is contained in:
Emmanuel Lepage Vallee 2018-12-26 21:38:08 -05:00
parent 29e804a4f8
commit f747438879
1 changed files with 30 additions and 5 deletions

View File

@ -1,5 +1,6 @@
--------------------------------------------------------------------------- ---------------------------------------------------------------------------
--- Layoutbox widget. --- Display the current client layout (`awful.layout`) icon or name
--
-- --
-- @author Julien Danjou <julien@danjou.info> -- @author Julien Danjou <julien@danjou.info>
-- @copyright 2009 Julien Danjou -- @copyright 2009 Julien Danjou
@ -13,6 +14,8 @@ local tooltip = require("awful.tooltip")
local beautiful = require("beautiful") local beautiful = require("beautiful")
local wibox = require("wibox") local wibox = require("wibox")
local surface = require("gears.surface") local surface = require("gears.surface")
-- local gdebug = require("gears.debug")
local gtable = require("gears.table")
local function get_screen(s) local function get_screen(s)
return s and capi.screen[s] return s and capi.screen[s]
@ -42,10 +45,25 @@ end
--- Create a layoutbox widget. It draws a picture with the current layout --- Create a layoutbox widget. It draws a picture with the current layout
-- symbol of the current tag. -- symbol of the current tag.
-- @param screen The screen number that the layout will be represented for. -- @tparam table args The arguments.
-- @return An imagebox widget configured as a layoutbox. -- @tparam screen args.screen The screen number that the layout will be represented for.
-- @constructorfct awful.widget.layoutbox -- @tparam table args.buttons The `awful.button`s for this layoutbox.
function layoutbox.new(screen) -- @return The layoutbox.
function layoutbox.new(args)
args = args or {}
local screen = nil
if type(args) == "number" or type(args) == "screen" or args.fake_remove then
screen, args = args, {}
--TODO uncomment
-- gdebug.deprecate(
-- "Use awful.widget.layoutbox{screen=s} instead of awful.widget.layoutbox(screen)",
-- {deprecated_in=5}
-- )
end
assert(type(args) == "table")
screen = get_screen(screen or 1) screen = get_screen(screen or 1)
-- Do we already have the update callbacks registered? -- Do we already have the update callbacks registered?
@ -80,6 +98,9 @@ function layoutbox.new(screen)
w._layoutbox_tooltip = tooltip {objects = {w}, delay_show = 1} w._layoutbox_tooltip = tooltip {objects = {w}, delay_show = 1}
-- Apply the buttons, visible, forced_width and so on
gtable.crush(w, args)
update(w, screen) update(w, screen)
boxes[screen] = w boxes[screen] = w
end end
@ -91,6 +112,10 @@ function layoutbox.mt:__call(...)
return layoutbox.new(...) return layoutbox.new(...)
end end
--@DOC_widget_COMMON@
--@DOC_object_COMMON@
return setmetatable(layoutbox, layoutbox.mt) return setmetatable(layoutbox, layoutbox.mt)
-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80 -- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80