diff options
| -rw-r--r-- | src/application-service-appstore.c | 144 | ||||
| -rw-r--r-- | src/application-service-appstore.h | 3 | ||||
| -rw-r--r-- | src/application-service-marshal.list | 3 | ||||
| -rw-r--r-- | src/application-service.xml | 10 | ||||
| -rw-r--r-- | src/indicator-application.c | 217 | 
5 files changed, 331 insertions, 46 deletions
| diff --git a/src/application-service-appstore.c b/src/application-service-appstore.c index f18a89e..55906ff 100644 --- a/src/application-service-appstore.c +++ b/src/application-service-appstore.c @@ -38,17 +38,20 @@ static gboolean _application_service_server_get_applications (ApplicationService  #include "application-service-server.h" -#define NOTIFICATION_ITEM_PROP_ID         "Id" -#define NOTIFICATION_ITEM_PROP_CATEGORY   "Category" -#define NOTIFICATION_ITEM_PROP_STATUS     "Status" -#define NOTIFICATION_ITEM_PROP_ICON_NAME  "IconName" -#define NOTIFICATION_ITEM_PROP_AICON_NAME "AttentionIconName" +#define NOTIFICATION_ITEM_PROP_ID               "Id" +#define NOTIFICATION_ITEM_PROP_CATEGORY         "Category" +#define NOTIFICATION_ITEM_PROP_STATUS           "Status" +#define NOTIFICATION_ITEM_PROP_ICON_NAME        "IconName" +#define NOTIFICATION_ITEM_PROP_AICON_NAME       "AttentionIconName"  #define NOTIFICATION_ITEM_PROP_ICON_THEME_PATH  "IconThemePath" -#define NOTIFICATION_ITEM_PROP_MENU       "Menu" - -#define NOTIFICATION_ITEM_SIG_NEW_ICON    "NewIcon" -#define NOTIFICATION_ITEM_SIG_NEW_AICON   "NewAttentionIcon" -#define NOTIFICATION_ITEM_SIG_NEW_STATUS  "NewStatus" +#define NOTIFICATION_ITEM_PROP_MENU             "Menu" +#define NOTIFICATION_ITEM_PROP_LABEL            "Label" +#define NOTIFICATION_ITEM_PROP_LABEL_GUIDE      "LabelGuide" + +#define NOTIFICATION_ITEM_SIG_NEW_ICON               "NewIcon" +#define NOTIFICATION_ITEM_SIG_NEW_AICON              "NewAttentionIcon" +#define NOTIFICATION_ITEM_SIG_NEW_STATUS             "NewStatus" +#define NOTIFICATION_ITEM_SIG_NEW_LABEL              "NewLabel"  #define NOTIFICATION_ITEM_SIG_NEW_ICON_THEME_PATH    "NewIconThemePath"  /* Private Stuff */ @@ -79,6 +82,8 @@ struct _Application {  	gchar * aicon;  	gchar * menu;  	gchar * icon_theme_path; +	gchar * label; +	gchar * guide;  	gboolean currently_free;  }; @@ -90,6 +95,7 @@ enum {  	APPLICATION_ADDED,  	APPLICATION_REMOVED,  	APPLICATION_ICON_CHANGED, +	APPLICATION_LABEL_CHANGED,  	APPLICATION_ICON_THEME_PATH_CHANGED,  	LAST_SIGNAL  }; @@ -124,8 +130,8 @@ application_service_appstore_class_init (ApplicationServiceAppstoreClass *klass)  	                                           G_SIGNAL_RUN_LAST,  	                                           G_STRUCT_OFFSET (ApplicationServiceAppstoreClass, application_added),  	                                           NULL, NULL, -	                                           _application_service_marshal_VOID__STRING_INT_STRING_STRING_STRING, -	                                           G_TYPE_NONE, 5, G_TYPE_STRING, G_TYPE_INT, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_NONE); +	                                           _application_service_marshal_VOID__STRING_INT_STRING_STRING_STRING_STRING_STRING, +	                                           G_TYPE_NONE, 7, G_TYPE_STRING, G_TYPE_INT, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_NONE);  	signals[APPLICATION_REMOVED] = g_signal_new ("application-removed",  	                                           G_TYPE_FROM_CLASS(klass),  	                                           G_SIGNAL_RUN_LAST, @@ -147,6 +153,19 @@ application_service_appstore_class_init (ApplicationServiceAppstoreClass *klass)  	                                           NULL, NULL,  	                                           _application_service_marshal_VOID__INT_STRING,  	                                           G_TYPE_NONE, 2, G_TYPE_INT, G_TYPE_STRING, G_TYPE_NONE); +	signals[APPLICATION_LABEL_CHANGED] = g_signal_new ("application-label-changed", +	                                           G_TYPE_FROM_CLASS(klass), +	                                           G_SIGNAL_RUN_LAST, +	                                           G_STRUCT_OFFSET (ApplicationServiceAppstoreClass, application_label_changed), +	                                           NULL, NULL, +	                                           _application_service_marshal_VOID__INT_STRING_STRING, +	                                           G_TYPE_NONE, 3, G_TYPE_INT, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_NONE); + +	dbus_g_object_register_marshaller(_application_service_marshal_VOID__STRING_STRING, +	                                  G_TYPE_NONE, +	                                  G_TYPE_STRING, +	                                  G_TYPE_STRING, +	                                  G_TYPE_INVALID);  	dbus_g_object_type_install_info(APPLICATION_SERVICE_APPSTORE_TYPE,  	                                &dbus_glib__application_service_server_object_info); @@ -262,6 +281,20 @@ get_all_properties_cb (DBusGProxy * proxy, GHashTable * properties, GError * err  		app->icon_theme_path = g_strdup("");  	} +	gpointer label_data = g_hash_table_lookup(properties, NOTIFICATION_ITEM_PROP_LABEL); +	if (label_data != NULL) { +		app->label = g_value_dup_string((GValue *)label_data); +	} else { +		app->label = g_strdup(""); +	} + +	gpointer guide_data = g_hash_table_lookup(properties, NOTIFICATION_ITEM_PROP_LABEL_GUIDE); +	if (guide_data != NULL) { +		app->guide = g_value_dup_string((GValue *)guide_data); +	} else { +		app->guide = g_strdup(""); +	} +  	/* TODO: Calling approvers, but we're ignoring the results.  So, eh. */  	g_list_foreach(priv->approvers, check_with_old_approver, app); @@ -358,6 +391,12 @@ application_free (Application * app)  	if (app->icon_theme_path != NULL) {  		g_free(app->icon_theme_path);  	} +	if (app->label != NULL) { +		g_free(app->label); +	} +	if (app->guide != NULL) { +		g_free(app->guide); +	}  	g_free(app);  	return; @@ -455,6 +494,8 @@ apply_status (Application * app, AppIndicatorStatus status)                                                app->dbus_name,                                                app->menu,                                                app->icon_theme_path, +                                              app->label, +                                              app->guide,                                                TRUE);                          }  		} else { @@ -621,6 +662,48 @@ new_icon_theme_path (DBusGProxy * proxy, const gchar * icon_theme_path, gpointer  	return;  } +/* Called when the Notification Item signals that it +   has a new label. */ +static void +new_label (DBusGProxy * proxy, const gchar * label, const gchar * guide, gpointer data) +{ +	Application * app = (Application *)data; +	if (!app->validated) return; + +	gboolean changed = FALSE; + +	if (g_strcmp0(app->label, label) != 0) { +		changed = TRUE; +		if (app->label != NULL) { +			g_free(app->label); +			app->label = NULL; +		} +		app->label = g_strdup(label); +	} + +	if (g_strcmp0(app->guide, guide) != 0) { +		changed = TRUE; +		if (app->guide != NULL) { +			g_free(app->guide); +			app->guide = NULL; +		} +		app->guide = g_strdup(guide); +	} + +	if (changed) { +		gint position = get_position(app); +		if (position == -1) return; + +		g_signal_emit(app->appstore, signals[APPLICATION_LABEL_CHANGED], 0, +					  position, +		              app->label != NULL ? app->label : "",  +		              app->guide != NULL ? app->guide : "", +		              TRUE); +	} + +	return; +} +  /* Adding a new NotificationItem object from DBus in to the     appstore.  First, we need to get the information on it     though. */ @@ -648,6 +731,8 @@ application_service_appstore_application_add (ApplicationServiceAppstore * appst  	app->aicon = NULL;  	app->menu = NULL;  	app->icon_theme_path = NULL; +	app->label = NULL; +	app->guide = NULL;  	app->currently_free = FALSE;  	/* Get the DBus proxy for the NotificationItem interface */ @@ -698,7 +783,12 @@ application_service_appstore_application_add (ApplicationServiceAppstore * appst  	                        NOTIFICATION_ITEM_SIG_NEW_ICON_THEME_PATH,  	                        G_TYPE_STRING,  	                        G_TYPE_INVALID); -	 +	dbus_g_proxy_add_signal(app->dbus_proxy, +	                        NOTIFICATION_ITEM_SIG_NEW_LABEL, +	                        G_TYPE_STRING, +	                        G_TYPE_STRING, +	                        G_TYPE_INVALID); +  	dbus_g_proxy_connect_signal(app->dbus_proxy,  	                            NOTIFICATION_ITEM_SIG_NEW_ICON,  	                            G_CALLBACK(new_icon), @@ -719,7 +809,12 @@ application_service_appstore_application_add (ApplicationServiceAppstore * appst  	                            G_CALLBACK(new_icon_theme_path),  	                            app,  	                            NULL); -	 +	dbus_g_proxy_connect_signal(app->dbus_proxy, +	                            NOTIFICATION_ITEM_SIG_NEW_LABEL, +	                            G_CALLBACK(new_label), +	                            app, +	                            NULL); +  	/* Get all the propertiees */  	org_freedesktop_DBus_Properties_get_all_async(app->prop_proxy,  	                                              NOTIFICATION_ITEM_DBUS_IFACE, @@ -778,13 +873,14 @@ _application_service_server_get_applications (ApplicationServiceAppstore * appst  	gint position = 0;  	for (listpntr = priv->applications; listpntr != NULL; listpntr = g_list_next(listpntr)) { +		Application * app = (Application *)listpntr->data;  		GValueArray * values = g_value_array_new(5);  		GValue value = {0};  		/* Icon name */  		g_value_init(&value, G_TYPE_STRING); -		g_value_set_string(&value, ((Application *)listpntr->data)->icon); +		g_value_set_string(&value, app->icon);  		g_value_array_append(values, &value);  		g_value_unset(&value); @@ -796,19 +892,31 @@ _application_service_server_get_applications (ApplicationServiceAppstore * appst  		/* DBus Address */  		g_value_init(&value, G_TYPE_STRING); -		g_value_set_string(&value, ((Application *)listpntr->data)->dbus_name); +		g_value_set_string(&value, app->dbus_name);  		g_value_array_append(values, &value);  		g_value_unset(&value);  		/* DBus Object */  		g_value_init(&value, DBUS_TYPE_G_OBJECT_PATH); -		g_value_set_static_boxed(&value, ((Application *)listpntr->data)->menu); +		g_value_set_static_boxed(&value, app->menu);  		g_value_array_append(values, &value);  		g_value_unset(&value);  		/* Icon path */  		g_value_init(&value, G_TYPE_STRING); -		g_value_set_string(&value, ((Application *)listpntr->data)->icon_theme_path); +		g_value_set_string(&value, app->icon_theme_path); +		g_value_array_append(values, &value); +		g_value_unset(&value); + +		/* Label */ +		g_value_init(&value, G_TYPE_STRING); +		g_value_set_string(&value, app->label); +		g_value_array_append(values, &value); +		g_value_unset(&value); + +		/* Guide */ +		g_value_init(&value, G_TYPE_STRING); +		g_value_set_string(&value, app->guide);  		g_value_array_append(values, &value);  		g_value_unset(&value); diff --git a/src/application-service-appstore.h b/src/application-service-appstore.h index 422b0fd..9ae2874 100644 --- a/src/application-service-appstore.h +++ b/src/application-service-appstore.h @@ -45,8 +45,9 @@ struct _ApplicationServiceAppstoreClass {  	void (*application_added) (ApplicationServiceAppstore * appstore, gchar *, gint, gchar *, gchar *, gpointer);  	void (*application_removed) (ApplicationServiceAppstore * appstore, gint, gpointer); -	void (*application_icon_changed)(ApplicationServiceAppstore * appstore, gint, const gchar *, gpointer);	 +	void (*application_icon_changed)(ApplicationServiceAppstore * appstore, gint, const gchar *, gpointer);  	void (*application_icon_theme_path_changed)(ApplicationServiceAppstore * appstore, gint, const gchar *, gpointer); +	void (*application_label_changed)(ApplicationServiceAppstore * appstore, gint, const gchar *, const gchar *, gpointer);  };  struct _ApplicationServiceAppstore { diff --git a/src/application-service-marshal.list b/src/application-service-marshal.list index b49ff41..f432028 100644 --- a/src/application-service-marshal.list +++ b/src/application-service-marshal.list @@ -16,6 +16,7 @@  #   # You should have received a copy of the GNU General Public License along   # with this program.  If not, see <http://www.gnu.org/licenses/>. -VOID: STRING, INT, STRING, STRING, STRING +VOID: STRING, INT, STRING, STRING, STRING, STRING, STRING +VOID: INT, STRING, STRING  VOID: INT, STRING  VOID: STRING, STRING diff --git a/src/application-service.xml b/src/application-service.xml index dcccfa4..031bf68 100644 --- a/src/application-service.xml +++ b/src/application-service.xml @@ -26,7 +26,7 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  <!-- Methods -->  		<method name="GetApplications"> -			<arg type="a(sisos)" name="applications" direction="out" /> +			<arg type="a(sisosss)" name="applications" direction="out" />  		</method>  <!-- Signals --> @@ -36,6 +36,8 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  			<arg type="s" name="dbusaddress" direction="out" />  			<arg type="o" name="dbusobject" direction="out" />  			<arg type="s" name="iconpath" direction="out" /> +			<arg type="s" name="label" direction="out" /> +			<arg type="s" name="labelguide" direction="out" />  		</signal>  		<signal name="ApplicationRemoved">  			<arg type="i" name="position" direction="out" /> @@ -48,6 +50,10 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  			<arg type="i" name="position" direction="out" />  			<arg type="s" name="icon_theme_path" direction="out" />  		</signal> - +		<signal name="ApplicationLabelChanged"> +			<arg type="i" name="position" direction="out" /> +			<arg type="s" name="label" direction="out" /> +			<arg type="s" name="guide" direction="out" /> +		</signal>  	</interface>  </node> diff --git a/src/indicator-application.c b/src/indicator-application.c index 066ea63..36e1446 100644 --- a/src/indicator-application.c +++ b/src/indicator-application.c @@ -85,10 +85,11 @@ typedef struct _ApplicationEntry ApplicationEntry;  struct _ApplicationEntry {  	IndicatorObjectEntry entry;  	gchar * icon_theme_path; -	gchar * icon_name;  	gboolean old_service;  	gchar * dbusobject;  	gchar * dbusaddress; +	gchar * guide; +	gchar * longname;  };  #define INDICATOR_APPLICATION_GET_PRIVATE(o) \ @@ -106,8 +107,9 @@ static void disconnected (IndicatorApplication * application);  static void disconnected_helper (gpointer data, gpointer user_data);  static gboolean disconnected_kill (gpointer user_data);  static void disconnected_kill_helper (gpointer data, gpointer user_data); -static void application_added (DBusGProxy * proxy, const gchar * iconname, gint position, const gchar * dbusaddress, const gchar * dbusobject, const gchar * icon_theme_path, IndicatorApplication * application); +static void application_added (DBusGProxy * proxy, const gchar * iconname, gint position, const gchar * dbusaddress, const gchar * dbusobject, const gchar * icon_theme_path, const gchar * label, const gchar * guide, IndicatorApplication * application);  static void application_removed (DBusGProxy * proxy, gint position , IndicatorApplication * application); +static void application_label_changed (DBusGProxy * proxy, gint position, const gchar * label, const gchar * guide, IndicatorApplication * application);  static void application_icon_changed (DBusGProxy * proxy, gint position, const gchar * iconname, IndicatorApplication * application);  static void application_icon_theme_path_changed (DBusGProxy * proxy, gint position, const gchar * icon_theme_path, IndicatorApplication * application);  static void get_applications (DBusGProxy *proxy, GPtrArray *OUT_applications, GError *error, gpointer userdata); @@ -132,19 +134,27 @@ indicator_application_class_init (IndicatorApplicationClass *klass)  	io_class->get_entries = get_entries;  	io_class->get_location = get_location; -	dbus_g_object_register_marshaller(_application_service_marshal_VOID__STRING_INT_STRING_STRING_STRING, +	dbus_g_object_register_marshaller(_application_service_marshal_VOID__STRING_INT_STRING_STRING_STRING_STRING_STRING,  	                                  G_TYPE_NONE,  	                                  G_TYPE_STRING,  	                                  G_TYPE_INT,  	                                  G_TYPE_STRING,  	                                  G_TYPE_STRING,  	                                  G_TYPE_STRING, +	                                  G_TYPE_STRING, +	                                  G_TYPE_STRING,  	                                  G_TYPE_INVALID);  	dbus_g_object_register_marshaller(_application_service_marshal_VOID__INT_STRING,  	                                  G_TYPE_NONE,  	                                  G_TYPE_INT,  	                                  G_TYPE_STRING,  	                                  G_TYPE_INVALID); +	dbus_g_object_register_marshaller(_application_service_marshal_VOID__INT_STRING_STRING, +	                                  G_TYPE_NONE, +	                                  G_TYPE_INT, +	                                  G_TYPE_STRING, +	                                  G_TYPE_STRING, +	                                  G_TYPE_INVALID);  	return;  } @@ -272,6 +282,8 @@ connected (IndicatorApplication * application)  	                        	G_TYPE_STRING,  	                        	G_TYPE_STRING,  	                        	G_TYPE_STRING, +	                        	G_TYPE_STRING, +	                        	G_TYPE_STRING,  	                        	G_TYPE_INVALID);  		dbus_g_proxy_add_signal(priv->service_proxy,  	                        	"ApplicationRemoved", @@ -287,6 +299,12 @@ connected (IndicatorApplication * application)  	                        	G_TYPE_INT,  	                        	G_TYPE_STRING,  	                        	G_TYPE_INVALID); +		dbus_g_proxy_add_signal(priv->service_proxy, +	                        	"ApplicationLabelChanged", +	                        	G_TYPE_INT, +	                        	G_TYPE_STRING, +	                        	G_TYPE_STRING, +	                        	G_TYPE_INVALID);  		/* Connect to them */  		g_debug("Connect to them."); @@ -310,6 +328,11 @@ connected (IndicatorApplication * application)  	                            	G_CALLBACK(application_icon_theme_path_changed),  	                            	application,  	                            	NULL /* Disconnection Signal */); +		dbus_g_proxy_connect_signal(priv->service_proxy, +	                            	"ApplicationLabelChanged", +	                            	G_CALLBACK(application_label_changed), +	                            	application, +	                            	NULL /* Disconnection Signal */);  	}  	/* Query it for existing applications */ @@ -421,11 +444,51 @@ application_added_search (gconstpointer a, gconstpointer b)  	return -1;  } +/* Does a quick meausre of how big the string is in +   pixels with a Pango layout */ +static gint +measure_string (GtkStyle * style, PangoContext * context, const gchar * string) +{ +	PangoLayout * layout = pango_layout_new(context); +	pango_layout_set_text(layout, string, -1); +	pango_layout_set_font_description(layout, style->font_desc); + +	gint width; +	pango_layout_get_pixel_size(layout, &width, NULL); +	g_object_unref(layout); +	return width; +} + +/* Try to get a good guess at what a maximum width of the entire +   string would be. */ +static void +guess_label_size (ApplicationEntry * app) +{ +	/* This is during startup. */ +	if (app->entry.label == NULL) return; + +	GtkStyle * style = gtk_widget_get_style(GTK_WIDGET(app->entry.label)); +	PangoContext * context = gtk_widget_get_pango_context(GTK_WIDGET(app->entry.label)); + +	gint length = measure_string(style, context, gtk_label_get_text(app->entry.label)); + +	if (app->guide != NULL) { +		gint guidelen = measure_string(style, context, app->guide); +		if (guidelen > length) { +			length = guidelen; +		} +	} + +	gtk_widget_set_size_request(GTK_WIDGET(app->entry.label), length, -1); + +	return; +} +  /* Here we respond to new applications by building up the     ApplicationEntry and signaling the indicator host that     we've got a new indicator. */  static void -application_added (DBusGProxy * proxy, const gchar * iconname, gint position, const gchar * dbusaddress, const gchar * dbusobject, const gchar * icon_theme_path, IndicatorApplication * application) +application_added (DBusGProxy * proxy, const gchar * iconname, gint position, const gchar * dbusaddress, const gchar * dbusobject, const gchar * icon_theme_path, const gchar * label, const gchar * guide, IndicatorApplication * application)  {  	g_return_if_fail(IS_INDICATOR_APPLICATION(application));  	g_debug("Building new application entry: %s  with icon: %s", dbusaddress, iconname); @@ -455,21 +518,38 @@ application_added (DBusGProxy * proxy, const gchar * iconname, gint position, co  	app->dbusaddress = g_strdup(dbusaddress);  	app->dbusobject = g_strdup(dbusobject); +	app->guide = NULL; -    app->icon_name = g_strdup(iconname);  	/* We make a long name using the suffix, and if that  	   icon is available we want to use it.  Otherwise we'll  	   just use the name we were given. */ -	gchar * longname = NULL; +	app->longname = NULL;  	if (!g_str_has_suffix(iconname, PANEL_ICON_SUFFIX)) { -		longname = g_strdup_printf("%s-%s", iconname, PANEL_ICON_SUFFIX); +		app->longname = g_strdup_printf("%s-%s", iconname, PANEL_ICON_SUFFIX);  	} else { -		longname = g_strdup(iconname); +		app->longname = g_strdup(iconname); +	} +	app->entry.image = indicator_image_helper(app->longname); + +	if (label == NULL || label[0] == '\0') { +		app->entry.label = NULL; +	} else { +		app->entry.label = GTK_LABEL(gtk_label_new(label)); +		g_object_ref(G_OBJECT(app->entry.label)); +		gtk_widget_show(GTK_WIDGET(app->entry.label)); + +		if (app->guide != NULL) { +			g_free(app->guide); +			app->guide = NULL; +		} + +		if (guide != NULL) { +			app->guide = g_strdup(guide); +		} + +		guess_label_size(app);  	} -	app->entry.image = indicator_image_helper(longname); -	g_free(longname); -	app->entry.label = NULL;  	app->entry.menu = GTK_MENU(dbusmenu_gtkmenu_new((gchar *)dbusaddress, (gchar *)dbusobject));  	/* Keep copies of these for ourself, just in case. */ @@ -480,7 +560,6 @@ application_added (DBusGProxy * proxy, const gchar * iconname, gint position, co  	priv->applications = g_list_insert(priv->applications, app, position); -	/* TODO: Need to deal with position here somehow */  	g_signal_emit(G_OBJECT(application), INDICATOR_OBJECT_SIGNAL_ENTRY_ADDED_ID, 0, &(app->entry), TRUE);  	return;  } @@ -512,14 +591,16 @@ application_removed (DBusGProxy * proxy, gint position, IndicatorApplication * a  	if (app->dbusobject != NULL) {  		g_free(app->dbusobject);  	} -	if (app->icon_name != NULL) { -	    g_free(app->icon_name); -    } +	if (app->guide != NULL) { +		g_free(app->guide); +	} +	if (app->longname != NULL) { +		g_free(app->longname); +	}  	if (app->entry.image != NULL) {  		g_object_unref(G_OBJECT(app->entry.image));  	}  	if (app->entry.label != NULL) { -		g_warning("Odd, an application indicator with a label?");  		g_object_unref(G_OBJECT(app->entry.label));  	}  	if (app->entry.menu != NULL) { @@ -530,6 +611,87 @@ application_removed (DBusGProxy * proxy, gint position, IndicatorApplication * a  	return;  } +/* The callback for the signal that the label for an application +   has changed. */ +static void +application_label_changed (DBusGProxy * proxy, gint position, const gchar * label, const gchar * guide, IndicatorApplication * application) +{ +	IndicatorApplicationPrivate * priv = INDICATOR_APPLICATION_GET_PRIVATE(application); +	ApplicationEntry * app = (ApplicationEntry *)g_list_nth_data(priv->applications, position); +	gboolean signal_reload = FALSE; + +	if (app == NULL) { +		g_warning("Unable to find application at position: %d", position); +		return; +	} +	 +	if (label == NULL || label[0] == '\0') { +		/* No label, let's see if we need to delete the old one */ +		if (app->entry.label != NULL) { +			g_object_unref(G_OBJECT(app->entry.label)); +			app->entry.label = NULL; + +			signal_reload = TRUE; +		} +	} else { +		/* We've got a label, is this just an update or is +		   it a new thing. */ +		if (app->entry.label != NULL) { +			gtk_label_set_text(app->entry.label, label); +		} else { +			app->entry.label = GTK_LABEL(gtk_label_new(label)); +			g_object_ref(G_OBJECT(app->entry.label)); +			gtk_widget_show(GTK_WIDGET(app->entry.label)); + +			signal_reload = TRUE; +		} +	} + +	/* Copy the guide if we have one */ +	if (app->guide != NULL) { +		g_free(app->guide); +		app->guide = NULL; +	} + +	if (guide != NULL && guide[0] != '\0') { +		app->guide = g_strdup(guide); +	} + +	/* Protected against not having a label */ +	guess_label_size(app); + +	if (signal_reload) { +		/* Telling the listener that this has been removed, and then +		   readded to make it reparse the entry. */ +		if (app->entry.label != NULL) { +			gtk_widget_hide(GTK_WIDGET(app->entry.label)); +		} + +		if (app->entry.image != NULL) { +			gtk_widget_hide(GTK_WIDGET(app->entry.image)); +		} + +		if (app->entry.menu != NULL) { +			gtk_menu_detach(app->entry.menu); +		} + +		g_signal_emit(G_OBJECT(application), INDICATOR_OBJECT_SIGNAL_ENTRY_REMOVED_ID, 0, &(app->entry), TRUE); + +		if (app->entry.label != NULL) { +			gtk_widget_show(GTK_WIDGET(app->entry.label)); +		} + +		if (app->entry.image != NULL) { +			indicator_image_helper_update(app->entry.image, app->longname); +			gtk_widget_show(GTK_WIDGET(app->entry.image)); +		} + +		g_signal_emit(G_OBJECT(application), INDICATOR_OBJECT_SIGNAL_ENTRY_ADDED_ID, 0, &(app->entry), TRUE); +	} + +	return; +} +  /* The callback for the signal that the icon for an application     has changed. */  static void @@ -546,11 +708,16 @@ application_icon_changed (DBusGProxy * proxy, gint position, const gchar * iconn  	/* We make a long name using the suffix, and if that  	   icon is available we want to use it.  Otherwise we'll  	   just use the name we were given. */ -	gchar * longname = g_strdup_printf("%s-%s", iconname, PANEL_ICON_SUFFIX); -	indicator_image_helper_update(app->entry.image, longname); -	g_free(longname); -	 -	app->icon_name = g_strdup(iconname); +	if (app->longname != NULL) { +		g_free(app->longname); +		app->longname = NULL; +	} +	if (!g_str_has_suffix(iconname, PANEL_ICON_SUFFIX)) { +		app->longname = g_strdup_printf("%s-%s", iconname, PANEL_ICON_SUFFIX); +	} else { +		app->longname = g_strdup(iconname); +	} +	indicator_image_helper_update(app->entry.image, app->longname);  	return;  } @@ -578,7 +745,7 @@ application_icon_theme_path_changed (DBusGProxy * proxy, gint position, const gc  		    app->icon_theme_path = g_strdup(icon_theme_path);  		    theme_dir_ref(application, app->icon_theme_path);  	    } -	   indicator_image_helper_update(app->entry.image, app->icon_name); +	   indicator_image_helper_update(app->entry.image, app->longname);  	}  	return; @@ -605,15 +772,17 @@ get_applications_helper (gpointer data, gpointer user_data)  {  	GValueArray * array = (GValueArray *)data; -	g_return_if_fail(array->n_values == 5); +	g_return_if_fail(array->n_values == 7);  	const gchar * icon_name = g_value_get_string(g_value_array_get_nth(array, 0));  	gint position = g_value_get_int(g_value_array_get_nth(array, 1));  	const gchar * dbus_address = g_value_get_string(g_value_array_get_nth(array, 2));  	const gchar * dbus_object = g_value_get_boxed(g_value_array_get_nth(array, 3));  	const gchar * icon_theme_path = g_value_get_string(g_value_array_get_nth(array, 4)); +	const gchar * label = g_value_get_string(g_value_array_get_nth(array, 5)); +	const gchar * guide = g_value_get_string(g_value_array_get_nth(array, 6)); -	return application_added(NULL, icon_name, position, dbus_address, dbus_object, icon_theme_path, user_data); +	return application_added(NULL, icon_name, position, dbus_address, dbus_object, icon_theme_path, label, guide, user_data);  }  /* Unrefs a theme directory.  This may involve removing it from | 
