From 982bf2ed9cec576b599f0f87f3201675757eda05 Mon Sep 17 00:00:00 2001 From: Lars Uebernickel Date: Fri, 25 May 2012 11:25:37 +0200 Subject: appmenuitem: make app-info a construct-only property --- src/app-menu-item.c | 103 +++++++++++++++++++++++++++++++++++++++++++++------- src/app-menu-item.h | 1 + 2 files changed, 90 insertions(+), 14 deletions(-) (limited to 'src') diff --git a/src/app-menu-item.c b/src/app-menu-item.c index b18b7c9..7638eb5 100644 --- a/src/app-menu-item.c +++ b/src/app-menu-item.c @@ -46,13 +46,31 @@ struct _AppMenuItemPrivate #define APP_MENU_ITEM_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), APP_MENU_ITEM_TYPE, AppMenuItemPrivate)) +enum { + PROP_0, + PROP_APPINFO, + NUM_PROPERTIES +}; + +static GParamSpec *properties[NUM_PROPERTIES]; + /* Prototypes */ -static void app_menu_item_class_init (AppMenuItemClass *klass); -static void app_menu_item_init (AppMenuItem *self); -static void app_menu_item_dispose (GObject *object); -static void activate_cb (GSimpleAction *action, - GVariant *param, - gpointer userdata); +static void app_menu_item_class_init (AppMenuItemClass *klass); +static void app_menu_item_init (AppMenuItem *self); +static void app_menu_item_get_property (GObject *object, + guint property_id, + GValue *value, + GParamSpec *pspec); +static void app_menu_item_set_property (GObject *object, + guint property_id, + const GValue *value, + GParamSpec *pspec); +static void app_menu_item_dispose (GObject *object); +static void activate_cb (GSimpleAction *action, + GVariant *param, + gpointer userdata); +static void app_menu_item_set_app_info (AppMenuItem *self, + GDesktopAppInfo *appinfo); /* GObject Boilerplate */ G_DEFINE_TYPE (AppMenuItem, app_menu_item, G_TYPE_OBJECT); @@ -64,7 +82,17 @@ app_menu_item_class_init (AppMenuItemClass *klass) g_type_class_add_private (klass, sizeof (AppMenuItemPrivate)); + object_class->get_property = app_menu_item_get_property; + object_class->set_property = app_menu_item_set_property; object_class->dispose = app_menu_item_dispose; + + properties[PROP_APPINFO] = g_param_spec_object ("app-info", + "AppInfo", + "The GAppInfo for the app that this menu represents", + G_TYPE_APP_INFO, + G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY); + + g_object_class_install_properties (object_class, NUM_PROPERTIES, properties); } static void @@ -82,6 +110,43 @@ app_menu_item_init (AppMenuItem *self) return; } +static void +app_menu_item_get_property (GObject *object, + guint property_id, + GValue *value, + GParamSpec *pspec) +{ + AppMenuItem *self = APP_MENU_ITEM (object); + + switch (property_id) + { + case PROP_APPINFO: + g_value_set_object (value, app_menu_item_get_app_info (self)); + break; + + default: + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); + } +} + +static void +app_menu_item_set_property (GObject *object, + guint property_id, + const GValue *value, + GParamSpec *pspec) +{ + AppMenuItem *self = APP_MENU_ITEM (object); + + switch (property_id) + { + case PROP_APPINFO: + app_menu_item_set_app_info (self, g_value_get_object (value)); + break; + + default: + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); + } +} static void app_menu_item_dispose (GObject *object) { @@ -123,8 +188,8 @@ nick_activate_cb (GSimpleAction *action, } static void -app_menu_item_set_appinfo (AppMenuItem *self, - GDesktopAppInfo *appinfo) +app_menu_item_set_app_info (AppMenuItem *self, + GDesktopAppInfo *appinfo) { AppMenuItemPrivate *priv = APP_MENU_ITEM_GET_PRIVATE (self); GSimpleAction *launch; @@ -133,9 +198,13 @@ app_menu_item_set_appinfo (AppMenuItem *self, gchar *iconstr = NULL; gchar *label; - g_return_if_fail (appinfo != NULL); + g_return_if_fail (priv->appinfo == NULL); + + if (appinfo == NULL) { + g_warning ("appinfo must not be NULL"); + return; + } - g_clear_object (&priv->appinfo); priv->appinfo = g_object_ref (appinfo); icon = g_app_info_get_icon (G_APP_INFO(priv->appinfo)); @@ -185,10 +254,9 @@ app_menu_item_set_appinfo (AppMenuItem *self, AppMenuItem * app_menu_item_new (GDesktopAppInfo *appinfo) { - AppMenuItem *self = g_object_new(APP_MENU_ITEM_TYPE, NULL); - if (appinfo) - app_menu_item_set_appinfo (self, appinfo); - return self; + return g_object_new (APP_MENU_ITEM_TYPE, + "app-info", appinfo, + NULL); } static void @@ -245,3 +313,10 @@ app_menu_item_get_menu (AppMenuItem *appitem) return G_MENU_MODEL (priv->menu); } +GAppInfo * +app_menu_item_get_app_info (AppMenuItem *appitem) +{ + AppMenuItemPrivate * priv = APP_MENU_ITEM_GET_PRIVATE(appitem); + return G_APP_INFO (priv->appinfo); +} + diff --git a/src/app-menu-item.h b/src/app-menu-item.h index cec5bb0..1fb2762 100644 --- a/src/app-menu-item.h +++ b/src/app-menu-item.h @@ -50,6 +50,7 @@ guint app_menu_item_get_count (AppMenuItem * appitem); const gchar * app_menu_item_get_name (AppMenuItem * appitem); const gchar * app_menu_item_get_desktop (AppMenuItem * appitem); GMenuModel * app_menu_item_get_menu (AppMenuItem *appitem); +GAppInfo * app_menu_item_get_app_info (AppMenuItem *appitem); G_END_DECLS -- cgit v1.2.3