2022-06-29 16:02:05 +08:00
|
|
|
/*
|
|
|
|
* Copyright © 2011 Canonical Ltd.
|
|
|
|
*
|
2023-02-14 16:00:02 +08:00
|
|
|
* SPDX-License-Identifier: LGPL-2.1-or-later
|
|
|
|
*
|
2022-06-29 16:02:05 +08:00
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* Author: Ryan Lortie <desrt@desrt.ca>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __G_MENU_MODEL_H__
|
|
|
|
#define __G_MENU_MODEL_H__
|
|
|
|
|
|
|
|
#include <glib-object.h>
|
|
|
|
|
|
|
|
#include <gio/giotypes.h>
|
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_MENU_ATTRIBUTE_ACTION:
|
|
|
|
*
|
|
|
|
* The menu item attribute which holds the action name of the item. Action
|
|
|
|
* names are namespaced with an identifier for the action group in which the
|
|
|
|
* action resides. For example, "win." for window-specific actions and "app."
|
|
|
|
* for application-wide actions.
|
|
|
|
*
|
|
|
|
* See also g_menu_model_get_item_attribute() and g_menu_item_set_attribute().
|
|
|
|
*
|
|
|
|
* Since: 2.32
|
|
|
|
**/
|
|
|
|
#define G_MENU_ATTRIBUTE_ACTION "action"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_MENU_ATTRIBUTE_ACTION_NAMESPACE:
|
|
|
|
*
|
|
|
|
* The menu item attribute that holds the namespace for all action names in
|
|
|
|
* menus that are linked from this item.
|
|
|
|
*
|
|
|
|
* Since: 2.36
|
|
|
|
**/
|
|
|
|
#define G_MENU_ATTRIBUTE_ACTION_NAMESPACE "action-namespace"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_MENU_ATTRIBUTE_TARGET:
|
|
|
|
*
|
|
|
|
* The menu item attribute which holds the target with which the item's action
|
|
|
|
* will be activated.
|
|
|
|
*
|
|
|
|
* See also g_menu_item_set_action_and_target()
|
|
|
|
*
|
|
|
|
* Since: 2.32
|
|
|
|
**/
|
|
|
|
#define G_MENU_ATTRIBUTE_TARGET "target"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_MENU_ATTRIBUTE_LABEL:
|
|
|
|
*
|
|
|
|
* The menu item attribute which holds the label of the item.
|
|
|
|
*
|
|
|
|
* Since: 2.32
|
|
|
|
**/
|
|
|
|
#define G_MENU_ATTRIBUTE_LABEL "label"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_MENU_ATTRIBUTE_ICON:
|
|
|
|
*
|
|
|
|
* The menu item attribute which holds the icon of the item.
|
|
|
|
*
|
|
|
|
* The icon is stored in the format returned by g_icon_serialize().
|
|
|
|
*
|
|
|
|
* This attribute is intended only to represent 'noun' icons such as
|
|
|
|
* favicons for a webpage, or application icons. It should not be used
|
|
|
|
* for 'verbs' (ie: stock icons).
|
|
|
|
*
|
|
|
|
* Since: 2.38
|
|
|
|
**/
|
|
|
|
#define G_MENU_ATTRIBUTE_ICON "icon"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_MENU_LINK_SUBMENU:
|
|
|
|
*
|
|
|
|
* The name of the link that associates a menu item with a submenu.
|
|
|
|
*
|
|
|
|
* See also g_menu_item_set_link().
|
|
|
|
*
|
|
|
|
* Since: 2.32
|
|
|
|
**/
|
|
|
|
#define G_MENU_LINK_SUBMENU "submenu"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* G_MENU_LINK_SECTION:
|
|
|
|
*
|
|
|
|
* The name of the link that associates a menu item with a section. The linked
|
|
|
|
* menu will usually be shown in place of the menu item, using the item's label
|
|
|
|
* as a header.
|
|
|
|
*
|
|
|
|
* See also g_menu_item_set_link().
|
|
|
|
*
|
|
|
|
* Since: 2.32
|
|
|
|
**/
|
|
|
|
#define G_MENU_LINK_SECTION "section"
|
|
|
|
|
|
|
|
#define G_TYPE_MENU_MODEL (g_menu_model_get_type ())
|
|
|
|
#define G_MENU_MODEL(inst) (G_TYPE_CHECK_INSTANCE_CAST ((inst), \
|
|
|
|
G_TYPE_MENU_MODEL, GMenuModel))
|
|
|
|
#define G_MENU_MODEL_CLASS(class) (G_TYPE_CHECK_CLASS_CAST ((class), \
|
|
|
|
G_TYPE_MENU_MODEL, GMenuModelClass))
|
|
|
|
#define G_IS_MENU_MODEL(inst) (G_TYPE_CHECK_INSTANCE_TYPE ((inst), \
|
|
|
|
G_TYPE_MENU_MODEL))
|
|
|
|
#define G_IS_MENU_MODEL_CLASS(class) (G_TYPE_CHECK_CLASS_TYPE ((class), \
|
|
|
|
G_TYPE_MENU_MODEL))
|
|
|
|
#define G_MENU_MODEL_GET_CLASS(inst) (G_TYPE_INSTANCE_GET_CLASS ((inst), \
|
|
|
|
G_TYPE_MENU_MODEL, GMenuModelClass))
|
|
|
|
|
|
|
|
typedef struct _GMenuModelPrivate GMenuModelPrivate;
|
|
|
|
typedef struct _GMenuModelClass GMenuModelClass;
|
|
|
|
|
|
|
|
typedef struct _GMenuAttributeIterPrivate GMenuAttributeIterPrivate;
|
|
|
|
typedef struct _GMenuAttributeIterClass GMenuAttributeIterClass;
|
|
|
|
typedef struct _GMenuAttributeIter GMenuAttributeIter;
|
|
|
|
|
|
|
|
typedef struct _GMenuLinkIterPrivate GMenuLinkIterPrivate;
|
|
|
|
typedef struct _GMenuLinkIterClass GMenuLinkIterClass;
|
|
|
|
typedef struct _GMenuLinkIter GMenuLinkIter;
|
|
|
|
|
|
|
|
struct _GMenuModel
|
|
|
|
{
|
|
|
|
GObject parent_instance;
|
|
|
|
GMenuModelPrivate *priv;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GMenuModelClass::get_item_attributes:
|
|
|
|
* @model: the #GMenuModel to query
|
|
|
|
* @item_index: The #GMenuItem to query
|
|
|
|
* @attributes: (out) (element-type utf8 GLib.Variant): Attributes on the item
|
|
|
|
*
|
|
|
|
* Gets all the attributes associated with the item in the menu model.
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* GMenuModelClass::get_item_links:
|
|
|
|
* @model: the #GMenuModel to query
|
|
|
|
* @item_index: The #GMenuItem to query
|
|
|
|
* @links: (out) (element-type utf8 Gio.MenuModel): Links from the item
|
|
|
|
*
|
|
|
|
* Gets all the links associated with the item in the menu model.
|
|
|
|
*/
|
|
|
|
struct _GMenuModelClass
|
|
|
|
{
|
|
|
|
GObjectClass parent_class;
|
|
|
|
|
|
|
|
gboolean (*is_mutable) (GMenuModel *model);
|
|
|
|
gint (*get_n_items) (GMenuModel *model);
|
|
|
|
void (*get_item_attributes) (GMenuModel *model,
|
|
|
|
gint item_index,
|
|
|
|
GHashTable **attributes);
|
|
|
|
GMenuAttributeIter * (*iterate_item_attributes) (GMenuModel *model,
|
|
|
|
gint item_index);
|
|
|
|
GVariant * (*get_item_attribute_value) (GMenuModel *model,
|
|
|
|
gint item_index,
|
|
|
|
const gchar *attribute,
|
|
|
|
const GVariantType *expected_type);
|
|
|
|
void (*get_item_links) (GMenuModel *model,
|
|
|
|
gint item_index,
|
|
|
|
GHashTable **links);
|
|
|
|
GMenuLinkIter * (*iterate_item_links) (GMenuModel *model,
|
|
|
|
gint item_index);
|
|
|
|
GMenuModel * (*get_item_link) (GMenuModel *model,
|
|
|
|
gint item_index,
|
|
|
|
const gchar *link);
|
|
|
|
};
|
|
|
|
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
GType g_menu_model_get_type (void) G_GNUC_CONST;
|
|
|
|
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
gboolean g_menu_model_is_mutable (GMenuModel *model);
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
gint g_menu_model_get_n_items (GMenuModel *model);
|
|
|
|
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
GMenuAttributeIter * g_menu_model_iterate_item_attributes (GMenuModel *model,
|
|
|
|
gint item_index);
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
GVariant * g_menu_model_get_item_attribute_value (GMenuModel *model,
|
|
|
|
gint item_index,
|
|
|
|
const gchar *attribute,
|
|
|
|
const GVariantType *expected_type);
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
gboolean g_menu_model_get_item_attribute (GMenuModel *model,
|
|
|
|
gint item_index,
|
|
|
|
const gchar *attribute,
|
|
|
|
const gchar *format_string,
|
|
|
|
...);
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
GMenuLinkIter * g_menu_model_iterate_item_links (GMenuModel *model,
|
|
|
|
gint item_index);
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
GMenuModel * g_menu_model_get_item_link (GMenuModel *model,
|
|
|
|
gint item_index,
|
|
|
|
const gchar *link);
|
|
|
|
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
void g_menu_model_items_changed (GMenuModel *model,
|
|
|
|
gint position,
|
|
|
|
gint removed,
|
|
|
|
gint added);
|
|
|
|
|
|
|
|
|
|
|
|
#define G_TYPE_MENU_ATTRIBUTE_ITER (g_menu_attribute_iter_get_type ())
|
|
|
|
#define G_MENU_ATTRIBUTE_ITER(inst) (G_TYPE_CHECK_INSTANCE_CAST ((inst), \
|
|
|
|
G_TYPE_MENU_ATTRIBUTE_ITER, GMenuAttributeIter))
|
|
|
|
#define G_MENU_ATTRIBUTE_ITER_CLASS(class) (G_TYPE_CHECK_CLASS_CAST ((class), \
|
|
|
|
G_TYPE_MENU_ATTRIBUTE_ITER, GMenuAttributeIterClass))
|
|
|
|
#define G_IS_MENU_ATTRIBUTE_ITER(inst) (G_TYPE_CHECK_INSTANCE_TYPE ((inst), \
|
|
|
|
G_TYPE_MENU_ATTRIBUTE_ITER))
|
|
|
|
#define G_IS_MENU_ATTRIBUTE_ITER_CLASS(class) (G_TYPE_CHECK_CLASS_TYPE ((class), \
|
|
|
|
G_TYPE_MENU_ATTRIBUTE_ITER))
|
|
|
|
#define G_MENU_ATTRIBUTE_ITER_GET_CLASS(inst) (G_TYPE_INSTANCE_GET_CLASS ((inst), \
|
|
|
|
G_TYPE_MENU_ATTRIBUTE_ITER, GMenuAttributeIterClass))
|
|
|
|
|
|
|
|
struct _GMenuAttributeIter
|
|
|
|
{
|
|
|
|
GObject parent_instance;
|
|
|
|
GMenuAttributeIterPrivate *priv;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct _GMenuAttributeIterClass
|
|
|
|
{
|
|
|
|
GObjectClass parent_class;
|
|
|
|
|
|
|
|
gboolean (*get_next) (GMenuAttributeIter *iter,
|
|
|
|
const gchar **out_name,
|
|
|
|
GVariant **value);
|
|
|
|
};
|
|
|
|
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
GType g_menu_attribute_iter_get_type (void) G_GNUC_CONST;
|
|
|
|
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
gboolean g_menu_attribute_iter_get_next (GMenuAttributeIter *iter,
|
|
|
|
const gchar **out_name,
|
|
|
|
GVariant **value);
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
gboolean g_menu_attribute_iter_next (GMenuAttributeIter *iter);
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
const gchar * g_menu_attribute_iter_get_name (GMenuAttributeIter *iter);
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
GVariant * g_menu_attribute_iter_get_value (GMenuAttributeIter *iter);
|
|
|
|
|
|
|
|
|
|
|
|
#define G_TYPE_MENU_LINK_ITER (g_menu_link_iter_get_type ())
|
|
|
|
#define G_MENU_LINK_ITER(inst) (G_TYPE_CHECK_INSTANCE_CAST ((inst), \
|
|
|
|
G_TYPE_MENU_LINK_ITER, GMenuLinkIter))
|
|
|
|
#define G_MENU_LINK_ITER_CLASS(class) (G_TYPE_CHECK_CLASS_CAST ((class), \
|
|
|
|
G_TYPE_MENU_LINK_ITER, GMenuLinkIterClass))
|
|
|
|
#define G_IS_MENU_LINK_ITER(inst) (G_TYPE_CHECK_INSTANCE_TYPE ((inst), \
|
|
|
|
G_TYPE_MENU_LINK_ITER))
|
|
|
|
#define G_IS_MENU_LINK_ITER_CLASS(class) (G_TYPE_CHECK_CLASS_TYPE ((class), \
|
|
|
|
G_TYPE_MENU_LINK_ITER))
|
|
|
|
#define G_MENU_LINK_ITER_GET_CLASS(inst) (G_TYPE_INSTANCE_GET_CLASS ((inst), \
|
|
|
|
G_TYPE_MENU_LINK_ITER, GMenuLinkIterClass))
|
|
|
|
|
|
|
|
struct _GMenuLinkIter
|
|
|
|
{
|
|
|
|
GObject parent_instance;
|
|
|
|
GMenuLinkIterPrivate *priv;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct _GMenuLinkIterClass
|
|
|
|
{
|
|
|
|
GObjectClass parent_class;
|
|
|
|
|
|
|
|
gboolean (*get_next) (GMenuLinkIter *iter,
|
|
|
|
const gchar **out_link,
|
|
|
|
GMenuModel **value);
|
|
|
|
};
|
|
|
|
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
GType g_menu_link_iter_get_type (void) G_GNUC_CONST;
|
|
|
|
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
gboolean g_menu_link_iter_get_next (GMenuLinkIter *iter,
|
|
|
|
const gchar **out_link,
|
|
|
|
GMenuModel **value);
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
gboolean g_menu_link_iter_next (GMenuLinkIter *iter);
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
const gchar * g_menu_link_iter_get_name (GMenuLinkIter *iter);
|
|
|
|
GLIB_AVAILABLE_IN_2_32
|
|
|
|
GMenuModel * g_menu_link_iter_get_value (GMenuLinkIter *iter);
|
|
|
|
|
|
|
|
G_END_DECLS
|
|
|
|
|
|
|
|
#endif /* __G_MENU_MODEL_H__ */
|