[gdm] Move seat stuff into its own structure
- From: Ray Strode <halfline src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gdm] Move seat stuff into its own structure
- Date: Tue, 17 Aug 2010 19:06:33 +0000 (UTC)
commit 023e9f40ea52ebb47cd3aa7985500fbdd283d294
Author: Ray Strode <rstrode redhat com>
Date: Thu Jun 24 02:54:18 2010 -0400
Move seat stuff into its own structure
The user manager has a few bits of data that are
tied to the current seat. For clarity, move it
to its own structure.
https://bugzilla.gnome.org/show_bug.cgi?id=622639
(cherry picked from commit 6379bd161eb7806c3e3815d74aa7166ebf78ab5b)
gui/simple-greeter/gdm-user-manager.c | 56 +++++++++++++++++++--------------
1 files changed, 32 insertions(+), 24 deletions(-)
---
diff --git a/gui/simple-greeter/gdm-user-manager.c b/gui/simple-greeter/gdm-user-manager.c
index ce65804..65bcfd0 100644
--- a/gui/simple-greeter/gdm-user-manager.c
+++ b/gui/simple-greeter/gdm-user-manager.c
@@ -84,6 +84,14 @@
#define ACCOUNTS_PATH "/org/freedesktop/Accounts"
#define ACCOUNTS_INTERFACE "org.freedesktop.Accounts"
+typedef struct
+{
+ char *id;
+ char *session_id;
+
+ DBusGProxy *proxy;
+} GdmUserManagerSeat;
+
struct GdmUserManagerPrivate
{
GHashTable *users_by_name;
@@ -91,10 +99,10 @@ struct GdmUserManagerPrivate
GHashTable *sessions;
GHashTable *shells;
DBusGConnection *connection;
- DBusGProxy *seat_proxy;
DBusGProxyCall *get_sessions_call;
DBusGProxy *accounts_proxy;
- char *seat_id;
+
+ GdmUserManagerSeat seat;
GFileMonitor *passwd_monitor;
GFileMonitor *shells_monitor;
@@ -292,7 +300,7 @@ _get_login_window_session_id (GdmUserManager *manager)
char *primary_ssid;
int i;
- if (manager->priv->seat_id == NULL || manager->priv->seat_id[0] == '\0') {
+ if (manager->priv->seat.id == NULL || manager->priv->seat.id[0] == '\0') {
g_debug ("GdmUserManager: display seat ID is not set; can't switch sessions");
return NULL;
}
@@ -308,7 +316,7 @@ _get_login_window_session_id (GdmUserManager *manager)
}
error = NULL;
- res = dbus_g_proxy_call (manager->priv->seat_proxy,
+ res = dbus_g_proxy_call (manager->priv->seat.proxy,
"GetSessions",
&error,
G_TYPE_INVALID,
@@ -359,7 +367,7 @@ gdm_user_manager_goto_login_session (GdmUserManager *manager)
ssid = _get_login_window_session_id (manager);
if (ssid != NULL) {
- res = activate_session_id (manager, manager->priv->seat_id, ssid);
+ res = activate_session_id (manager, manager->priv->seat.id, ssid);
if (res) {
ret = TRUE;
}
@@ -382,7 +390,7 @@ gdm_user_manager_can_switch (GdmUserManager *manager)
gboolean can_activate_sessions;
GError *error;
- if (manager->priv->seat_id == NULL || manager->priv->seat_id[0] == '\0') {
+ if (manager->priv->seat.id == NULL || manager->priv->seat.id[0] == '\0') {
g_debug ("GdmUserManager: display seat ID is not set; can't switch sessions");
return FALSE;
}
@@ -390,7 +398,7 @@ gdm_user_manager_can_switch (GdmUserManager *manager)
g_debug ("GdmUserManager: checking if seat can activate sessions");
error = NULL;
- res = dbus_g_proxy_call (manager->priv->seat_proxy,
+ res = dbus_g_proxy_call (manager->priv->seat.proxy,
"CanActivateSessions",
&error,
G_TYPE_INVALID,
@@ -436,7 +444,7 @@ gdm_user_manager_activate_user_session (GdmUserManager *manager,
goto out;
}
- res = activate_session_id (manager, manager->priv->seat_id, ssid);
+ res = activate_session_id (manager, manager->priv->seat.id, ssid);
if (! res) {
g_debug ("GdmUserManager: unable to activate session: %s", ssid);
goto out;
@@ -1035,7 +1043,7 @@ on_seat_proxy_destroy (DBusGProxy *proxy,
{
g_debug ("GdmUserManager: seat proxy destroyed");
- manager->priv->seat_proxy = NULL;
+ manager->priv->seat.proxy = NULL;
}
static void
@@ -1044,19 +1052,19 @@ get_seat_proxy (GdmUserManager *manager)
DBusGProxy *proxy;
GError *error;
- g_assert (manager->priv->seat_proxy == NULL);
+ g_assert (manager->priv->seat.proxy == NULL);
- manager->priv->seat_id = get_current_seat_id (manager->priv->connection);
- if (manager->priv->seat_id == NULL) {
+ manager->priv->seat.id = get_current_seat_id (manager->priv->connection);
+ if (manager->priv->seat.id == NULL) {
return;
}
- g_debug ("GdmUserManager: Found current seat: %s", manager->priv->seat_id);
+ g_debug ("GdmUserManager: Found current seat: %s", manager->priv->seat.id);
error = NULL;
proxy = dbus_g_proxy_new_for_name_owner (manager->priv->connection,
CK_NAME,
- manager->priv->seat_id,
+ manager->priv->seat.id,
CK_SEAT_INTERFACE,
&error);
@@ -1091,7 +1099,7 @@ get_seat_proxy (GdmUserManager *manager)
G_CALLBACK (seat_session_removed),
manager,
NULL);
- manager->priv->seat_proxy = proxy;
+ manager->priv->seat.proxy = proxy;
}
@@ -1479,10 +1487,10 @@ load_ck_history (GdmUserManager *manager)
command = NULL;
seat_id = NULL;
- if (manager->priv->seat_id != NULL
- && g_str_has_prefix (manager->priv->seat_id, "/org/freedesktop/ConsoleKit/")) {
+ if (manager->priv->seat.id != NULL
+ && g_str_has_prefix (manager->priv->seat.id, "/org/freedesktop/ConsoleKit/")) {
- seat_id = manager->priv->seat_id + strlen ("/org/freedesktop/ConsoleKit/");
+ seat_id = manager->priv->seat.id + strlen ("/org/freedesktop/ConsoleKit/");
}
if (seat_id == NULL) {
@@ -1906,12 +1914,12 @@ load_sessions (GdmUserManager *manager)
{
DBusGProxyCall *call;
- if (manager->priv->seat_proxy == NULL) {
+ if (manager->priv->seat.proxy == NULL) {
g_debug ("GdmUserManager: no seat proxy; can't load sessions");
return;
}
- call = dbus_g_proxy_begin_call (manager->priv->seat_proxy,
+ call = dbus_g_proxy_begin_call (manager->priv->seat.proxy,
"GetSessions",
on_get_sessions_finished,
manager,
@@ -2301,7 +2309,7 @@ gdm_user_manager_init (GdmUserManager *manager)
NULL,
g_object_unref);
- g_assert (manager->priv->seat_proxy == NULL);
+ g_assert (manager->priv->seat.proxy == NULL);
error = NULL;
manager->priv->connection = dbus_g_bus_get (DBUS_BUS_SYSTEM, &error);
@@ -2346,8 +2354,8 @@ gdm_user_manager_finalize (GObject *object)
g_slist_free (manager->priv->include_usernames);
}
- if (manager->priv->seat_proxy != NULL) {
- g_object_unref (manager->priv->seat_proxy);
+ if (manager->priv->seat.proxy != NULL) {
+ g_object_unref (manager->priv->seat.proxy);
}
if (manager->priv->accounts_proxy != NULL) {
@@ -2388,7 +2396,7 @@ gdm_user_manager_finalize (GObject *object)
}
g_hash_table_destroy (manager->priv->shells);
- g_free (manager->priv->seat_id);
+ g_free (manager->priv->seat.id);
G_OBJECT_CLASS (gdm_user_manager_parent_class)->finalize (object);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]