Linux unitednationsplay.com 3.10.0-1160.45.1.el7.x86_64 #1 SMP Wed Oct 13 17:20:51 UTC 2021 x86_64
nginx/1.20.1
Server IP : 188.130.139.92 & Your IP : 3.144.41.22
Domains :
Cant Read [ /etc/named.conf ]
User : web
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
share /
gnome-shell /
Delete
Unzip
Name
Size
Permission
Date
Action
extensions
[ DIR ]
drwxr-xr-x
2021-08-31 14:50
search-providers
[ DIR ]
drwxr-xr-x
2021-08-31 14:50
theme
[ DIR ]
drwxr-xr-x
2022-01-26 17:33
Gvc-1.0.gir
109.47
KB
-rw-r--r--
2021-08-31 14:49
Shell-0.1.gir
186.09
KB
-rw-r--r--
2021-08-31 14:50
ShellMenu-0.1.gir
50.55
KB
-rw-r--r--
2021-08-31 14:50
St-1.0.gir
276.72
KB
-rw-r--r--
2021-08-31 14:50
gnome-shell-osk-layouts.gresource
418.91
KB
-rw-r--r--
2021-08-31 14:49
gnome-shell-theme.gresource
456.9
KB
-rw-r--r--
2021-08-31 14:49
perf-background.xml
1.1
KB
-rw-r--r--
2021-08-31 14:49
Save
Rename
<?xml version="1.0"?> <!-- This file was automatically generated from C sources - DO NOT EDIT! To affect the contents of this file, edit the original C definitions, and/or use gtk-doc annotations. --> <repository version="1.2" xmlns="http://www.gtk.org/introspection/core/1.0" xmlns:c="http://www.gtk.org/introspection/c/1.0" xmlns:glib="http://www.gtk.org/introspection/glib/1.0"> <include name="Gio" version="2.0"/> <include name="St" version="1.0"/> <namespace name="ShellMenu" version="0.1" shared-library="libgnome-shell-menu.so" c:identifier-prefixes="Gtk" c:symbol-prefixes="gtk"> <class name="ActionMuxer" c:symbol-prefix="action_muxer" c:type="GtkActionMuxer" parent="GObject.Object" glib:type-name="GtkActionMuxer" glib:get-type="gtk_action_muxer_get_type"> <doc xml:space="preserve">#GtkActionMuxer is a #GActionGroup and #GtkActionObservable that is capable of containing other #GActionGroup instances. The typical use is aggregating all of the actions applicable to a particular context into a single action group, with namespacing. Consider the case of two action groups -- one containing actions applicable to an entire application (such as 'quit') and one containing actions applicable to a particular window in the application (such as 'fullscreen'). In this case, each of these action groups could be added to a #GtkActionMuxer with the prefixes "app" and "win", respectively. This would expose the actions as "app.quit" and "win.fullscreen" on the #GActionGroup interface presented by the #GtkActionMuxer. Activations and state change requests on the #GtkActionMuxer are wired through to the underlying action group in the expected way. This class is typically only used at the site of "consumption" of actions (eg: when displaying a menu that contains many actions on different objects).</doc> <implements name="Gio.ActionGroup"/> <implements name="ActionObservable"/> <constructor name="new" c:identifier="gtk_action_muxer_new"> <doc xml:space="preserve">Creates a new #GtkActionMuxer.</doc> <return-value transfer-ownership="full"> <type name="ActionMuxer" c:type="GtkActionMuxer*"/> </return-value> </constructor> <method name="get_parent" c:identifier="gtk_action_muxer_get_parent"> <return-value transfer-ownership="none"> <doc xml:space="preserve">the parent of @muxer, or NULL.</doc> <type name="ActionMuxer" c:type="GtkActionMuxer*"/> </return-value> <parameters> <instance-parameter name="muxer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionMuxer</doc> <type name="ActionMuxer" c:type="GtkActionMuxer*"/> </instance-parameter> </parameters> </method> <method name="get_primary_accel" c:identifier="gtk_action_muxer_get_primary_accel"> <return-value transfer-ownership="none"> <type name="utf8" c:type="const gchar*"/> </return-value> <parameters> <instance-parameter name="muxer" transfer-ownership="none"> <type name="ActionMuxer" c:type="GtkActionMuxer*"/> </instance-parameter> <parameter name="action_and_target" transfer-ownership="none"> <type name="utf8" c:type="const gchar*"/> </parameter> </parameters> </method> <method name="insert" c:identifier="gtk_action_muxer_insert"> <doc xml:space="preserve">Adds the actions in @action_group to the list of actions provided by @muxer. @prefix is prefixed to each action name, such that for each action <varname>x</varname> in @action_group, there is an equivalent action @prefix<literal>.</literal><varname>x</varname> in @muxer. For example, if @prefix is "<literal>app</literal>" and @action_group contains an action called "<literal>quit</literal>", then @muxer will now contain an action called "<literal>app.quit</literal>". If any #GtkActionObservers are registered for actions in the group, "action_added" notifications will be emitted, as appropriate. @prefix must not contain a dot ('.').</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="muxer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionMuxer</doc> <type name="ActionMuxer" c:type="GtkActionMuxer*"/> </instance-parameter> <parameter name="prefix" transfer-ownership="none"> <doc xml:space="preserve">the prefix string for the action group</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="action_group" transfer-ownership="none"> <doc xml:space="preserve">a #GActionGroup</doc> <type name="Gio.ActionGroup" c:type="GActionGroup*"/> </parameter> </parameters> </method> <method name="remove" c:identifier="gtk_action_muxer_remove"> <doc xml:space="preserve">Removes a #GActionGroup from the #GtkActionMuxer. If any #GtkActionObservers are registered for actions in the group, "action_removed" notifications will be emitted, as appropriate.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="muxer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionMuxer</doc> <type name="ActionMuxer" c:type="GtkActionMuxer*"/> </instance-parameter> <parameter name="prefix" transfer-ownership="none"> <doc xml:space="preserve">the prefix of the action group to remove</doc> <type name="utf8" c:type="const gchar*"/> </parameter> </parameters> </method> <method name="set_parent" c:identifier="gtk_action_muxer_set_parent"> <doc xml:space="preserve">Sets the parent of @muxer to @parent.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="muxer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionMuxer</doc> <type name="ActionMuxer" c:type="GtkActionMuxer*"/> </instance-parameter> <parameter name="parent" transfer-ownership="none" nullable="1" allow-none="1"> <doc xml:space="preserve">the new parent #GtkActionMuxer</doc> <type name="ActionMuxer" c:type="GtkActionMuxer*"/> </parameter> </parameters> </method> <method name="set_primary_accel" c:identifier="gtk_action_muxer_set_primary_accel"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="muxer" transfer-ownership="none"> <type name="ActionMuxer" c:type="GtkActionMuxer*"/> </instance-parameter> <parameter name="action_and_target" transfer-ownership="none"> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="primary_accel" transfer-ownership="none"> <type name="utf8" c:type="const gchar*"/> </parameter> </parameters> </method> <property name="parent" writable="1" transfer-ownership="none"> <type name="ActionMuxer"/> </property> <glib:signal name="primary-accel-changed" when="last"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <parameter name="object" transfer-ownership="none"> <type name="utf8" c:type="gchar*"/> </parameter> <parameter name="p0" transfer-ownership="none"> <type name="utf8" c:type="gchar*"/> </parameter> </parameters> </glib:signal> </class> <interface name="ActionObservable" c:symbol-prefix="action_observable" c:type="GtkActionObservable" glib:type-name="GtkActionObservable" glib:get-type="gtk_action_observable_get_type" glib:type-struct="ActionObservableInterface"> <virtual-method name="register_observer" invoker="register_observer"> <doc xml:space="preserve">Registers @observer as being interested in changes to @action_name on @observable.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObservable</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </instance-parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">the #GtkActionObserver to which the events will be reported</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </parameter> </parameters> </virtual-method> <virtual-method name="unregister_observer" invoker="unregister_observer"> <doc xml:space="preserve">Removes the registration of @observer as being interested in changes to @action_name on @observable. If the observer was registered multiple times, it must be unregistered an equal number of times.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObservable</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </instance-parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">the #GtkActionObserver to which the events will be reported</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </parameter> </parameters> </virtual-method> <method name="register_observer" c:identifier="gtk_action_observable_register_observer"> <doc xml:space="preserve">Registers @observer as being interested in changes to @action_name on @observable.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObservable</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </instance-parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">the #GtkActionObserver to which the events will be reported</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </parameter> </parameters> </method> <method name="unregister_observer" c:identifier="gtk_action_observable_unregister_observer"> <doc xml:space="preserve">Removes the registration of @observer as being interested in changes to @action_name on @observable. If the observer was registered multiple times, it must be unregistered an equal number of times.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObservable</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </instance-parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">the #GtkActionObserver to which the events will be reported</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </parameter> </parameters> </method> </interface> <record name="ActionObservableInterface" c:type="GtkActionObservableInterface" glib:is-gtype-struct-for="ActionObservable"> <field name="g_iface"> <type name="GObject.TypeInterface" c:type="GTypeInterface"/> </field> <field name="register_observer"> <callback name="register_observer"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObservable</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">the #GtkActionObserver to which the events will be reported</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </parameter> </parameters> </callback> </field> <field name="unregister_observer"> <callback name="unregister_observer"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObservable</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">the #GtkActionObserver to which the events will be reported</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </parameter> </parameters> </callback> </field> </record> <interface name="ActionObserver" c:symbol-prefix="action_observer" c:type="GtkActionObserver" glib:type-name="GtkActionObserver" glib:get-type="gtk_action_observer_get_type" glib:type-struct="ActionObserverInterface"> <doc xml:space="preserve">GtkActionObserver is a simple interface allowing objects that wish to be notified of changes to actions to be notified of those changes. It is also possible to monitor changes to action groups using #GObject signals, but there are a number of reasons that this approach could become problematic: - there are four separate signals that must be manually connected and disconnected - when a large number of different observers wish to monitor a (usually disjoint) set of actions within the same action group, there is only one way to avoid having all notifications delivered to all observers: signal detail. In order to use signal detail, each action name must be quarked, which is not always practical. - even if quarking is acceptable, #GObject signal details are implemented by scanning a linked list, so there is no real decrease in complexity</doc> <virtual-method name="action_added" invoker="action_added"> <doc xml:space="preserve">This function is called when an action that the observer is registered to receive events for is added. This function should only be called by objects with which the observer has explicitly registered itself to receive events.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </instance-parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="parameter_type" transfer-ownership="none"> <doc xml:space="preserve">the parameter type for action invocations, or %NULL if no parameter is required</doc> <type name="GLib.VariantType" c:type="const GVariantType*"/> </parameter> <parameter name="enabled" transfer-ownership="none"> <doc xml:space="preserve">%TRUE if the action is now enabled</doc> <type name="gboolean" c:type="gboolean"/> </parameter> <parameter name="state" transfer-ownership="none"> <doc xml:space="preserve">the current state of the action, or %NULL if the action is stateless</doc> <type name="GLib.Variant" c:type="GVariant*"/> </parameter> </parameters> </virtual-method> <virtual-method name="action_enabled_changed" invoker="action_enabled_changed"> <doc xml:space="preserve">This function is called when an action that the observer is registered to receive events for becomes enabled or disabled. This function should only be called by objects with which the observer has explicitly registered itself to receive events.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </instance-parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="enabled" transfer-ownership="none"> <doc xml:space="preserve">%TRUE if the action is now enabled</doc> <type name="gboolean" c:type="gboolean"/> </parameter> </parameters> </virtual-method> <virtual-method name="action_removed" invoker="action_removed"> <doc xml:space="preserve">This function is called when an action that the observer is registered to receive events for is removed. This function should only be called by objects with which the observer has explicitly registered itself to receive events.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </instance-parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> </parameters> </virtual-method> <virtual-method name="action_state_changed" invoker="action_state_changed"> <doc xml:space="preserve">This function is called when an action that the observer is registered to receive events for changes to its state. This function should only be called by objects with which the observer has explicitly registered itself to receive events.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </instance-parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="state" transfer-ownership="none"> <doc xml:space="preserve">the new state of the action</doc> <type name="GLib.Variant" c:type="GVariant*"/> </parameter> </parameters> </virtual-method> <virtual-method name="primary_accel_changed" invoker="primary_accel_changed"> <doc xml:space="preserve">This function is called when an action that the observer is registered to receive events for has one of its accelerators changed. Accelerator changes are reported for all targets associated with the action. The @action_and_target string should be used to check if the reported target is the one that the observer is interested in.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </instance-parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="action_and_target" transfer-ownership="none"> <doc xml:space="preserve">detailed action of the changed accel, in "action and target" format</doc> <type name="utf8" c:type="const gchar*"/> </parameter> </parameters> </virtual-method> <method name="action_added" c:identifier="gtk_action_observer_action_added"> <doc xml:space="preserve">This function is called when an action that the observer is registered to receive events for is added. This function should only be called by objects with which the observer has explicitly registered itself to receive events.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </instance-parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="parameter_type" transfer-ownership="none"> <doc xml:space="preserve">the parameter type for action invocations, or %NULL if no parameter is required</doc> <type name="GLib.VariantType" c:type="const GVariantType*"/> </parameter> <parameter name="enabled" transfer-ownership="none"> <doc xml:space="preserve">%TRUE if the action is now enabled</doc> <type name="gboolean" c:type="gboolean"/> </parameter> <parameter name="state" transfer-ownership="none"> <doc xml:space="preserve">the current state of the action, or %NULL if the action is stateless</doc> <type name="GLib.Variant" c:type="GVariant*"/> </parameter> </parameters> </method> <method name="action_enabled_changed" c:identifier="gtk_action_observer_action_enabled_changed"> <doc xml:space="preserve">This function is called when an action that the observer is registered to receive events for becomes enabled or disabled. This function should only be called by objects with which the observer has explicitly registered itself to receive events.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </instance-parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="enabled" transfer-ownership="none"> <doc xml:space="preserve">%TRUE if the action is now enabled</doc> <type name="gboolean" c:type="gboolean"/> </parameter> </parameters> </method> <method name="action_removed" c:identifier="gtk_action_observer_action_removed"> <doc xml:space="preserve">This function is called when an action that the observer is registered to receive events for is removed. This function should only be called by objects with which the observer has explicitly registered itself to receive events.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </instance-parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> </parameters> </method> <method name="action_state_changed" c:identifier="gtk_action_observer_action_state_changed"> <doc xml:space="preserve">This function is called when an action that the observer is registered to receive events for changes to its state. This function should only be called by objects with which the observer has explicitly registered itself to receive events.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </instance-parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="state" transfer-ownership="none"> <doc xml:space="preserve">the new state of the action</doc> <type name="GLib.Variant" c:type="GVariant*"/> </parameter> </parameters> </method> <method name="primary_accel_changed" c:identifier="gtk_action_observer_primary_accel_changed"> <doc xml:space="preserve">This function is called when an action that the observer is registered to receive events for has one of its accelerators changed. Accelerator changes are reported for all targets associated with the action. The @action_and_target string should be used to check if the reported target is the one that the observer is interested in.</doc> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </instance-parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="action_and_target" transfer-ownership="none"> <doc xml:space="preserve">detailed action of the changed accel, in "action and target" format</doc> <type name="utf8" c:type="const gchar*"/> </parameter> </parameters> </method> </interface> <record name="ActionObserverInterface" c:type="GtkActionObserverInterface" glib:is-gtype-struct-for="ActionObserver"> <field name="g_iface"> <type name="GObject.TypeInterface" c:type="GTypeInterface"/> </field> <field name="action_added"> <callback name="action_added"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="parameter_type" transfer-ownership="none"> <doc xml:space="preserve">the parameter type for action invocations, or %NULL if no parameter is required</doc> <type name="GLib.VariantType" c:type="const GVariantType*"/> </parameter> <parameter name="enabled" transfer-ownership="none"> <doc xml:space="preserve">%TRUE if the action is now enabled</doc> <type name="gboolean" c:type="gboolean"/> </parameter> <parameter name="state" transfer-ownership="none"> <doc xml:space="preserve">the current state of the action, or %NULL if the action is stateless</doc> <type name="GLib.Variant" c:type="GVariant*"/> </parameter> </parameters> </callback> </field> <field name="action_enabled_changed"> <callback name="action_enabled_changed"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="enabled" transfer-ownership="none"> <doc xml:space="preserve">%TRUE if the action is now enabled</doc> <type name="gboolean" c:type="gboolean"/> </parameter> </parameters> </callback> </field> <field name="action_state_changed"> <callback name="action_state_changed"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="state" transfer-ownership="none"> <doc xml:space="preserve">the new state of the action</doc> <type name="GLib.Variant" c:type="GVariant*"/> </parameter> </parameters> </callback> </field> <field name="action_removed"> <callback name="action_removed"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> </parameters> </callback> </field> <field name="primary_accel_changed"> <callback name="primary_accel_changed"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <parameter name="observer" transfer-ownership="none"> <doc xml:space="preserve">a #GtkActionObserver</doc> <type name="ActionObserver" c:type="GtkActionObserver*"/> </parameter> <parameter name="observable" transfer-ownership="none"> <doc xml:space="preserve">the source of the event</doc> <type name="ActionObservable" c:type="GtkActionObservable*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <doc xml:space="preserve">the name of the action</doc> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="action_and_target" transfer-ownership="none"> <doc xml:space="preserve">detailed action of the changed accel, in "action and target" format</doc> <type name="utf8" c:type="const gchar*"/> </parameter> </parameters> </callback> </field> </record> <class name="MenuTrackerItem" c:symbol-prefix="menu_tracker_item" c:type="GtkMenuTrackerItem" parent="GObject.Object" glib:type-name="GtkMenuTrackerItem" glib:get-type="gtk_menu_tracker_item_get_type"> <doc xml:space="preserve">A #GtkMenuTrackerItem is a small helper class used by #GtkMenuTracker to represent menu items. It has one of three classes: normal item, separator, or submenu. If an item is one of the non-normal classes (submenu, separator), only the label of the item needs to be respected. Otherwise, all the properties of the item contribute to the item's appearance and state. Implementing the appearance of the menu item is up to toolkits, and certain toolkits may choose to ignore certain properties, like icon or accel. The role of the item determines its accessibility role, along with its decoration if the GtkMenuTrackerItem::toggled property is true. As an example, if the item has the role %GTK_MENU_TRACKER_ITEM_ROLE_CHECK and GtkMenuTrackerItem::toggled is %FALSE, its accessible role should be that of a check menu item, and no decoration should be drawn. But if GtkMenuTrackerItem::toggled is %TRUE, a checkmark should be drawn. All properties except for the two class-determining properties, GtkMenuTrackerItem::is-separator and GtkMenuTrackerItem::has-submenu are allowed to change, so listen to the notify signals to update your item's appearance. When using a GObject library, this can conveniently be done with g_object_bind_property() and #GBinding, and this is how this is implemented in GTK+; the appearance side is implemented in #GtkModelMenuItem. When an item is clicked, simply call gtk_menu_tracker_item_activated() in response. The #GtkMenuTrackerItem will take care of everything related to activating the item and will itself update the state of all items in response. Submenus are a special case of menu item. When an item is a submenu, you should create a submenu for it with gtk_menu_tracker_new_item_for_submenu(), and apply the same menu tracking logic you would for a toplevel menu. Applications using submenus may want to lazily build their submenus in response to the user clicking on it, as building a submenu may be expensive. Thus, the submenu has two special controls -- the submenu's visibility should be controlled by the GtkMenuTrackerItem::submenu-shown property, and if a user clicks on the submenu, do not immediately show the menu, but call gtk_menu_tracker_item_request_submenu_shown() and wait for the GtkMenuTrackerItem::submenu-shown property to update. If the user navigates, the application may want to be notified so it can cancel the expensive operation that it was using to build the submenu. Thus, gtk_menu_tracker_item_request_submenu_shown() takes a boolean parameter. Use %TRUE when the user wants to open the submenu, and %FALSE when the user wants to close the submenu.</doc> <implements name="ActionObserver"/> <method name="activated" c:identifier="gtk_menu_tracker_item_activated"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="get_accel" c:identifier="gtk_menu_tracker_item_get_accel"> <return-value transfer-ownership="none"> <type name="utf8" c:type="const gchar*"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="get_has_submenu" c:identifier="gtk_menu_tracker_item_get_has_submenu"> <doc xml:space="preserve">Returns whether the menu item has a submenu. If so, only certain properties may need to be obeyed. See the documentation for #GtkMenuTrackerItem.</doc> <return-value transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <doc xml:space="preserve">A #GtkMenuTrackerItem instance</doc> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="get_icon" c:identifier="gtk_menu_tracker_item_get_icon"> <return-value transfer-ownership="full"> <type name="Gio.Icon" c:type="GIcon*"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="get_is_separator" c:identifier="gtk_menu_tracker_item_get_is_separator"> <doc xml:space="preserve">Returns whether the menu item is a separator. If so, only certain properties may need to be obeyed. See the documentation for #GtkMenuTrackerItem.</doc> <return-value transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <doc xml:space="preserve">A #GtkMenuTrackerItem instance</doc> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="get_label" c:identifier="gtk_menu_tracker_item_get_label"> <return-value transfer-ownership="none"> <type name="utf8" c:type="const gchar*"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="get_role" c:identifier="gtk_menu_tracker_item_get_role"> <return-value transfer-ownership="none"> <type name="MenuTrackerItemRole" c:type="GtkMenuTrackerItemRole"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="get_sensitive" c:identifier="gtk_menu_tracker_item_get_sensitive"> <return-value transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="get_should_request_show" c:identifier="gtk_menu_tracker_item_get_should_request_show"> <return-value transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="get_submenu_shown" c:identifier="gtk_menu_tracker_item_get_submenu_shown"> <return-value transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="get_toggled" c:identifier="gtk_menu_tracker_item_get_toggled"> <return-value transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="get_visible" c:identifier="gtk_menu_tracker_item_get_visible"> <return-value transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> </parameters> </method> <method name="request_submenu_shown" c:identifier="gtk_menu_tracker_item_request_submenu_shown"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <instance-parameter name="self" transfer-ownership="none"> <type name="MenuTrackerItem" c:type="GtkMenuTrackerItem*"/> </instance-parameter> <parameter name="shown" transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </parameter> </parameters> </method> <property name="accel" transfer-ownership="none"> <type name="utf8" c:type="gchar*"/> </property> <property name="has-submenu" transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </property> <property name="icon" transfer-ownership="none"> <type name="Gio.Icon"/> </property> <property name="is-separator" transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </property> <property name="label" transfer-ownership="none"> <type name="utf8" c:type="gchar*"/> </property> <property name="role" transfer-ownership="none"> <type name="MenuTrackerItemRole"/> </property> <property name="sensitive" transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </property> <property name="submenu-shown" transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </property> <property name="toggled" transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </property> <property name="visible" transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </property> <glib:signal name="visibility-changed" when="first"> <return-value transfer-ownership="none"> <type name="none" c:type="void"/> </return-value> <parameters> <parameter name="object" transfer-ownership="none"> <type name="gboolean" c:type="gboolean"/> </parameter> </parameters> </glib:signal> </class> <enumeration name="MenuTrackerItemRole" glib:type-name="GtkMenuTrackerItemRole" glib:get-type="gtk_menu_tracker_item_role_get_type" c:type="GtkMenuTrackerItemRole"> <member name="normal" value="0" c:identifier="GTK_MENU_TRACKER_ITEM_ROLE_NORMAL" glib:nick="normal"> </member> <member name="check" value="1" c:identifier="GTK_MENU_TRACKER_ITEM_ROLE_CHECK" glib:nick="check"> </member> <member name="radio" value="2" c:identifier="GTK_MENU_TRACKER_ITEM_ROLE_RADIO" glib:nick="radio"> </member> </enumeration> <function name="print_action_and_target" c:identifier="gtk_print_action_and_target"> <return-value transfer-ownership="full"> <type name="utf8" c:type="gchar*"/> </return-value> <parameters> <parameter name="action_namespace" transfer-ownership="none"> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="action_name" transfer-ownership="none"> <type name="utf8" c:type="const gchar*"/> </parameter> <parameter name="target" transfer-ownership="none"> <type name="GLib.Variant" c:type="GVariant*"/> </parameter> </parameters> </function> </namespace> </repository>