diff options
| -rw-r--r-- | src/application-service-appstore.c | 49 | ||||
| -rw-r--r-- | src/application-service.xml | 2 | ||||
| -rw-r--r-- | src/indicator-application.c | 24 | 
3 files changed, 71 insertions, 4 deletions
| diff --git a/src/application-service-appstore.c b/src/application-service-appstore.c index d0b5570..d95007c 100644 --- a/src/application-service-appstore.c +++ b/src/application-service-appstore.c @@ -31,7 +31,7 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  #include "dbus-shared.h"  /* DBus Prototypes */ -static gboolean _application_service_server_get_applications (ApplicationServiceAppstore * appstore, GArray ** apps); +static gboolean _application_service_server_get_applications (ApplicationServiceAppstore * appstore, GPtrArray ** apps, GError ** error);  #include "application-service-server.h" @@ -647,9 +647,52 @@ application_service_appstore_application_remove (ApplicationServiceAppstore * ap  /* DBus Interface */  static gboolean -_application_service_server_get_applications (ApplicationServiceAppstore * appstore, GArray ** apps) +_application_service_server_get_applications (ApplicationServiceAppstore * appstore, GPtrArray ** apps, GError ** error)  { +	ApplicationServiceAppstorePrivate * priv = APPLICATION_SERVICE_APPSTORE_GET_PRIVATE(appstore); + +	*apps = g_ptr_array_new(); +	GList * listpntr; +	gint position = 0; + +	for (listpntr = priv->applications; listpntr != NULL; listpntr = g_list_next(listpntr)) { +		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_array_append(values, &value); +		g_value_unset(&value); + +		/* Position */ +		g_value_init(&value, G_TYPE_INT); +		g_value_set_int(&value, position++); +		g_value_array_append(values, &value); +		g_value_unset(&value); + +		/* DBus Address */ +		g_value_init(&value, G_TYPE_STRING); +		g_value_set_string(&value, ((Application *)listpntr->data)->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_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_path); +		g_value_array_append(values, &value); +		g_value_unset(&value); + +		g_ptr_array_add(*apps, values); +	} -	return FALSE; +	return TRUE;  } diff --git a/src/application-service.xml b/src/application-service.xml index d74aaa9..0b2e959 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(siso)" name="applications" direction="out" /> +			<arg type="a(sisos)" name="applications" direction="out" />  		</method>  <!-- Signals --> diff --git a/src/indicator-application.c b/src/indicator-application.c index 8e88f8e..ef11179 100644 --- a/src/indicator-application.c +++ b/src/indicator-application.c @@ -96,6 +96,7 @@ static void application_added (DBusGProxy * proxy, const gchar * iconname, gint  static void application_removed (DBusGProxy * proxy, gint position , IndicatorApplication * application);  static void application_icon_changed (DBusGProxy * proxy, gint position, const gchar * iconname, IndicatorApplication * application);  static void get_applications (DBusGProxy *proxy, GPtrArray *OUT_applications, GError *error, gpointer userdata); +static void get_applications_helper (gpointer data, gpointer user_data);  G_DEFINE_TYPE (IndicatorApplication, indicator_application, INDICATOR_OBJECT_TYPE); @@ -372,6 +373,29 @@ application_icon_changed (DBusGProxy * proxy, gint position, const gchar * iconn  static void  get_applications (DBusGProxy *proxy, GPtrArray *OUT_applications, GError *error, gpointer userdata)  { +	if (error != NULL) { +		g_warning("Unable to get application list: %s", error->message); +		return; +	} +	g_ptr_array_foreach(OUT_applications, get_applications_helper, userdata);  	return;  } + +/* A little helper that takes apart the DBus structure and calls +   application_added on every entry in the list. */ +static void +get_applications_helper (gpointer data, gpointer user_data) +{ +	GValueArray * array = (GValueArray *)data; + +	g_return_if_fail(array->n_values == 5); + +	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_path = g_value_get_string(g_value_array_get_nth(array, 4)); + +	return application_added(NULL, icon_name, position, dbus_address, dbus_object, icon_path, user_data); +} | 
