layoutbox: Modernize the constructor.
Another step in the long running project to unify all constructors design.
This commit is contained in:
parent
29e804a4f8
commit
f747438879
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue