labwc-menu - Man Page
menu files
Description
Static menus are built based on content of XML files located at "~/.config/labwc" and equivalent XDG Base Directories.
Syntax
The menu file must be entirely enclosed within <openbox_menu> and </openbox_menu> tags. Inside these tags, menus are specified as follows:
<menu id=""> <!-- A menu entry with an action, for example to execute an application --> <item label=""> <action></action> </item> <!-- A submenu defined elsewhere --> <menu id="" /> <!-- Horizontal line > <separator /> <!-- An inline submenu --> <menu id="" label=""> ...some content... </menu> <!-- Pipemenu --> <menu label="" execute="COMMAND"/> </menu>
- menu.id
Each menu must be given an id, which is a unique identifier of the menu. This id is used to refer to the menu in a ShowMenu action. Default identifiers are "client-menu" for the titlebar context menu and "root-menu" for the root window context menu. Available localisation for the default "client-menu" is only shown if no "client-menu" is present in menu.xml.
- menu.label
The title of the menu, shown in its parent. A label must be given when defining a menu.
- menu.item.label
The visible name of the menu item.
- menu.item.action
See labwc-action(5). Note: XML CDATA is supported for this node in order to maintain compatibility with obmenu-generator.
- menu.separator
Horizontal line.
- menu.execute
Command to execute for pipe menu. See details below.
Pipe Menus
Pipe menus are menus generated dynamically based on output of scripts or binaries. They are so-called because the output of the executable is piped to the labwc menu.
For any <menu label="" execute="COMMAND"/> entry in menu.xml, the COMMAND will be executed every time the item is selected (for example by cursor or keyboard input). The XML output of the command will be parsed and shows as a submenu.
The content of the output must be entirely enclosed within <openbox_pipe_menu> tags. Inside these, menus are specified in the same way as static (normal) menus, for example:
<openbox_pipe_menu> <item label="Terminal"> <action name="Execute" command="xterm"/> </item> </openbox_pipe_menu>
When writing pipe menu scripts, make sure to escape XML special characters such as "&" ("&"), "<" ("<"), and ">" (">").
See Also
labwc(1), labwc-action(5), labwc-config(5), labwc-theme(5)