diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/Makefile.in | 6 | ||||
| -rw-r--r-- | src/application-service-appstore.c | 9 | ||||
| -rw-r--r-- | src/application-service.xml | 3 | ||||
| -rw-r--r-- | src/gen-application-service.xml.c | 3 | ||||
| -rw-r--r-- | src/indicator-application.c | 36 | 
5 files changed, 36 insertions, 21 deletions
| diff --git a/src/Makefile.in b/src/Makefile.in index b5625bf..45c6786 100644 --- a/src/Makefile.in +++ b/src/Makefile.in @@ -56,10 +56,8 @@ DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in \  libexec_PROGRAMS = indicator-application-service$(EXEEXT)  subdir = src  ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/m4/libtool.m4 \ -	$(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ -	$(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ -	$(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac +am__aclocal_m4_deps = $(top_srcdir)/acinclude.m4 \ +	$(top_srcdir)/configure.ac  am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \  	$(ACLOCAL_M4)  mkinstalldirs = $(install_sh) -d diff --git a/src/application-service-appstore.c b/src/application-service-appstore.c index 238814e..9cd65b4 100644 --- a/src/application-service-appstore.c +++ b/src/application-service-appstore.c @@ -870,12 +870,12 @@ apply_status (Application * app)  		if (app->visible_state == VISIBLE_STATE_HIDDEN) {  			/* Put on panel */  			emit_signal (appstore, "ApplicationAdded", -				     g_variant_new ("(sisossss)", newicon, +				     g_variant_new ("(sisosssss)", newicon,  			                            get_position(app),  			                            app->dbus_name, app->menu,  			                            app->icon_theme_path,  			                            app->label, app->guide, -			                            newdesc)); +			                            newdesc, app->id));  		} else {  			/* Icon update */  			gint position = get_position(app); @@ -1265,11 +1265,12 @@ get_applications (ApplicationServiceAppstore * appstore)  				continue;  			} -			g_variant_builder_add (&builder, "(sisossss)", app->icon, +			g_variant_builder_add (&builder, "(sisosssss)", app->icon,  			                       position++, app->dbus_name, app->menu,  			                       app->icon_theme_path, app->label,  			                       app->guide, -			                       (app->icon_desc != NULL) ? app->icon_desc : ""); +			                       (app->icon_desc != NULL) ? app->icon_desc : "", +			                       app->id);  		}  		out = g_variant_builder_end(&builder); diff --git a/src/application-service.xml b/src/application-service.xml index f3164ef..1cffbc7 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(sisossss)" name="applications" direction="out" /> +			<arg type="a(sisosssss)" name="applications" direction="out" />  		</method>  		<method name="ApplicationScrollEvent">  			<arg type="s" name="dbusaddress" direction="in" /> @@ -45,6 +45,7 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  			<arg type="s" name="label" direction="out" />  			<arg type="s" name="labelguide" direction="out" />  			<arg type="s" name="accessibledesc" direction="out" /> +			<arg type="s" name="hint" direction="out" />  		</signal>  		<signal name="ApplicationRemoved">  			<arg type="i" name="position" direction="out" /> diff --git a/src/gen-application-service.xml.c b/src/gen-application-service.xml.c index cae1819..e3ae1c7 100644 --- a/src/gen-application-service.xml.c +++ b/src/gen-application-service.xml.c @@ -27,7 +27,7 @@ const char * _application_service =  "\n"  "<!-- Methods -->\n"  "		<method name=\"GetApplications\">\n" -"			<arg type=\"a(sisossss)\" name=\"applications\" direction=\"out\" />\n" +"			<arg type=\"a(sisosssss)\" name=\"applications\" direction=\"out\" />\n"  "		</method>\n"  "		<method name=\"ApplicationScrollEvent\">\n"  "			<arg type=\"s\" name=\"dbusaddress\" direction=\"in\" />\n" @@ -46,6 +46,7 @@ const char * _application_service =  "			<arg type=\"s\" name=\"label\" direction=\"out\" />\n"  "			<arg type=\"s\" name=\"labelguide\" direction=\"out\" />\n"  "			<arg type=\"s\" name=\"accessibledesc\" direction=\"out\" />\n" +"			<arg type=\"s\" name=\"hint\" direction=\"out\" />\n"  "		</signal>\n"  "		<signal name=\"ApplicationRemoved\">\n"  "			<arg type=\"i\" name=\"position\" direction=\"out\" />\n" diff --git a/src/indicator-application.c b/src/indicator-application.c index 2b26c92..dc810f4 100644 --- a/src/indicator-application.c +++ b/src/indicator-application.c @@ -109,14 +109,14 @@ static void indicator_application_dispose    (GObject *object);  static void indicator_application_finalize   (GObject *object);  static GList * get_entries (IndicatorObject * io);  static guint get_location (IndicatorObject * io, IndicatorObjectEntry * entry); -static void scroll_entry (IndicatorObject * io, IndicatorObjectEntry * entry, gint delta, IndicatorScrollDirection direction); +static void entry_scrolled (IndicatorObject * io, IndicatorObjectEntry * entry, gint delta, IndicatorScrollDirection direction);  void connection_changed (IndicatorServiceManager * sm, gboolean connected, IndicatorApplication * application);  static void connected (IndicatorApplication * application);  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 (IndicatorApplication * application, const gchar * iconname, gint position, const gchar * dbusaddress, const gchar * dbusobject, const gchar * icon_theme_path, const gchar * label, const gchar * guide, const gchar * accessible_desc); +static void application_added (IndicatorApplication * application, const gchar * iconname, gint position, const gchar * dbusaddress, const gchar * dbusobject, const gchar * icon_theme_path, const gchar * label, const gchar * guide, const gchar * accessible_desc, const gchar * hint);  static void application_removed (IndicatorApplication * application, gint position);  static void application_label_changed (IndicatorApplication * application, gint position, const gchar * label, const gchar * guide);  static void application_icon_changed (IndicatorApplication * application, gint position, const gchar * iconname, const gchar * icondesc); @@ -144,7 +144,7 @@ indicator_application_class_init (IndicatorApplicationClass *klass)  	io_class->get_entries = get_entries;  	io_class->get_location = get_location; -	io_class->scroll_entry = scroll_entry; +	io_class->entry_scrolled = entry_scrolled;  	return;  } @@ -403,7 +403,7 @@ get_location (IndicatorObject * io, IndicatorObjectEntry * entry)  }  /* Redirect the scroll event to the Application Item */ -static void scroll_entry (IndicatorObject * io, IndicatorObjectEntry * entry, gint delta, IndicatorScrollDirection direction) { +static void entry_scrolled (IndicatorObject * io, IndicatorObjectEntry * entry, gint delta, IndicatorScrollDirection direction) {  	g_return_if_fail(IS_INDICATOR_APPLICATION(io)); @@ -469,7 +469,7 @@ guess_label_size (ApplicationEntry * app)     ApplicationEntry and signaling the indicator host that     we've got a new indicator. */  static void -application_added (IndicatorApplication * application, const gchar * iconname, gint position, const gchar * dbusaddress, const gchar * dbusobject, const gchar * icon_theme_path, const gchar * label, const gchar * guide, const gchar * accessible_desc) +application_added (IndicatorApplication * application, const gchar * iconname, gint position, const gchar * dbusaddress, const gchar * dbusobject, const gchar * icon_theme_path, const gchar * label, const gchar * guide, const gchar * accessible_desc, const gchar * hint)  {  	g_return_if_fail(IS_INDICATOR_APPLICATION(application));  	g_debug("Building new application entry: %s  with icon: %s at position %i", dbusaddress, iconname, position); @@ -524,6 +524,12 @@ application_added (IndicatorApplication * application, const gchar * iconname, g  		app->entry.accessible_desc = g_strdup(accessible_desc);  	} +	if (hint == NULL || hint[0] == '\0') { +		app->entry.name_hint = NULL; +	} else { +		app->entry.name_hint = g_strdup(hint); +	} +  	app->entry.menu = GTK_MENU(dbusmenu_gtkmenu_new((gchar *)dbusaddress, (gchar *)dbusobject));  	/* Keep copies of these for ourself, just in case. */ @@ -580,6 +586,12 @@ application_removed (IndicatorApplication * application, gint position)  	if (app->entry.menu != NULL) {  		g_object_unref(G_OBJECT(app->entry.menu));  	} +	if (app->entry.accessible_desc != NULL) { +		g_free((gchar *)app->entry.accessible_desc); +	} +	if (app->entry.name_hint != NULL) { +		g_free((gchar *)app->entry.name_hint); +	}  	g_free(app);  	return; @@ -775,13 +787,14 @@ receive_signal (GDBusProxy * proxy, gchar * sender_name, gchar * signal_name,  		const gchar * label;  		const gchar * guide;  		const gchar * accessible_desc; -		g_variant_get (parameters, "(&si&s&o&s&s&s&s)", &iconname, +		const gchar * hint; +		g_variant_get (parameters, "(&si&s&o&s&s&s&s&s)", &iconname,  		               &position, &dbusaddress, &dbusobject,  		               &icon_theme_path, &label, &guide, -		               &accessible_desc); +		               &accessible_desc, &hint);  		application_added(self, iconname, position, dbusaddress,  		                  dbusobject, icon_theme_path, label, guide, -		                  accessible_desc); +		                  accessible_desc, hint);  	}  	else if (g_strcmp0(signal_name, "ApplicationRemoved") == 0) {  		gint position; @@ -872,11 +885,12 @@ get_applications_helper (IndicatorApplication * self, GVariant * variant)  	const gchar * label;  	const gchar * guide;  	const gchar * accessible_desc; -	g_variant_get(variant, "(sisossss)", &icon_name, &position, +	const gchar * hint; +	g_variant_get(variant, "(sisosssss)", &icon_name, &position,  	              &dbus_address, &dbus_object, &icon_theme_path, &label, -	              &guide, &accessible_desc); +	              &guide, &accessible_desc, &hint); -	return application_added(self, icon_name, position, dbus_address, dbus_object, icon_theme_path, label, guide, accessible_desc); +	return application_added(self, icon_name, position, dbus_address, dbus_object, icon_theme_path, label, guide, accessible_desc, hint);  }  /* Unrefs a theme directory.  This may involve removing it from | 
