aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAurelien Gateau <aurelien.gateau@canonical.com>2009-11-13 14:33:30 -0600
committerAurelien Gateau <aurelien.gateau@canonical.com>2009-11-13 14:33:30 -0600
commitd3d19b7180357ddd33ff77a94cbf228681f650e4 (patch)
tree2e614c86d2e467a44b0ed8383a5d7e5042d27a3f
parentabee236b2e4e15db407532ac308e5f508c73abad (diff)
downloadlibdbusmenu-d3d19b7180357ddd33ff77a94cbf228681f650e4.tar.gz
libdbusmenu-d3d19b7180357ddd33ff77a94cbf228681f650e4.tar.bz2
libdbusmenu-d3d19b7180357ddd33ff77a94cbf228681f650e4.zip
New DBus menu API
-rw-r--r--libdbusmenu-glib/dbus-menu.xml140
1 files changed, 92 insertions, 48 deletions
diff --git a/libdbusmenu-glib/dbus-menu.xml b/libdbusmenu-glib/dbus-menu.xml
index c22d477..6f5bdb2 100644
--- a/libdbusmenu-glib/dbus-menu.xml
+++ b/libdbusmenu-glib/dbus-menu.xml
@@ -30,91 +30,135 @@ License version 3 and version 2.1 along with this program. If not, see
<node name="/">
<interface name="org.freedesktop.dbusmenu">
-<!-- Properties -->
-<!--
-Provides an XML representation of the menu hierarchy
-
-XML syntax:
-
-<menu id="1" revision="2"> # Root container
- <menu id="2" revision="2"> # First level menu, for example "File"
- <menu id="3" revision="2"/> ~ Second level menu, for example "Open"
- <menu id="4" revision="3"/>
- ...
- </menu>
- <menu id="5" revision="2"> # Another first level menu, say "Edit"
- ...
- </menu>
- ...
-</menu>
--->
- <property name="layout" type="s" access="read"/>
-
<!-- Functions -->
<!--
-Each menu item has a set of properties. Property keys are in menuitem.h:
+Returns the list of items which are children of @a parentId.
-- visible
-- sensitive
-- label
-- icon
-- icon-data
-- type
+@param parentid unsigned the parent id for the list. If it is 0, returns the root
+item list;
+@param propertyNames list of string the list of item properties we are interested in
-"type" property is an enum which can take the following values (client.h):
+An item is represented as a struct following this format:
+@li id unsigned the item id
+@li properties map(string => variant) the requested item properties
-- menuitem
-- separator
-- imageitem
+-->
+ <method name="GetChildren">
+ <arg type="u" name="parentId" direction="in" />
+ <arg type="as" name="propertyNames" direction="in" />
+ <arg type="a(ua{sv})" name="children" direction="out" />
+ </method>
+
+<!--
+Each menu item has a set of properties. Property keys are in menuitem.h:
+
+@li type string Type of the item (see below)
+@li label string Text of the item
+@li icon-data binary Raw data of the icon (TODO: define format)
+@li icon string Icon name of the item, following icon spec
+@li sensitive boolean Whether the item can be activated or not
+@li visible boolean Whether the item is visible or not (XXX: Is this necessary?)
+@li checked boolean Whether a checkbox or radio item is checked
+@li shortcut string The keyboard shortcut
+
+@c type property is an enum which can take the following values (client.h):
+
+@li action An item which can be clicked to trigger an action
+@li checkbox An item which can be checked or unchecked
+@li radio An item which can be checked or unchecked as part of a group
+@li separator A separator
+@li menu An item which contains more items
-->
<method name="GetProperty">
<arg type="u" name="id" direction="in" />
- <arg type="s" name="property" direction="in" />
- <arg type="s" name="value" direction="out" />
+ <arg type="s" name="name" direction="in" />
+ <arg type="v" name="value" direction="out" />
</method>
<!--
-Convenience method to retrieve all properties in one call (more efficient)
+Returns multiple properties in one call. This is more efficient than
+GetProperty.
+
+@param id unsigned the item whose properties we want to retrieve.
+@param propertyNames list of string name of the properties we want.
-->
<method name="GetProperties">
+ <annotation name="com.trolltech.QtDBus.QtTypeName.Out0" value="QVariantMap"/>
<arg type="u" name="id" direction="in" />
- <arg type="a{ss}" name="properties" direction="out" />
+ <arg type="as" name="propertyNames" direction="in" />
+ <arg type="a{sv}" name="properties" direction="out" />
</method>
<!--
-This is called by the display to notify the application it should trigger
-the action associated with a specific menu id
+This is called by the applet to notify the application an event happened on a
+menu item.
+
+@param id the id of the item which received the event
+@param type the type of event
+@param data event-specific data
+
+@a type can be one of the following:
+
+@li "clicked"
+@li "hovered"
+
+Vendor specific events can be added by prefixing them with "x-<vendor>-"
-->
- <method name="Call">
+ <method name="Event">
<arg type="u" name="id" direction="in" />
+ <arg type="s" name="eventId" direction="in" />
+ <arg type="v" name="data" direction="in" />
</method>
<!-- Signals -->
<!--
-Triggered by the application to notify display that the property prop from menu id
-as changed to value.
+Triggered by the application to notify the applet that the property @a property
+from item @a id has changed to @a value.
-->
- <signal name="IdPropUpdate">
+ <signal name="ItemPropertyUpdated">
<arg type="u" name="id" direction="out" />
<arg type="s" name="prop" direction="out" />
<arg type="s" name="value" direction="out" />
</signal>
<!--
-Triggered by the application to notify display that all properties of menu id
-should be considered outdated
+Triggered by the application to notify the applet that all properties of item
+@a id should be considered outdated
+-->
+ <signal name="ItemUpdated">
+ <arg type="u" name="id" direction="out" />
+ </signal>
+
+<!--
+Triggered by the application to notify applet it should retrieve the children
+for item @a id.
+-->
+ <signal name="ChildrenUpdated">
+ <arg type="u" name="id" direction="out" />
+ </signal>
+
+<!--
+Triggered by the application to notify applet that an item has been added.
+
+@param id unsigned id of the added item
+@param parentid unsigned id of the added item parent. O if the item is
+added to the root list
+@param row unsigned position the item has been added
-->
- <signal name="IdUpdate">
+ <signal name="ItemAdded">
<arg type="u" name="id" direction="out" />
+ <arg type="u" name="parentId" direction="out" />
+ <arg type="u" name="row" direction="out" />
</signal>
<!--
-Triggered by the application to notify display of a layout update, up to
-revision
+Triggered by the application to notify applet that an item has been removed.
+
+@param id unsigned id of the removed item
-->
- <signal name="LayoutUpdate">
- <arg type="i" name="revision" direction="out" />
+ <signal name="ItemRemoved">
+ <arg type="u" name="id" direction="out" />
</signal>
<!-- End of interesting stuff -->