diff options
| author | Ted Gould <ted@gould.cx> | 2011-04-06 16:43:21 -0500 | 
|---|---|---|
| committer | Ted Gould <ted@gould.cx> | 2011-04-06 16:43:21 -0500 | 
| commit | 1df0fbfcda860c90504b369f010cd8f2330ab14f (patch) | |
| tree | 4c25eabe64cf908d7262ebe79432e7a98d68d236 /src | |
| parent | 34ffc06debd8561c60fa43b9a12f08fe598745a5 (diff) | |
| parent | d20e74d9a59f8ef75127422e20bc8354eee04577 (diff) | |
| download | ayatana-indicator-messages-1df0fbfcda860c90504b369f010cd8f2330ab14f.tar.gz ayatana-indicator-messages-1df0fbfcda860c90504b369f010cd8f2330ab14f.tar.bz2 ayatana-indicator-messages-1df0fbfcda860c90504b369f010cd8f2330ab14f.zip | |
Add support for a specific icon on the menu
Diffstat (limited to 'src')
| -rw-r--r-- | src/app-menu-item.c | 47 | ||||
| -rw-r--r-- | src/default-applications.h | 4 | ||||
| -rw-r--r-- | src/launcher-menu-item.c | 36 | 
3 files changed, 75 insertions, 12 deletions
| diff --git a/src/app-menu-item.c b/src/app-menu-item.c index e846914..ef3fbc0 100644 --- a/src/app-menu-item.c +++ b/src/app-menu-item.c @@ -52,6 +52,7 @@ struct _AppMenuItemPrivate  	gchar * type;  	GAppInfo * appinfo; +	GKeyFile * keyfile;  	gchar * desktop;  	guint unreadcount; @@ -129,6 +130,7 @@ app_menu_item_init (AppMenuItem *self)  	priv->server = NULL;  	priv->type = NULL;  	priv->appinfo = NULL; +	priv->keyfile = NULL;  	priv->desktop = NULL;  	priv->unreadcount = 0; @@ -179,6 +181,16 @@ app_menu_item_dispose (GObject *object)  		priv->client = NULL;  	} +	if (priv->appinfo != NULL) { +		g_object_unref(priv->appinfo); +		priv->appinfo = NULL; +	} + +	if (priv->keyfile != NULL) { +		g_object_unref(priv->keyfile); +		priv->keyfile = NULL; +	} +  	G_OBJECT_CLASS (app_menu_item_parent_class)->dispose (object);  } @@ -192,14 +204,12 @@ app_menu_item_finalize (GObject *object)  	if (priv->type != NULL) {  		g_free(priv->type); +		priv->type = NULL;  	}  	if (priv->desktop != NULL) {  		g_free(priv->desktop); -	} - -	if (priv->appinfo != NULL) { -		g_object_unref(priv->appinfo); +		priv->desktop = NULL;  	}  	G_OBJECT_CLASS (app_menu_item_parent_class)->finalize (object); @@ -298,7 +308,7 @@ count_cb (IndicateListener * listener, IndicateListenerServer * server, guint va  /* Callback for when we ask the server for the path     to it's desktop file.  We then turn it into an     app structure and start sucking data out of it. -   Mostly the name. */ +   Mostly the name. And the icon. */  static void   desktop_cb (IndicateListener * listener, IndicateListenerServer * server, const gchar * value, gpointer data)  { @@ -325,6 +335,9 @@ desktop_cb (IndicateListener * listener, IndicateListenerServer * server, const  	priv->appinfo = G_APP_INFO(g_desktop_app_info_new_from_filename(value));  	g_return_if_fail(priv->appinfo != NULL); +	priv->keyfile = g_key_file_new(); +	g_key_file_load_from_file(priv->keyfile, value, G_KEY_FILE_NONE, NULL); +  	priv->desktop = g_strdup(value);  	dbusmenu_menuitem_property_set_bool(DBUSMENU_MENUITEM(self), DBUSMENU_MENUITEM_PROP_VISIBLE, TRUE); @@ -334,8 +347,28 @@ desktop_cb (IndicateListener * listener, IndicateListenerServer * server, const  	const gchar * def_icon = get_default_icon(priv->desktop);  	if (def_icon == NULL) { -		GIcon * icon = g_app_info_get_icon(priv->appinfo); -		gchar * iconstr = g_icon_to_string(icon); +		gchar * iconstr = NULL; + +		/* Check for the over ride key and see if we should be using that +		   icon.  If we can't get it, then go back to the app info */ +		if (g_key_file_has_key(priv->keyfile, G_KEY_FILE_DESKTOP_GROUP, ICON_KEY, NULL) && iconstr == NULL) { +			GError * error = NULL; + +			iconstr = g_key_file_get_string(priv->keyfile, G_KEY_FILE_DESKTOP_GROUP, ICON_KEY, &error); + +			if (error != NULL) { +				/* Can't figure out why this would happen, but sure, let's print something */ +				g_warning("Error getting '" ICON_KEY "' from desktop file: %s", error->message); +				g_error_free(error); +			} +		} + +		/* For some reason that didn't work, let's try the app info */ +		if (iconstr == NULL) { +			GIcon * icon = g_app_info_get_icon(priv->appinfo); +			iconstr = g_icon_to_string(icon); +		} +  		dbusmenu_menuitem_property_set(DBUSMENU_MENUITEM(self), APPLICATION_MENUITEM_PROP_ICON, iconstr);  		g_free(iconstr);  	} else { diff --git a/src/default-applications.h b/src/default-applications.h index 0a32e7c..df52b38 100644 --- a/src/default-applications.h +++ b/src/default-applications.h @@ -22,6 +22,10 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  #ifndef DEFAULT_APPLICATIONS_H__  #define DEFAULT_APPLICATIONS_H__ 1 +/* Used for override icons in the normal case, but didn't +   have a better place to put it. */ +#define ICON_KEY  "X-Ayatana-Messaging-Menu-Icon" +  const gchar * get_default_name  (const gchar * desktop_path);  const gchar * get_default_setup (const gchar * desktop_path);  const gchar * get_default_icon  (const gchar * desktop_path); diff --git a/src/launcher-menu-item.c b/src/launcher-menu-item.c index 60880ad..e01806e 100644 --- a/src/launcher-menu-item.c +++ b/src/launcher-menu-item.c @@ -44,6 +44,7 @@ typedef struct _LauncherMenuItemPrivate LauncherMenuItemPrivate;  struct _LauncherMenuItemPrivate  {  	GAppInfo * appinfo; +	GKeyFile * keyfile;  	gchar * desktop;  	IndicatorDesktopShortcuts * ids;  	GList * shortcuts; @@ -93,6 +94,7 @@ launcher_menu_item_init (LauncherMenuItem *self)  	priv->appinfo = NULL;  	priv->desktop = NULL; +	priv->keyfile = NULL;  	priv->ids = NULL;  	priv->shortcuts = NULL; @@ -120,6 +122,11 @@ launcher_menu_item_dispose (GObject *object)  		priv->appinfo = NULL;  	} +	if (priv->keyfile != NULL) { +		g_object_unref(priv->keyfile); +		priv->keyfile = NULL; +	} +  	if (priv->ids != NULL) {  		g_object_unref(priv->ids);  		priv->ids = NULL; @@ -160,6 +167,8 @@ launcher_menu_item_new (const gchar * desktop_file)  	/* Parse the desktop file we've been given. */  	priv->appinfo = G_APP_INFO(g_desktop_app_info_new_from_filename(desktop_file)); +	priv->keyfile = g_key_file_new(); +	g_key_file_load_from_file(priv->keyfile, desktop_file, G_KEY_FILE_NONE, NULL);  	priv->desktop = g_strdup(desktop_file);  	/* Set the appropriate values on this menu item based on the @@ -250,18 +259,35 @@ nick_activate_cb (LauncherMenuItem * self, guint timestamp, gpointer data)  	return;  } +/* Figure out the appropriate icon for this launcher */  gchar *  launcher_menu_item_get_icon (LauncherMenuItem * appitem)  {  	LauncherMenuItemPrivate * priv = LAUNCHER_MENU_ITEM_GET_PRIVATE(appitem); +	gchar * retval = NULL; -	if (priv->appinfo == NULL) { -		return NULL; -	} else { +	/* Check to see if there is a specific icon for the messaging +	   menu first.  */ +	if (g_key_file_has_key(priv->keyfile, G_KEY_FILE_DESKTOP_GROUP, ICON_KEY, NULL) && retval == NULL) { +		GError * error = NULL; + +		retval = g_key_file_get_string(priv->keyfile, G_KEY_FILE_DESKTOP_GROUP, ICON_KEY, &error); + +		if (error != NULL) { +			/* Can't figure out why this would happen, but sure, let's print something */ +			g_warning("Error getting '" ICON_KEY "' from desktop file: %s", error->message); +			g_error_free(error); +		} +	} + +	/* If there's not, or there is an error, we'll use the one +	   from the application info */ +	if (priv->appinfo != NULL && retval == NULL) {  		GIcon * icon = g_app_info_get_icon(priv->appinfo); -		gchar * iconstr = g_icon_to_string(icon); -		return iconstr; +		retval = g_icon_to_string(icon);  	} + +	return retval;  }  /* When the menu item is clicked on it tries to launch | 
