aboutsummaryrefslogtreecommitdiff
path: root/src/indicator-fusa.c
diff options
context:
space:
mode:
authorTed Gould <ted@canonical.com>2009-06-08 16:25:14 -0500
committerTed Gould <ted@canonical.com>2009-06-08 16:25:14 -0500
commit80b3de3f554b9d9fc60d20c4835026017465b61c (patch)
tree1ea8fe73f3cc8155df0125537c58f1af987b636c /src/indicator-fusa.c
parentd68a776f7c88fc1304572e4739a65ee1b93688e4 (diff)
downloadayatana-indicator-session-80b3de3f554b9d9fc60d20c4835026017465b61c.tar.gz
ayatana-indicator-session-80b3de3f554b9d9fc60d20c4835026017465b61c.tar.bz2
ayatana-indicator-session-80b3de3f554b9d9fc60d20c4835026017465b61c.zip
Making things into a set of three user-daemons.
Diffstat (limited to 'src/indicator-fusa.c')
-rw-r--r--src/indicator-fusa.c43
1 files changed, 39 insertions, 4 deletions
diff --git a/src/indicator-fusa.c b/src/indicator-fusa.c
index 8815fb5..4c1c163 100644
--- a/src/indicator-fusa.c
+++ b/src/indicator-fusa.c
@@ -7,14 +7,19 @@
#include <libindicator/indicator.h>
INDICATOR_SET_VERSION
-INDICATOR_SET_NAME("users-status-shutdown")
+INDICATOR_SET_NAME("users-status-session")
#include "dbus-shared-names.h"
+static GtkMenu * status_menu = NULL;
+static GtkMenu * users_menu = NULL;
+static GtkMenu * session_menu = NULL;
+static GtkMenu * main_menu = NULL;
+
GtkLabel *
get_label (void)
{
- GtkLabel * returnval = gtk_label_new("Ted Gould");
+ GtkLabel * returnval = GTK_LABEL(gtk_label_new("Ted Gould"));
return returnval;
}
@@ -33,7 +38,7 @@ get_menu (void)
DBusGConnection * connection = dbus_g_bus_get(DBUS_BUS_SESSION, NULL);
DBusGProxy * proxy = dbus_g_proxy_new_for_name(connection, DBUS_SERVICE_DBUS, DBUS_PATH_DBUS, DBUS_INTERFACE_DBUS);
- if (!org_freedesktop_DBus_start_service_by_name (proxy, INDICATOR_FUSA_DBUS_NAME, 0, &returnval, &error)) {
+ if (!org_freedesktop_DBus_start_service_by_name (proxy, INDICATOR_STATUS_DBUS_NAME, 0, &returnval, &error)) {
g_error("Unable to send message to DBus to start service: %s", error != NULL ? error->message : "(NULL error)" );
g_error_free(error);
return NULL;
@@ -44,7 +49,37 @@ get_menu (void)
return NULL;
}
- return GTK_MENU(dbusmenu_gtkmenu_new(INDICATOR_FUSA_DBUS_NAME, INDICATOR_FUSA_DBUS_OBJECT));
+ status_menu = GTK_MENU(dbusmenu_gtkmenu_new(INDICATOR_STATUS_DBUS_NAME, INDICATOR_STATUS_DBUS_OBJECT));
+
+ if (!org_freedesktop_DBus_start_service_by_name (proxy, INDICATOR_USERS_DBUS_NAME, 0, &returnval, &error)) {
+ g_error("Unable to send message to DBus to start service: %s", error != NULL ? error->message : "(NULL error)" );
+ g_error_free(error);
+ return NULL;
+ }
+
+ if (returnval != DBUS_START_REPLY_SUCCESS && returnval != DBUS_START_REPLY_ALREADY_RUNNING) {
+ g_error("Return value isn't indicative of success: %d", returnval);
+ return NULL;
+ }
+
+ users_menu = GTK_MENU(dbusmenu_gtkmenu_new(INDICATOR_USERS_DBUS_NAME, INDICATOR_USERS_DBUS_OBJECT));
+
+ if (!org_freedesktop_DBus_start_service_by_name (proxy, INDICATOR_SESSION_DBUS_NAME, 0, &returnval, &error)) {
+ g_error("Unable to send message to DBus to start service: %s", error != NULL ? error->message : "(NULL error)" );
+ g_error_free(error);
+ return NULL;
+ }
+
+ if (returnval != DBUS_START_REPLY_SUCCESS && returnval != DBUS_START_REPLY_ALREADY_RUNNING) {
+ g_error("Return value isn't indicative of success: %d", returnval);
+ return NULL;
+ }
+
+ session_menu = GTK_MENU(dbusmenu_gtkmenu_new(INDICATOR_SESSION_DBUS_NAME, INDICATOR_SESSION_DBUS_OBJECT));
+
+ main_menu = GTK_MENU(gtk_menu_new());
+
+ return main_menu;
}