diff options
author | Ted Gould <ted@gould.cx> | 2010-01-20 14:42:59 -0600 |
---|---|---|
committer | Ted Gould <ted@gould.cx> | 2010-01-20 14:42:59 -0600 |
commit | b22c464dacbc94cb5e73584021aa00bb87b9a28c (patch) | |
tree | a6fca8b185aa2a807a961b870e3a0c9177071890 /src/application-service-appstore.c | |
parent | ba6eadc425796f206169d3ffd91934417f045506 (diff) | |
parent | 9c545b7e13a3c0926d569775cfe5ff470874f675 (diff) | |
download | libayatana-appindicator-b22c464dacbc94cb5e73584021aa00bb87b9a28c.tar.gz libayatana-appindicator-b22c464dacbc94cb5e73584021aa00bb87b9a28c.tar.bz2 libayatana-appindicator-b22c464dacbc94cb5e73584021aa00bb87b9a28c.zip |
Merge to get the current list of applications on startup.
Diffstat (limited to 'src/application-service-appstore.c')
-rw-r--r-- | src/application-service-appstore.c | 49 |
1 files changed, 46 insertions, 3 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; } |