.\" Generated by scdoc 1.11.3 .\" Complete documentation for this program is not available as a GNU info page .ie \n(.g .ds Aq \(aq .el .ds Aq ' .nh .ad l .\" Begin generated content: .TH "labwc-actions" "5" "2024-12-26" .PP .SH NAME .PP labwc - actions .PP .SH ACTIONS .PP Actions are used in menus and keyboard/mouse bindings.\& .PP \fB\fR .RS 4 Close top-most window.\& .PP .RE \fB\fR .RS 4 Kill the process associated with the current window by sending it the SIGTERM signal.\& .PP .RE \fB\fR .RS 4 Execute command.\& Note that in the interest of backward compatibility, labwc supports as an alternative to even though openbox documentation states that it is deprecated.\& Note: Tilde (~) is expanded in the command before passing to execvp().\& .PP .RE \fB\fR .RS 4 Exit labwc.\& .PP .RE \fB\fR .RS 4 Give focus to window under cursor.\& .PP .RE \fB\fR .RS 4 Remove focus from the window that is currently focused.\& .PP .RE \fB\fR .RS 4 Restack the current window above other open windows.\& .PP .RE \fB\fR .RS 4 Restack the current window below other open windows.\& .PP .RE \fB\fR .RS 4 Iconify (minimize) focused window.\& .PP .RE \fB\fR .RS 4 Begin interactive move of window under cursor.\& .PP .RE \fB\fR .RS 4 Move window until it hits the next edge.\& .PP \fBdirection\fR [left|up|right|down] Direction in which to move.\& .PP \fBsnapWindows\fR [yes|no] Move window until it hits an edge of another window or screen edge.\& If set to "no", only move to the next screen edge.\& Default is yes.\& .PP .RE \fB\fR .RS 4 Begin interactive resize of window under cursor.\& .PP .RE \fB\fR .RS 4 Resize window relative to its current size.\& Values of left, right, top or bottom tell how much to resize on that edge of window, positive values grow window, negative shrink window.\& .PP .RE \fB\fR .RS 4 Resize window to fill the space between its edge and any other window edge.\& .PP \fBdirection\fR [left|up|right|down] Direction in which to grow.\& .PP .RE \fB\fR .RS 4 Reverse of GrowToEdge.\& Shrinks by a maximum of 50%.\& .PP \fBdirection\fR [left|up|right|down] Direction in which to shrink.\& .PP .RE \fB\fR .RS 4 Move to position (x, y).\& .PP .RE \fB\fR .RS 4 Resize window.\& .PP \fBwidth\fR The width to resize the window to in pixels.\& .PP \fBheight\fR The height to resize the window to in pixels.\& .PP .RE \fB\fR .RS 4 Move to be centered on cursor.\& Tries to prevent any part of the window from going off-screen.\& This action is deprecated from v0.\&7.\&3.\& To ensure your config works in future labwc releases, please use: \fB\fR .PP .RE \fB\fR .RS 4 Move window relative to its current position.\& Positive value of x moves it right, negative left.\& Positive value of y moves it down, negative up.\& .PP .RE \fB\fR .br \fB\fR .RS 4 Resize window to fill half the output in the given direction.\& Supports directions "left", "up", "right", "down" and "center".\& .PP ToggleSnapToEdge additionally toggles the active window between tiled to the given direction and its untiled position.\& .PP .RE \fB\fR .br \fB\fR .RS 4 Resize and move active window according to the given region.\& .PP ToggleSnapToRegion additionally toggles the active window between tiled to the given region and its untiled position.\& .PP See labwc-config(5) for further information on how to define regions.\& .PP .RE \fB\fR .RS 4 Resize and move the active window back to its untiled or unmaximized position if it had been maximized or tiled to a direction or region.\& .PP .RE \fB\fR .br \fB\fR .RS 4 Cycle focus to next/previous window respectively.\& .br Default keybind for NextWindow is Alt-Tab.\& .PP The shift key is used to reverse direction while cycling.\& .PP The arrow keys are used to move forwards/backwards while cycling.\& .PP .RE \fB\fR .RS 4 Re-load configuration and theme files.\& .PP .RE \fB\fR .RS 4 Show a menu.\& .PP \fBmenu\fR The name of the menu to show.\& The menus "root-menu", "client-menu", "client-send-to-menu" and "client-list-combined-menu" are guaranteed to exist, but others may be defined explicitly.\& See labwc-menu(5) for more information.\& .PP \fBatCursor\fR [yes|no] When opening a menu, open the menu at the location of the mouse cursor.\& When set to no, the menu will appear at the upper-left corner of the window associated with the action or underneath the window button that opened the menu.\& Default is yes.\& .PP \fBposition\fR Show the menu in the specified position on the monitor that has cursor focus, see below.\& .PP The position tag has two sub-tags.\& and specify a position and take either a pixel value, the string "center" which will center the menu in that dimension, or a relative value specified as a percentage A relative value is interpreted in terms of the monitor the menu will be shown on, and will be relative to the left/top edge of the menu window and monitor for positive values, and to the right/bottom edge for negative values.\& .PP .RE \fB\fR .RS 4 Set decorations of focused window.\& .PP \fBdecorations\fR [full|border|none] \fBfull\fR enables the whole server side decorations.\& With \fBborder\fR.\& only the borders and invisible resize area are enabled.\& \fBnone\fR disables everything.\& .PP \fBforceSSD\fR [yes|no] If this is no, this action will be ignored for windows that have client side decorations if it would increase the amount of decoration.\& Default is no.\& .PP .RE \fB\fR .RS 4 Toggle decorations of focused window.\& .PP This is a 3-state action which can be executed multiple times: .PD 0 .IP \(bu 4 Only the titlebar will be hidden, borders and resize area are kept .IP \(bu 4 Remaining decorations will be disabled .IP \(bu 4 Decorations will be shown normally .PD .PP By disabling the theme configuration '\&keepBorder'\& the first step will be removed and the action only toggles between on and off.\& .PP .RE \fB\fR .RS 4 Toggle fullscreen state of focused window.\& .PP .RE \fB\fR .RS 4 Toggle maximize state of focused window.\& Supported directions are "both" (default), "horizontal", and "vertical".\& .PP .RE \fB\fR .RS 4 Maximize focused window in the direction(s) specified.\& Supported directions are "both" (default), "horizontal", and "vertical".\& .PP .RE \fB\fR .RS 4 Unmaximize focused window in the direction(s) specified and return it to its pre-maximized dimensions.\& Supported directions are "both" (default), "horizontal", and "vertical".\& .PP .RE \fB\fR .RS 4 Toggle always-on-top of focused window.\& .PP .RE \fB\fR .RS 4 Toggle between layers '\&always-on-bottom'\& and '\&normal'\&.\& When a window is in the '\&always-on-bottom'\& layer, it is rendered below all other top-level windows.\& It is anticipated that this action will be useful when defining window-rules for desktop-management tools that do not support the wlr-layer-shell protocol.\& .PP .RE \fB\fR .RS 4 Toggle omnipresent (visible on all workspaces / sticky) for the focused window.\& .PP .RE \fB\fR .RS 4 Stop handling keybinds other than ToggleKeybinds itself.\& This can be used to allow A-Tab and similar keybinds to be delivered to Virtual Machines, VNC clients or nested compositors.\& A second call will restore all original keybinds.\& .PP This action will only affect the window that had keyboard focus when the binding was executed.\& Thus when switching to another window, all the usual keybinds will function again until switching back to the original window.\& There can be multiple windows with this mode set.\& .PP .RE \fB\fR .RS 4 Toggles tearing for the focused window between enabled and disabled.\& This overrides the preference (tearing hint) from the focused window.\& .PP Requires the config option '\&allowTearing'\&.\& When '\&allowTearing'\& is set to '\&fullscreen'\& or '\&fullscreenForced'\&, tearing will still only be enabled if the active window is in fullscreen mode.\& .PP .RE \fB\fR .RS 4 Give focus to topmost window on other output and warp the cursor to the center of the window.\& .PP If \fBoutput\fR is specified, the focus is given to the specified output and \fBdirection\fR is ignored.\& If \fBoutput\fR is omitted, \fBdirection\fR may be one of "left", "right", "up" or "down" to indicate that the focus should be given to the next output in that direction (if one exists).\& .PP \fBwrap\fR [yes|no] When using the direction attribute, wrap around from right-to-left or top-to-bottom, and vice versa.\& Default is no.\& .PP If the target output does not contain any windows, the cursor will be centered on the output.\& .PP .RE \fB\fR .RS 4 Moves active window to other output, unless the window state is fullscreen.\& .PP If \fBoutput\fR is specified, the window will be sent directly to the specified output and \fBdirection\fR is ignored.\& If \fBoutput\fR is omitted, \fBdirection\fR may be one of "left", "right", "up" or "down" to indicate that the window should be moved to the next output in that direction (if one exists).\& .PP \fBwrap\fR [yes|no] When using the direction attribute, wrap around from right-to-left or top-to-bottom, and vice versa.\& Default no.\& .PP .RE \fB\fR .RS 4 Resizes active window size to width and height of the output when the window size exceeds the output size.\& .PP .RE \fB\fR .RS 4 Switch to workspace.\& .PP \fBto\fR The workspace to switch to.\& Supported values are "current", "last", "left", "right" or the full name of a workspace or its index (starting at 1) as configured in rc.\&xml.\& .PP \fBwrap\fR [yes|no] Wrap around from last desktop to first, and vice versa.\& Default yes.\& .PP .RE \fB\fR .RS 4 Send active window to workspace.\& .PP \fBto\fR The workspace to send the window to.\& Supported values are the same as for GoToDesktop.\& .PP \fBfollow\fR [yes|no] Also switch to the specified workspace.\& Default yes.\& .PP \fBwrap\fR [yes|no] Wrap around from last desktop to first, and vice versa.\& Default yes.\& .PP .RE \fB\fR .RS 4 Add virtual output (headless backend).\& .PP For example, it can be used to overlay virtual output on real output, but with a different resolution (this can be done with `wlr-randr` or `wdisplays`).\& After that, virtual output can be selected for screen sharing (casting), effectively sharing only the region of the screen.\& .PP It must be noted that overlaying virtual output and real output is not endorsed or explicitly supported by wlroots.\& For example, after configuring virtual output, real output must be reconfigured as well (for the overlay configuration to work correctly).\& This is the example configuration: .PP .RE .nf .RS 4 .fi .RE .PP .RS 4 Note that the vertical resolution of "ScreenCasting" output is just 50px smaller than "eDP-1" output to cut off bottom panel from screen sharing.\& .PP Virtual output is also useful for extending the desktop to (maybe mobile) remote systems like tablets.\& E.\&g.\& simply adding a virtual output, attaching wayvnc to it and running a VNC client on the remote system.\& .PP \fBoutput_name\fR The name of virtual output.\& Providing virtual output name is beneficial for further automation.\& Default is "HEADLESS-X".\& .PP .RE \fB\fR .RS 4 Remove virtual output (headless backend).\& .PP \fBoutput_name\fR The name of virtual output.\& If not supplied, will remove the last virtual output added.\& .PP .RE \fB\fR .RS 4 Reposition the window according to the desired placement policy.\& .PP \fBpolicy\fR [automatic|cursor|center|cascade] Use the specified policy, which has the same meaning as the corresponding value for \fB\fR.\& Default is automatic.\& .PP .RE \fB\fR .br \fB\fR .br \fB\fR .RS 4 Set, unset, or toggle, respectively, the "shaded" state of the active window.\& When shaded, window contents are hidden, leaving only the titlebar visible.\& Full-screen windows or those without server-side decorations (including those for which the server-side titlebar has been hidden) are not eligible for shading.\& .PP .RE \fB\fR .br \fB\fR .br \fB\fR .RS 4 Enable, disable or toggle mouse emulation for drawing tablets respectively.\& .PP .RE \fB\fR .RS 4 Toggle the screen magnifier on or off at the last magnification level used.\& .PP .RE \fB\fR .br \fB\fR .RS 4 Increase or decrease the magnification level for the screen magnifier.\& If the magnifier is currently off, ZoomIn will enable it at the lowest magnification, equal to (1 + the magnifier increment set in the theme).\& If the magnifier is on and at the lowest magnification, ZoomOut will turn it off.\& .PP .RE \fB\fR .RS 4 If used as the only action for a binding: clear an earlier defined binding.\& .PP .RE .SH CONDITIONAL ACTIONS .PP Actions that execute other actions.\& Used in keyboard/mouse bindings.\& .PP \fB\fR .RS 4 This action will execute one set of actions if the focused window matches the criteria, or another if it does not.\& .PP The arguments are as follows: .PP .nf .RS 4 .fi .RE .PP \fBquery\fR .RS 4 Define a query with zero or more conditions.\& All conditions must be evaluated as true in order for the window to match this query.\& Multiple queries can be defined.\& .PP Pattern matching is done according to glob(7) and is case-insensitive.\& .PP Conditions are as follows: .PP \fBidentifier\fR .RS 4 XDG shell app_id for Wayland clients, WM_CLASS for XWayland clients.\& .PP .RE \fBtitle\fR .RS 4 XDG shell title for Wayland clients, WM_NAME for XWayland clients.\& .PP .RE \fBtype\fR .RS 4 Internal heuristics for Wayland clients, NET_WM_WINDOW_TYPE for XWayland clients.\& .PP .RE \fBshaded\fR [yes|no] .RS 4 Whether or not the client is rolled up.\& .PP .RE \fBmaximized\fR [both|horizontal|vertical|none] .RS 4 Whether the client is maximized along both axes, the horizontal axis only, the vertical axis only, or neither axis (none).\& .PP .RE \fBiconified\fR [yes|no] .RS 4 Whether or not the client is iconified.\& .PP .RE \fBfocused\fR [yes|no] .RS 4 Whether or not the client is focused.\& .PP .RE \fBomnipresent\fR [yes|no] .RS 4 Whether or not the client is visible on all desktops.\& .PP .RE \fBdesktop\fR .RS 4 The desktop the client is currently on.\& This can be the number or name of a desktop, or special relative values "current", "other", "left", "right" or "last".\& The "left" and "right" directions will not wrap.\& .PP .RE \fBtiled\fR [up|right|down|left|center] .RS 4 Whether the client is tiled (snapped) along the the indicated screen edge.\& .PP .RE \fBtiled_region\fR .RS 4 Whether the client is tiled (snapped) to the indicated region.\& The indicated region may be a glob.\& .PP .RE \fBdecoration\fR [full|border|none] .RS 4 Whether the client has full server-side decorations, borders only, or no server-side decorations.\& .PP .RE This argument is optional.\& .PP .RE \fBthen\fR .RS 4 A list of actions to be executed if the window matches any query.\& This argument is optional.\& .PP .RE \fBelse\fR .RS 4 A list of actions to be executed if the window does not match any query.\& This argument is optional.\& .PP .RE .RE \fB\fR .RS 4 Identical to "If" action, but applies to all windows, not just the focused one.\& .PP The \fBForEach\fR action has another optional \fBnone\fR branch which gets executed when no window has been matched by the query.\& This allows for example to implement a run-or-raise functionality.\& .PP .RE .SH SEE ALSO .PP labwc(1), labwc-config(5), labwc-theme(5), glob(7)