aboutsummaryrefslogtreecommitdiff
path: root/src/session-service.c
diff options
context:
space:
mode:
authorTed Gould <ted@gould.cx>2010-03-03 20:54:37 -0600
committerTed Gould <ted@gould.cx>2010-03-03 20:54:37 -0600
commit3be37d1ba50935f68435083548609a055f1f5751 (patch)
treef004bda94d04fe98171f2ae3a85967cc20bc638e /src/session-service.c
parenta6d04fe9a6dbd6c4b9b119686523962bf9147a8b (diff)
parent03c045f5890162a53ed613fcf8f627f0dc3badc8 (diff)
downloadayatana-indicator-session-3be37d1ba50935f68435083548609a055f1f5751.tar.gz
ayatana-indicator-session-3be37d1ba50935f68435083548609a055f1f5751.tar.bz2
ayatana-indicator-session-3be37d1ba50935f68435083548609a055f1f5751.zip
Sorting based on real names and conflict naming.
Diffstat (limited to 'src/session-service.c')
-rw-r--r--src/session-service.c16
1 files changed, 15 insertions, 1 deletions
diff --git a/src/session-service.c b/src/session-service.c
index 289bff8..85874b6 100644
--- a/src/session-service.c
+++ b/src/session-service.c
@@ -406,7 +406,15 @@ compare_users_by_username (const gchar *a,
UserData *user1 = (UserData *)a;
UserData *user2 = (UserData *)b;
- return g_strcmp0 (user1->user_name, user2->user_name);
+ gint retval = g_strcmp0 (user1->real_name, user2->real_name);
+
+ /* If they're the same, they're both in conflict. */
+ if (retval == 0) {
+ user1->real_name_conflict = TRUE;
+ user2->real_name_conflict = TRUE;
+ }
+
+ return retval;
}
/* Builds up the menu for us */
@@ -498,7 +506,13 @@ rebuild_items (DbusmenuMenuitem *root,
mi = dbusmenu_menuitem_new ();
dbusmenu_menuitem_property_set (mi, DBUSMENU_MENUITEM_PROP_TYPE, USER_ITEM_TYPE);
+ if (user->real_name_conflict) {
+ gchar * conflictedname = g_strdup_printf("%s (%s)", user->real_name, user->user_name);
+ dbusmenu_menuitem_property_set (mi, USER_ITEM_PROP_NAME, conflictedname);
+ g_free(conflictedname);
+ } else {
dbusmenu_menuitem_property_set (mi, USER_ITEM_PROP_NAME, user->real_name);
+ }
dbusmenu_menuitem_property_set_bool (mi, USER_ITEM_PROP_LOGGED_IN, user->sessions != NULL);
dbusmenu_menuitem_child_append (root, mi);
g_signal_connect (G_OBJECT (mi), DBUSMENU_MENUITEM_SIGNAL_ITEM_ACTIVATED, G_CALLBACK (activate_user_session), user);