doc: Major client documentation backfill.
This commit mostly rewrite the client documentation and pay the technical debt accumulated over the years. Most of the client documentation was still one-liners from the luadoc era. It now has all the new tags, type. It also has actual description of what the properties do beyond the name.
This commit is contained in:
parent
20743a9a16
commit
5e720c9744
|
@ -74,7 +74,7 @@ client.focus = require("awful.client.focus")
|
||||||
|
|
||||||
--- When applying the placement, honor the screen padding.
|
--- When applying the placement, honor the screen padding.
|
||||||
-- @clientruleproperty honor_padding
|
-- @clientruleproperty honor_padding
|
||||||
-- @param[opt=true] boolean
|
-- @tparam[opt=true] boolean honor_padding
|
||||||
-- @see awful.placement
|
-- @see awful.placement
|
||||||
|
|
||||||
--- When applying the placement, honor the screen work area.
|
--- When applying the placement, honor the screen work area.
|
||||||
|
@ -82,7 +82,7 @@ client.focus = require("awful.client.focus")
|
||||||
-- The workarea is the part of the screen that excludes the bars and docks.
|
-- The workarea is the part of the screen that excludes the bars and docks.
|
||||||
--
|
--
|
||||||
-- @clientruleproperty honor_workarea
|
-- @clientruleproperty honor_workarea
|
||||||
-- @param[opt=true] boolean
|
-- @tparam[opt=true] boolean honor_workarea
|
||||||
-- @see awful.placement
|
-- @see awful.placement
|
||||||
|
|
||||||
--- The client default tag.
|
--- The client default tag.
|
||||||
|
@ -90,7 +90,7 @@ client.focus = require("awful.client.focus")
|
||||||
-- @DOC_sequences_client_rules_tags_EXAMPLE@
|
-- @DOC_sequences_client_rules_tags_EXAMPLE@
|
||||||
--
|
--
|
||||||
-- @clientruleproperty tag
|
-- @clientruleproperty tag
|
||||||
-- @param tag
|
-- @tparam tag tag
|
||||||
-- @see tag
|
-- @see tag
|
||||||
-- @see new_tag
|
-- @see new_tag
|
||||||
-- @see tags
|
-- @see tags
|
||||||
|
@ -102,7 +102,7 @@ client.focus = require("awful.client.focus")
|
||||||
-- issues.
|
-- issues.
|
||||||
--
|
--
|
||||||
-- @clientruleproperty tags
|
-- @clientruleproperty tags
|
||||||
-- @param[opt={tag}] table
|
-- @tparam[opt={tag}] table tags
|
||||||
-- @see tag
|
-- @see tag
|
||||||
-- @see new_tag
|
-- @see new_tag
|
||||||
-- @see tags
|
-- @see tags
|
||||||
|
@ -130,7 +130,7 @@ client.focus = require("awful.client.focus")
|
||||||
-- @DOC_sequences_client_rules_switch_to_tags_EXAMPLE@
|
-- @DOC_sequences_client_rules_switch_to_tags_EXAMPLE@
|
||||||
--
|
--
|
||||||
-- @clientruleproperty switch_to_tags
|
-- @clientruleproperty switch_to_tags
|
||||||
-- @param[opt=false] boolean
|
-- @tparam[opt=false] boolean switch_to_tags
|
||||||
-- @see tag.selected
|
-- @see tag.selected
|
||||||
|
|
||||||
--- Define if the client should grab focus by default.
|
--- Define if the client should grab focus by default.
|
||||||
|
@ -138,11 +138,11 @@ client.focus = require("awful.client.focus")
|
||||||
-- The `request::activate` context for this call is `rules`.
|
-- The `request::activate` context for this call is `rules`.
|
||||||
--
|
--
|
||||||
-- @clientruleproperty focus
|
-- @clientruleproperty focus
|
||||||
-- @param[opt=false] boolean
|
-- @tparam[opt=false] boolean focus
|
||||||
|
|
||||||
--- Should this client have a titlebar by default.
|
--- Should this client have a titlebar by default.
|
||||||
-- @clientruleproperty titlebars_enabled
|
-- @clientruleproperty titlebars_enabled
|
||||||
-- @param[opt=false] boolean
|
-- @tparam[opt=false] boolean titlebars_enabled
|
||||||
-- @see awful.titlebar
|
-- @see awful.titlebar
|
||||||
|
|
||||||
--- A function to call when this client is ready.
|
--- A function to call when this client is ready.
|
||||||
|
@ -177,6 +177,8 @@ end
|
||||||
-- tag as arguments.
|
-- tag as arguments.
|
||||||
-- @request client activate client.jumpto granted When a client is activated
|
-- @request client activate client.jumpto granted When a client is activated
|
||||||
-- because `c:jump_to()` is called.
|
-- because `c:jump_to()` is called.
|
||||||
|
-- @see activate
|
||||||
|
-- @see active
|
||||||
function client.object.jump_to(self, merge)
|
function client.object.jump_to(self, merge)
|
||||||
local s = get_screen(screen.focused())
|
local s = get_screen(screen.focused())
|
||||||
-- focus the screen
|
-- focus the screen
|
||||||
|
@ -251,7 +253,7 @@ end
|
||||||
-- @tparam int i The index. Use 1 to get the next, -1 to get the previous.
|
-- @tparam int i The index. Use 1 to get the next, -1 to get the previous.
|
||||||
-- @client[opt] sel The client.
|
-- @client[opt] sel The client.
|
||||||
-- @tparam[opt=false] boolean stacked Use stacking order? (top to bottom)
|
-- @tparam[opt=false] boolean stacked Use stacking order? (top to bottom)
|
||||||
-- @return A client, or nil if no client is available.
|
-- @treturn[opt] client|nil A client, or nil if no client is available.
|
||||||
--
|
--
|
||||||
-- @usage -- focus the next window in the index
|
-- @usage -- focus the next window in the index
|
||||||
-- awful.client.next(1)
|
-- awful.client.next(1)
|
||||||
|
@ -282,10 +284,16 @@ function client.next(i, sel, stacked)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Swap a client with another client in the given direction.
|
--- Swap a client with another client in the given direction.
|
||||||
|
--
|
||||||
-- @staticfct awful.client.swap.bydirection
|
-- @staticfct awful.client.swap.bydirection
|
||||||
-- @tparam string dir The direction, can be either "up", "down", "left" or "right".
|
-- @tparam string dir The direction, can be either "up", "down", "left" or "right".
|
||||||
-- @client[opt=focused] c The client.
|
-- @client[opt=focused] c The client.
|
||||||
-- @tparam[opt=false] boolean stacked Use stacking order? (top to bottom)
|
-- @tparam[opt=false] boolean stacked Use stacking order? (top to bottom)
|
||||||
|
-- @see swap
|
||||||
|
-- @see swapped
|
||||||
|
-- @see awful.client.swap.global_bydirection
|
||||||
|
-- @see awful.client.swap.byidx
|
||||||
|
-- @see awful.client.cycle
|
||||||
function client.swap.bydirection(dir, c, stacked)
|
function client.swap.bydirection(dir, c, stacked)
|
||||||
local sel = c or capi.client.focus
|
local sel = c or capi.client.focus
|
||||||
if sel then
|
if sel then
|
||||||
|
@ -304,12 +312,18 @@ function client.swap.bydirection(dir, c, stacked)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Swap a client with another client in the given direction.
|
--- Swap a client with another client in the given direction.
|
||||||
|
--
|
||||||
-- Swaps across screens.
|
-- Swaps across screens.
|
||||||
-- @staticfct awful.client.swap.global_bydirection
|
-- @staticfct awful.client.swap.global_bydirection
|
||||||
-- @param dir The direction, can be either "up", "down", "left" or "right".
|
-- @tparam string dir The direction, can be either "up", "down", "left" or "right".
|
||||||
-- @client[opt] sel The client.
|
-- @client[opt] sel The client.
|
||||||
-- @request client activate client.swap.global_bydirection granted When a client
|
-- @request client activate client.swap.global_bydirection granted When a client
|
||||||
-- could be activated because `awful.client.swap.global_bydirection` was called.
|
-- could be activated because `awful.client.swap.global_bydirection` was called.
|
||||||
|
-- @see swap
|
||||||
|
-- @see swapped
|
||||||
|
-- @see awful.client.swap.bydirection
|
||||||
|
-- @see awful.client.swap.byidx
|
||||||
|
-- @see awful.client.cycle
|
||||||
function client.swap.global_bydirection(dir, sel)
|
function client.swap.global_bydirection(dir, sel)
|
||||||
sel = sel or capi.client.focus
|
sel = sel or capi.client.focus
|
||||||
local scr = get_screen(sel and sel.screen or screen.focused())
|
local scr = get_screen(sel and sel.screen or screen.focused())
|
||||||
|
@ -340,9 +354,15 @@ function client.swap.global_bydirection(dir, sel)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Swap a client by its relative index.
|
--- Swap a client by its relative index.
|
||||||
|
--
|
||||||
-- @staticfct awful.client.swap.byidx
|
-- @staticfct awful.client.swap.byidx
|
||||||
-- @param i The index.
|
-- @tparam integer i The index.
|
||||||
-- @client[opt] c The client, otherwise focused one is used.
|
-- @client[opt] c The client, otherwise focused one is used.
|
||||||
|
-- @see swap
|
||||||
|
-- @see swapped
|
||||||
|
-- @see awful.client.swap.bydirection
|
||||||
|
-- @see awful.client.swap.global_bydirection
|
||||||
|
-- @see awful.client.cycle
|
||||||
function client.swap.byidx(i, c)
|
function client.swap.byidx(i, c)
|
||||||
local sel = c or capi.client.focus
|
local sel = c or capi.client.focus
|
||||||
local target = client.next(i, sel)
|
local target = client.next(i, sel)
|
||||||
|
@ -351,12 +371,20 @@ function client.swap.byidx(i, c)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Cycle clients.
|
--- Cycle through the clients to change the focus.
|
||||||
|
--
|
||||||
|
-- This will swap the client from one position to the next
|
||||||
|
-- in the layout.
|
||||||
--
|
--
|
||||||
-- @staticfct awful.client.cycle
|
-- @staticfct awful.client.cycle
|
||||||
-- @param clockwise True to cycle clients clockwise.
|
-- @tparam boolean clockwise True to cycle clients clockwise.
|
||||||
-- @param[opt] s The screen where to cycle clients.
|
-- @tparam[opt] screen s The screen where to cycle clients.
|
||||||
-- @tparam[opt=false] boolean stacked Use stacking order? (top to bottom)
|
-- @tparam[opt=false] boolean stacked Use stacking order? (top to bottom)
|
||||||
|
-- @see swap
|
||||||
|
-- @see swapped
|
||||||
|
-- @see awful.client.swap.bydirection
|
||||||
|
-- @see awful.client.swap.global_bydirection
|
||||||
|
-- @see awful.client.swap.byidx
|
||||||
function client.cycle(clockwise, s, stacked)
|
function client.cycle(clockwise, s, stacked)
|
||||||
s = s or screen.focused()
|
s = s or screen.focused()
|
||||||
local cls = client.visible(s, stacked)
|
local cls = client.visible(s, stacked)
|
||||||
|
@ -402,7 +430,7 @@ end
|
||||||
--
|
--
|
||||||
-- @legacylayout awful.client.getmaster
|
-- @legacylayout awful.client.getmaster
|
||||||
-- @screen_or_idx[opt=awful.screen.focused()] s The screen.
|
-- @screen_or_idx[opt=awful.screen.focused()] s The screen.
|
||||||
-- @return The master window.
|
-- @treturn client The master client.
|
||||||
function client.getmaster(s)
|
function client.getmaster(s)
|
||||||
s = s or screen.focused()
|
s = s or screen.focused()
|
||||||
return client.visible(s)[1]
|
return client.visible(s)[1]
|
||||||
|
@ -431,10 +459,10 @@ end
|
||||||
|
|
||||||
--- Move/resize a client relative to current coordinates.
|
--- Move/resize a client relative to current coordinates.
|
||||||
-- @deprecated awful.client.moveresize
|
-- @deprecated awful.client.moveresize
|
||||||
-- @param x The relative x coordinate.
|
-- @tparam integer x The relative x coordinate.
|
||||||
-- @param y The relative y coordinate.
|
-- @tparam integer y The relative y coordinate.
|
||||||
-- @param w The relative width.
|
-- @tparam integer w The relative width.
|
||||||
-- @param h The relative height.
|
-- @tparam integer h The relative height.
|
||||||
-- @client[opt] c The client, otherwise focused one is used.
|
-- @client[opt] c The client, otherwise focused one is used.
|
||||||
-- @see client.relative_move
|
-- @see client.relative_move
|
||||||
function client.moveresize(x, y, w, h, c)
|
function client.moveresize(x, y, w, h, c)
|
||||||
|
@ -460,7 +488,7 @@ end
|
||||||
|
|
||||||
--- Move a client to a tag.
|
--- Move a client to a tag.
|
||||||
-- @deprecated awful.client.movetotag
|
-- @deprecated awful.client.movetotag
|
||||||
-- @param target The tag to move the client to.
|
-- @tparam tag target The tag to move the client to.
|
||||||
-- @client[opt] c The client to move, otherwise the focused one is used.
|
-- @client[opt] c The client to move, otherwise the focused one is used.
|
||||||
-- @see client.move_to_tag
|
-- @see client.move_to_tag
|
||||||
function client.movetotag(target, c)
|
function client.movetotag(target, c)
|
||||||
|
@ -469,10 +497,12 @@ function client.movetotag(target, c)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Move a client to a tag.
|
--- Move a client to a tag.
|
||||||
|
--
|
||||||
-- @method move_to_tag
|
-- @method move_to_tag
|
||||||
-- @tparam tag target The tag to move the client to.
|
-- @tparam tag target The tag to move the client to.
|
||||||
-- @request client activate client.movetotag granted When a client could be
|
-- @request client activate client.movetotag granted When a client could be
|
||||||
-- activated because `c:move_to_tag()` was called.
|
-- activated because `c:move_to_tag()` was called.
|
||||||
|
-- @see tags
|
||||||
function client.object.move_to_tag(self, target)
|
function client.object.move_to_tag(self, target)
|
||||||
local s = target.screen
|
local s = target.screen
|
||||||
if self and s then
|
if self and s then
|
||||||
|
@ -486,18 +516,22 @@ function client.object.move_to_tag(self, target)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Toggle a tag on a client.
|
--- Toggle a tag on a client.
|
||||||
|
--
|
||||||
-- @deprecated awful.client.toggletag
|
-- @deprecated awful.client.toggletag
|
||||||
-- @param target The tag to toggle.
|
-- @tparam tag target The tag to toggle.
|
||||||
-- @client[opt] c The client to toggle, otherwise the focused one is used.
|
-- @client[opt] c The client to toggle, otherwise the focused one is used.
|
||||||
-- @see client.toggle_tag
|
-- @see client.toggle_tag
|
||||||
|
-- @see tags
|
||||||
function client.toggletag(target, c)
|
function client.toggletag(target, c)
|
||||||
gdebug.deprecate("Use c:toggle_tag(target) instead of awful.client.toggletag", {deprecated_in=4})
|
gdebug.deprecate("Use c:toggle_tag(target) instead of awful.client.toggletag", {deprecated_in=4})
|
||||||
client.object.toggle_tag(c or capi.client.focus, target)
|
client.object.toggle_tag(c or capi.client.focus, target)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Toggle a tag on a client.
|
--- Toggle a tag on a client.
|
||||||
|
--
|
||||||
-- @method toggle_tag
|
-- @method toggle_tag
|
||||||
-- @tparam tag target The tag to move the client to.
|
-- @tparam tag target The tag to move the client to.
|
||||||
|
-- @see tags
|
||||||
function client.object.toggle_tag(self, target)
|
function client.object.toggle_tag(self, target)
|
||||||
-- Check that tag and client screen are identical
|
-- Check that tag and client screen are identical
|
||||||
if self and get_screen(self.screen) == get_screen(target.screen) then
|
if self and get_screen(self.screen) == get_screen(target.screen) then
|
||||||
|
@ -523,7 +557,7 @@ end
|
||||||
--- Move a client to a screen. Default is next screen, cycling.
|
--- Move a client to a screen. Default is next screen, cycling.
|
||||||
-- @deprecated awful.client.movetoscreen
|
-- @deprecated awful.client.movetoscreen
|
||||||
-- @client c The client to move.
|
-- @client c The client to move.
|
||||||
-- @param s The screen, default to current + 1.
|
-- @tparam screen s The screen, default to current + 1.
|
||||||
-- @see screen
|
-- @see screen
|
||||||
-- @see client.move_to_screen
|
-- @see client.move_to_screen
|
||||||
function client.movetoscreen(c, s)
|
function client.movetoscreen(c, s)
|
||||||
|
@ -590,14 +624,11 @@ end
|
||||||
|
|
||||||
--- If a client is marked or not.
|
--- If a client is marked or not.
|
||||||
--
|
--
|
||||||
-- **Signal:**
|
|
||||||
--
|
|
||||||
-- * *marked* (for legacy reasons, use `property::marked`)
|
|
||||||
-- * *unmarked* (for legacy reasons, use `property::marked`)
|
|
||||||
-- * *property::marked*
|
|
||||||
--
|
|
||||||
-- @property marked
|
-- @property marked
|
||||||
-- @param boolean
|
-- @tparam boolean marked
|
||||||
|
-- @emits marked (for legacy reasons, use `property::marked`)
|
||||||
|
-- @emits unmarker (for legacy reasons, use `property::marked`)
|
||||||
|
-- @emits property::marked
|
||||||
|
|
||||||
--- The border color when the client is focused.
|
--- The border color when the client is focused.
|
||||||
--
|
--
|
||||||
|
@ -664,7 +695,7 @@ end
|
||||||
|
|
||||||
--- Return the marked clients and empty the marked table.
|
--- Return the marked clients and empty the marked table.
|
||||||
-- @deprecated awful.client.getmarked
|
-- @deprecated awful.client.getmarked
|
||||||
-- @return A table with all marked clients.
|
-- @treturn table A table with all marked clients.
|
||||||
function client.getmarked()
|
function client.getmarked()
|
||||||
local copy = gtable.clone(client.data.marked, false)
|
local copy = gtable.clone(client.data.marked, false)
|
||||||
|
|
||||||
|
@ -682,7 +713,7 @@ end
|
||||||
-- Floating client are not handled by tiling layouts.
|
-- Floating client are not handled by tiling layouts.
|
||||||
-- @deprecated awful.client.floating.set
|
-- @deprecated awful.client.floating.set
|
||||||
-- @client c A client.
|
-- @client c A client.
|
||||||
-- @param s True or false.
|
-- @tparam boolean s True or false.
|
||||||
function client.floating.set(c, s)
|
function client.floating.set(c, s)
|
||||||
gdebug.deprecate("Use c.floating = true instead of awful.client.floating.set", {deprecated_in=4})
|
gdebug.deprecate("Use c.floating = true instead of awful.client.floating.set", {deprecated_in=4})
|
||||||
client.object.set_floating(c, s)
|
client.object.set_floating(c, s)
|
||||||
|
@ -691,7 +722,7 @@ end
|
||||||
-- Set a client floating state, overriding auto-detection.
|
-- Set a client floating state, overriding auto-detection.
|
||||||
-- Floating client are not handled by tiling layouts.
|
-- Floating client are not handled by tiling layouts.
|
||||||
-- @client c A client.
|
-- @client c A client.
|
||||||
-- @param s True or false.
|
-- @tparam boolan s True or false.
|
||||||
function client.object.set_floating(c, s)
|
function client.object.set_floating(c, s)
|
||||||
c = c or capi.client.focus
|
c = c or capi.client.focus
|
||||||
if c and client.property.get(c, "floating") ~= s then
|
if c and client.property.get(c, "floating") ~= s then
|
||||||
|
@ -741,13 +772,10 @@ end
|
||||||
|
|
||||||
--- Return if a client has a fixed size or not.
|
--- Return if a client has a fixed size or not.
|
||||||
--
|
--
|
||||||
-- **Signal:**
|
|
||||||
--
|
|
||||||
-- * *property::is_fixed*
|
|
||||||
--
|
|
||||||
-- This property is read only.
|
-- This property is read only.
|
||||||
-- @property is_fixed
|
-- @property is_fixed
|
||||||
-- @param boolean The fixed size state
|
-- @tparam[opt=false] boolean is_fixed The fixed size state
|
||||||
|
-- @propemits false false
|
||||||
-- @see size_hints
|
-- @see size_hints
|
||||||
-- @see size_hints_honor
|
-- @see size_hints_honor
|
||||||
|
|
||||||
|
@ -772,7 +800,7 @@ end
|
||||||
--
|
--
|
||||||
-- This property is read only.
|
-- This property is read only.
|
||||||
-- @property immobilized_horizontal
|
-- @property immobilized_horizontal
|
||||||
-- @param boolean The immobilized state
|
-- @tparam[opt=false] boolean immobilized_horizontal The immobilized state
|
||||||
-- @see maximized
|
-- @see maximized
|
||||||
-- @see maximized_horizontal
|
-- @see maximized_horizontal
|
||||||
-- @see fullscreen
|
-- @see fullscreen
|
||||||
|
@ -788,7 +816,7 @@ end
|
||||||
--
|
--
|
||||||
-- This property is read only.
|
-- This property is read only.
|
||||||
-- @property immobilized_vertical
|
-- @property immobilized_vertical
|
||||||
-- @param boolean The immobilized state
|
-- @tparam[opt=false] boolean immobilized_vertical The immobilized state
|
||||||
-- @see maximized
|
-- @see maximized
|
||||||
-- @see maximized_vertical
|
-- @see maximized_vertical
|
||||||
-- @see fullscreen
|
-- @see fullscreen
|
||||||
|
@ -801,7 +829,7 @@ end
|
||||||
-- @client c A client.
|
-- @client c A client.
|
||||||
-- @see floating
|
-- @see floating
|
||||||
-- @deprecated awful.client.floating.get
|
-- @deprecated awful.client.floating.get
|
||||||
-- @return True or false. Note that some windows might be floating even if you
|
-- @treturn boolean True or false. Note that some windows might be floating even if you
|
||||||
-- did not set them manually. For example, windows with a type different than
|
-- did not set them manually. For example, windows with a type different than
|
||||||
-- normal.
|
-- normal.
|
||||||
function client.floating.get(c)
|
function client.floating.get(c)
|
||||||
|
@ -817,10 +845,6 @@ end
|
||||||
-- did not set them manually. For example, windows with a type different than
|
-- did not set them manually. For example, windows with a type different than
|
||||||
-- normal.
|
-- normal.
|
||||||
--
|
--
|
||||||
-- **Signal:**
|
|
||||||
--
|
|
||||||
-- * *property::floating*
|
|
||||||
--
|
|
||||||
-- @property floating
|
-- @property floating
|
||||||
-- @tparam boolean floating The floating state.
|
-- @tparam boolean floating The floating state.
|
||||||
-- @request client border floating granted When a border update is required
|
-- @request client border floating granted When a border update is required
|
||||||
|
@ -829,6 +853,7 @@ end
|
||||||
-- floating.
|
-- floating.
|
||||||
-- @request client border inactive granted When a client stop being active and
|
-- @request client border inactive granted When a client stop being active and
|
||||||
-- is not floating.
|
-- is not floating.
|
||||||
|
-- @propemits false false
|
||||||
|
|
||||||
function client.object.get_floating(c)
|
function client.object.get_floating(c)
|
||||||
c = c or capi.client.focus
|
c = c or capi.client.focus
|
||||||
|
@ -901,39 +926,43 @@ end
|
||||||
|
|
||||||
--- The x coordinates.
|
--- The x coordinates.
|
||||||
--
|
--
|
||||||
-- **Signal:**
|
|
||||||
--
|
|
||||||
-- * *property::x*
|
|
||||||
--
|
|
||||||
-- @property x
|
-- @property x
|
||||||
-- @param integer
|
-- @tparam integer x
|
||||||
|
-- @emits property::geometry
|
||||||
|
-- @emitstparam property::geometry table geo The
|
||||||
|
-- geometry (with `x`, `y`, `width`, `height`).
|
||||||
|
-- @emits property::x
|
||||||
|
-- @emits property::position
|
||||||
|
|
||||||
--- The y coordinates.
|
--- The y coordinates.
|
||||||
--
|
--
|
||||||
-- **Signal:**
|
|
||||||
--
|
|
||||||
-- * *property::y*
|
|
||||||
--
|
|
||||||
-- @property y
|
-- @property y
|
||||||
-- @param integer
|
-- @tparam integer y
|
||||||
|
-- @emits property::geometry
|
||||||
|
-- @emitstparam property::geometry table geo The
|
||||||
|
-- geometry (with `x`, `y`, `width`, `height`).
|
||||||
|
-- @emits property::y
|
||||||
|
-- @emits property::position
|
||||||
|
|
||||||
--- The width of the client.
|
--- The width of the client.
|
||||||
--
|
--
|
||||||
-- **Signal:**
|
|
||||||
--
|
|
||||||
-- * *property::width*
|
|
||||||
--
|
|
||||||
-- @property width
|
-- @property width
|
||||||
-- @param width
|
-- @tparam integer width
|
||||||
|
-- @emits property::geometry
|
||||||
|
-- @emitstparam property::geometry table geo The
|
||||||
|
-- geometry (with `x`, `y`, `width`, `height`).
|
||||||
|
-- @emits property::width
|
||||||
|
-- @emits property::size
|
||||||
|
|
||||||
--- The height of the client.
|
--- The height of the client.
|
||||||
--
|
--
|
||||||
-- **Signal:**
|
|
||||||
--
|
|
||||||
-- * *property::height*
|
|
||||||
--
|
|
||||||
-- @property height
|
-- @property height
|
||||||
-- @param height
|
-- @tparam integer height
|
||||||
|
-- @emits property::geometry
|
||||||
|
-- @emitstparam property::geometry table geo The
|
||||||
|
-- geometry (with `x`, `y`, `width`, `height`).
|
||||||
|
-- @emits property::height
|
||||||
|
-- @emits property::size
|
||||||
|
|
||||||
-- Add the geometry helpers to match the wibox API
|
-- Add the geometry helpers to match the wibox API
|
||||||
for _, v in ipairs {"x", "y", "width", "height"} do
|
for _, v in ipairs {"x", "y", "width", "height"} do
|
||||||
|
@ -949,8 +978,8 @@ end
|
||||||
|
|
||||||
--- Restore (=unminimize) a random client.
|
--- Restore (=unminimize) a random client.
|
||||||
-- @staticfct awful.client.restore
|
-- @staticfct awful.client.restore
|
||||||
-- @param s The screen to use.
|
-- @tparam screen s The screen to use.
|
||||||
-- @return The restored client if some client was restored, otherwise nil.
|
-- @treturn client The restored client if some client was restored, otherwise nil.
|
||||||
function client.restore(s)
|
function client.restore(s)
|
||||||
s = s or screen.focused()
|
s = s or screen.focused()
|
||||||
local cls = capi.client.get(s)
|
local cls = capi.client.get(s)
|
||||||
|
@ -970,8 +999,8 @@ function client.restore(s)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Normalize a set of numbers to 1.
|
--- Normalize a set of numbers to 1.
|
||||||
-- @param set the set of numbers to normalize
|
-- @tparam table set the set of numbers to normalize.
|
||||||
-- @param num the number of numbers to normalize
|
-- @tparam number num the number of numbers to normalize.
|
||||||
local function normalize(set, num)
|
local function normalize(set, num)
|
||||||
num = num or #set
|
num = num or #set
|
||||||
local total = 0
|
local total = 0
|
||||||
|
@ -998,9 +1027,9 @@ end
|
||||||
--
|
--
|
||||||
-- @legacylayout awful.client.idx
|
-- @legacylayout awful.client.idx
|
||||||
-- @client c the client
|
-- @client c the client
|
||||||
-- @return col the column number
|
-- @treturn integer col The column number.
|
||||||
-- @return idx index of the client in the column
|
-- @treturn integer idx Index of the client in the column.
|
||||||
-- @return num the number of visible clients in the column
|
-- @treturn integer num The number of visible clients in the column.
|
||||||
function client.idx(c)
|
function client.idx(c)
|
||||||
c = c or capi.client.focus
|
c = c or capi.client.focus
|
||||||
if not c then return end
|
if not c then return end
|
||||||
|
@ -1058,8 +1087,9 @@ end
|
||||||
--- Set the window factor of a client
|
--- Set the window factor of a client
|
||||||
--
|
--
|
||||||
-- @legacylayout awful.client.setwfact
|
-- @legacylayout awful.client.setwfact
|
||||||
-- @param wfact the window factor value
|
-- @tparam number wfact the window factor value
|
||||||
-- @client c the client
|
-- @client c the client
|
||||||
|
-- @emits property::windowfact
|
||||||
function client.setwfact(wfact, c)
|
function client.setwfact(wfact, c)
|
||||||
-- get the currently selected window
|
-- get the currently selected window
|
||||||
c = c or capi.client.focus
|
c = c or capi.client.focus
|
||||||
|
@ -1114,7 +1144,8 @@ end
|
||||||
-- @tparam number add Amount to increase/decrease the client's window factor.
|
-- @tparam number add Amount to increase/decrease the client's window factor.
|
||||||
-- Should be between `-current_window_factor` and something close to
|
-- Should be between `-current_window_factor` and something close to
|
||||||
-- infinite. The normalisation then ensures that the sum of all factors is 1.
|
-- infinite. The normalisation then ensures that the sum of all factors is 1.
|
||||||
-- @client c the client
|
-- @client c the client.
|
||||||
|
-- @emits property::windowfact
|
||||||
function client.incwfact(add, c)
|
function client.incwfact(add, c)
|
||||||
c = c or capi.client.focus
|
c = c or capi.client.focus
|
||||||
if not c then return end
|
if not c then return end
|
||||||
|
@ -1152,12 +1183,9 @@ end
|
||||||
-- Clients with a type of "utility", "toolbar" or "dock" are dockable by
|
-- Clients with a type of "utility", "toolbar" or "dock" are dockable by
|
||||||
-- default.
|
-- default.
|
||||||
--
|
--
|
||||||
-- **Signal:**
|
|
||||||
--
|
|
||||||
-- * *property::dockable*
|
|
||||||
--
|
|
||||||
-- @property dockable
|
-- @property dockable
|
||||||
-- @param boolean The dockable state
|
-- @tparam boolean dockable The dockable state
|
||||||
|
-- @propemits false false
|
||||||
|
|
||||||
function client.object.get_dockable(c)
|
function client.object.get_dockable(c)
|
||||||
local value = client.property.get(c, "dockable")
|
local value = client.property.get(c, "dockable")
|
||||||
|
@ -1180,7 +1208,7 @@ end
|
||||||
-- to the edge of the workarea.
|
-- to the edge of the workarea.
|
||||||
--
|
--
|
||||||
-- @client c A client.
|
-- @client c A client.
|
||||||
-- @param value True or false.
|
-- @tparam boolean value True or false.
|
||||||
-- @deprecated awful.client.dockable.set
|
-- @deprecated awful.client.dockable.set
|
||||||
function client.dockable.set(c, value)
|
function client.dockable.set(c, value)
|
||||||
gdebug.deprecate("Use c.dockable = value instead of awful.client.dockable.set", {deprecated_in=4})
|
gdebug.deprecate("Use c.dockable = value instead of awful.client.dockable.set", {deprecated_in=4})
|
||||||
|
@ -1193,12 +1221,10 @@ end
|
||||||
-- various ways. This property uses the motif MWM_DECOR_TITLE hint and
|
-- various ways. This property uses the motif MWM_DECOR_TITLE hint and
|
||||||
-- interprets it as the client (not) wanting a titlebar.
|
-- interprets it as the client (not) wanting a titlebar.
|
||||||
--
|
--
|
||||||
-- **Signal:**
|
|
||||||
--
|
|
||||||
-- * *property::requests_no_titlebar*
|
|
||||||
--
|
|
||||||
-- @property requests_no_titlebar
|
-- @property requests_no_titlebar
|
||||||
-- @param boolean Whether the client requests not to get a titlebar
|
-- @tparam boolean requests_no_titlebar Whether the client
|
||||||
|
-- requests not to get a titlebar.
|
||||||
|
-- @propemits false false
|
||||||
|
|
||||||
function client.object.get_requests_no_titlebar(c)
|
function client.object.get_requests_no_titlebar(c)
|
||||||
local hints = c.motif_wm_hints
|
local hints = c.motif_wm_hints
|
||||||
|
@ -1224,8 +1250,8 @@ end)
|
||||||
-- This method is deprecated. It is now possible to use `c.value` directly.
|
-- This method is deprecated. It is now possible to use `c.value` directly.
|
||||||
--
|
--
|
||||||
-- @client c The client.
|
-- @client c The client.
|
||||||
-- @param prop The property name.
|
-- @tparam string prop The property name.
|
||||||
-- @return The property.
|
-- @return The property value.
|
||||||
-- @deprecated awful.client.property.get
|
-- @deprecated awful.client.property.get
|
||||||
function client.property.get(c, prop)
|
function client.property.get(c, prop)
|
||||||
if not c._private._persistent_properties_loaded then
|
if not c._private._persistent_properties_loaded then
|
||||||
|
@ -1248,8 +1274,8 @@ end
|
||||||
-- directly.
|
-- directly.
|
||||||
--
|
--
|
||||||
-- @client c The client.
|
-- @client c The client.
|
||||||
-- @param prop The property name.
|
-- @tparam string prop The property name.
|
||||||
-- @param value The value.
|
-- @param value The property value.
|
||||||
-- @deprecated awful.client.property.set
|
-- @deprecated awful.client.property.set
|
||||||
function client.property.set(c, prop, value)
|
function client.property.set(c, prop, value)
|
||||||
if not c._private.awful_client_properties then
|
if not c._private.awful_client_properties then
|
||||||
|
@ -1267,8 +1293,8 @@ end
|
||||||
--- Set a client property to be persistent across restarts (via X properties).
|
--- Set a client property to be persistent across restarts (via X properties).
|
||||||
--
|
--
|
||||||
-- @staticfct awful.client.property.persist
|
-- @staticfct awful.client.property.persist
|
||||||
-- @param prop The property name.
|
-- @tparam string prop The property name.
|
||||||
-- @param kind The type (used for register_xproperty).
|
-- @tparam string kind The type (used for register_xproperty).
|
||||||
-- One of "string", "number" or "boolean".
|
-- One of "string", "number" or "boolean".
|
||||||
function client.property.persist(prop, kind)
|
function client.property.persist(prop, kind)
|
||||||
local xprop = "awful.client.property." .. prop
|
local xprop = "awful.client.property." .. prop
|
||||||
|
@ -1288,10 +1314,10 @@ end
|
||||||
-- Starting from the client in focus or the given index, all clients that match
|
-- Starting from the client in focus or the given index, all clients that match
|
||||||
-- a given criteria.
|
-- a given criteria.
|
||||||
--
|
--
|
||||||
-- @param filter a function that returns true to indicate a positive match
|
-- @tparam function filter a function that returns true to indicate a positive match.
|
||||||
-- @param start what index to start iterating from. Defaults to using the
|
-- @tparam integer start what index to start iterating from. Defaults to using the
|
||||||
-- index of the currently focused client.
|
-- index of the currently focused client.
|
||||||
-- @param s which screen to use. nil means all screens.
|
-- @tparam screen s which screen to use. nil means all screens.
|
||||||
--
|
--
|
||||||
-- @staticfct awful.client.iterate
|
-- @staticfct awful.client.iterate
|
||||||
-- @usage -- un-minimize all urxvt instances
|
-- @usage -- un-minimize all urxvt instances
|
||||||
|
@ -1313,8 +1339,8 @@ end
|
||||||
-- If multiple clients match the given condition then the next one is
|
-- If multiple clients match the given condition then the next one is
|
||||||
-- focussed.
|
-- focussed.
|
||||||
--
|
--
|
||||||
-- @param cmd the command to execute
|
-- @tparam string cmd the command to execute
|
||||||
-- @param matcher a function that returns true to indicate a matching client
|
-- @tparam function matcher a function that returns true to indicate a matching client
|
||||||
-- @tparam bool|function merge If true then merge tags (select the client's
|
-- @tparam bool|function merge If true then merge tags (select the client's
|
||||||
-- first tag additionally) when the client is not visible.
|
-- first tag additionally) when the client is not visible.
|
||||||
-- If it is a function, it will be called with the client as argument.
|
-- If it is a function, it will be called with the client as argument.
|
||||||
|
@ -1354,7 +1380,7 @@ end
|
||||||
-- @client c The client.
|
-- @client c The client.
|
||||||
-- @tparam function matcher A function that should return true, if
|
-- @tparam function matcher A function that should return true, if
|
||||||
-- a matching parent client is found.
|
-- a matching parent client is found.
|
||||||
-- @treturn client.client|nil The matching parent client or nil.
|
-- @treturn client|nil The matching parent client or nil.
|
||||||
function client.get_transient_for_matching(c, matcher)
|
function client.get_transient_for_matching(c, matcher)
|
||||||
gdebug.deprecate("Use c:get_transient_for_matching(matcher) instead of"..
|
gdebug.deprecate("Use c:get_transient_for_matching(matcher) instead of"..
|
||||||
"awful.client.get_transient_for_matching", {deprecated_in=4})
|
"awful.client.get_transient_for_matching", {deprecated_in=4})
|
||||||
|
@ -1366,7 +1392,10 @@ end
|
||||||
-- @method get_transient_for_matching
|
-- @method get_transient_for_matching
|
||||||
-- @tparam function matcher A function that should return true, if
|
-- @tparam function matcher A function that should return true, if
|
||||||
-- a matching parent client is found.
|
-- a matching parent client is found.
|
||||||
-- @treturn client.client|nil The matching parent client or nil.
|
-- @treturn client|nil The matching parent client or nil.
|
||||||
|
-- @see transient_for
|
||||||
|
-- @see modal
|
||||||
|
-- @see is_transient_for
|
||||||
function client.object.get_transient_for_matching(self, matcher)
|
function client.object.get_transient_for_matching(self, matcher)
|
||||||
local tc = self.transient_for
|
local tc = self.transient_for
|
||||||
while tc do
|
while tc do
|
||||||
|
@ -1379,11 +1408,12 @@ function client.object.get_transient_for_matching(self, matcher)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Is a client transient for another one?
|
--- Is a client transient for another one?
|
||||||
|
--
|
||||||
-- @deprecated awful.client.is_transient_for
|
-- @deprecated awful.client.is_transient_for
|
||||||
-- @see client.is_transient_for
|
-- @see client.is_transient_for
|
||||||
-- @client c The child client (having transient_for).
|
-- @client c The child client (having transient_for).
|
||||||
-- @client c2 The parent client to check.
|
-- @client c2 The parent client to check.
|
||||||
-- @treturn client.client|nil The parent client or nil.
|
-- @treturn client|nil The parent client or nil.
|
||||||
function client.is_transient_for(c, c2)
|
function client.is_transient_for(c, c2)
|
||||||
gdebug.deprecate("Use c:is_transient_for(c2) instead of"..
|
gdebug.deprecate("Use c:is_transient_for(c2) instead of"..
|
||||||
"awful.client.is_transient_for", {deprecated_in=4})
|
"awful.client.is_transient_for", {deprecated_in=4})
|
||||||
|
@ -1391,9 +1421,20 @@ function client.is_transient_for(c, c2)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Is a client transient for another one?
|
--- Is a client transient for another one?
|
||||||
|
--
|
||||||
|
-- This will traverse the chain of `transient_for` client
|
||||||
|
-- until a client which is transient for `c2` is found. If
|
||||||
|
-- one is found, it will be returned. If none is found, then
|
||||||
|
-- `nil` will be returned. Most of the time there is no
|
||||||
|
-- long chain of clients, so `self` or `nil` are the most
|
||||||
|
-- likely return values.
|
||||||
|
--
|
||||||
-- @method is_transient_for
|
-- @method is_transient_for
|
||||||
-- @client c2 The parent client to check.
|
-- @client c2 The parent client to check.
|
||||||
-- @treturn client.client|nil The parent client or nil.
|
-- @treturn client|nil The parent client or nil.
|
||||||
|
-- @see transient_for
|
||||||
|
-- @see modal
|
||||||
|
-- @see client.get_transient_for_matching
|
||||||
function client.object.is_transient_for(self, c2)
|
function client.object.is_transient_for(self, c2)
|
||||||
local tc = self
|
local tc = self
|
||||||
while tc.transient_for do
|
while tc.transient_for do
|
||||||
|
@ -1418,12 +1459,15 @@ object.properties._legacy_accessors(client, "keys", "_keys", true, function(new_
|
||||||
end, true, true, "keybinding")
|
end, true, true, "keybinding")
|
||||||
|
|
||||||
--- Set the client shape.
|
--- Set the client shape.
|
||||||
|
--
|
||||||
-- @property shape
|
-- @property shape
|
||||||
-- @tparam gears.shape A gears.shape compatible function.
|
-- @tparam gears.shape A gears.shape compatible function.
|
||||||
|
-- @propemits true false
|
||||||
-- @see gears.shape
|
-- @see gears.shape
|
||||||
function client.object.set_shape(self, shape)
|
function client.object.set_shape(self, shape)
|
||||||
client.property.set(self, "_shape", shape)
|
client.property.set(self, "_shape", shape)
|
||||||
set_shape(self)
|
set_shape(self)
|
||||||
|
self:emit_signal("property::shape", shape)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Proxy those properties to decorate their accessors with an extra flag to
|
-- Proxy those properties to decorate their accessors with an extra flag to
|
||||||
|
@ -1643,7 +1687,7 @@ capi.client.connect_signal("request::manage", function (c)
|
||||||
require("awful.placement").no_offscreen(c)
|
require("awful.placement").no_offscreen(c)
|
||||||
end
|
end
|
||||||
|
|
||||||
if awesome.startup then
|
if capi.awesome.startup then
|
||||||
client.focus.history.add(c)
|
client.focus.history.add(c)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
688
objects/client.c
688
objects/client.c
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue