]> rtime.felk.cvut.cz Git - sojka/lightdm.git/blobdiff - src/seat-unity.c
Launchpad automatic translations update.
[sojka/lightdm.git] / src / seat-unity.c
index 597512a7762380e4436e33f0c7cfc2c3a865f9c8..c9a5ad6b8f5dc17c9a6292f6a94cb57cb36ff827 100644 (file)
@@ -17,8 +17,7 @@
 #include "seat-unity.h"
 #include "configuration.h"
 #include "unity-system-compositor.h"
-#include "x-server-local.h"
-#include "mir-server.h"
+#include "x-server-xmir.h"
 #include "vt.h"
 #include "plymouth.h"
 
@@ -28,12 +27,10 @@ struct SeatUnityPrivate
     UnitySystemCompositor *compositor;
 
     /* X server being used for XDMCP */
-    XServerLocal *xdmcp_x_server;
+    XServerXmir *xdmcp_x_server;
 
-    /* Next Mir ID to use for a Mir sessions, X server and greeters */
-    gint next_session_id;
+    /* Next Mir ID to use for a Xmir servers */
     gint next_x_server_id;
-    gint next_greeter_id;
 
     /* The currently visible session */
     Session *active_session;
@@ -42,7 +39,7 @@ struct SeatUnityPrivate
 
 G_DEFINE_TYPE (SeatUnity, seat_unity, SEAT_TYPE);
 
-static XServerLocal *create_x_server (Seat *seat);
+static XServerXmir *create_x_server (Seat *seat);
 
 static void
 seat_unity_setup (Seat *seat)
@@ -89,10 +86,10 @@ compositor_ready_cb (UnitySystemCompositor *compositor, SeatUnity *seat)
         gint port = 0;
 
         seat->priv->xdmcp_x_server = create_x_server (SEAT (seat));
-        x_server_local_set_xdmcp_server (seat->priv->xdmcp_x_server, xdmcp_manager);
+        x_server_local_set_xdmcp_server (X_SERVER_LOCAL (seat->priv->xdmcp_x_server), xdmcp_manager);
         port = seat_get_integer_property (SEAT (seat), "xdmcp-port");
         if (port > 0)
-            x_server_local_set_xdmcp_port (seat->priv->xdmcp_x_server, port);
+            x_server_local_set_xdmcp_port (X_SERVER_LOCAL (seat->priv->xdmcp_x_server), port);
         key_name = seat_get_string_property (SEAT (seat), "xdmcp-key");
         if (key_name)
         {
@@ -119,7 +116,7 @@ compositor_ready_cb (UnitySystemCompositor *compositor, SeatUnity *seat)
                     l_debug (seat, "Key %s not defined", key_name);
 
                 if (key)
-                    x_server_local_set_xdmcp_key (seat->priv->xdmcp_x_server, key);
+                    x_server_local_set_xdmcp_key (X_SERVER_LOCAL (seat->priv->xdmcp_x_server), key);
                 g_free (key);
             }
 
@@ -190,54 +187,51 @@ seat_unity_start (Seat *seat)
     return display_server_start (DISPLAY_SERVER (SEAT_UNITY (seat)->priv->compositor));
 }
 
-static XServerLocal *
+static XServerXmir *
 create_x_server (Seat *seat)
 {
-    XServerLocal *x_server;
+    XServerXmir *x_server;
+    gchar *number;
+    XAuthority *cookie;
     const gchar *command = NULL, *layout = NULL, *config_file = NULL;
     gboolean allow_tcp;
     gchar *id;
 
     l_debug (seat, "Starting X server on Unity compositor");
 
-    x_server = x_server_local_new ();
+    x_server = x_server_xmir_new (SEAT_UNITY (seat)->priv->compositor);
 
     command = seat_get_string_property (seat, "xmir-command");
-    x_server_local_set_command (x_server, command);
+    x_server_local_set_command (X_SERVER_LOCAL (x_server), command);
 
     id = g_strdup_printf ("x-%d", SEAT_UNITY (seat)->priv->next_x_server_id);
     SEAT_UNITY (seat)->priv->next_x_server_id++;
-    x_server_local_set_mir_id (x_server, id);
-    x_server_local_set_mir_socket (x_server, unity_system_compositor_get_socket (SEAT_UNITY (seat)->priv->compositor));
+    x_server_xmir_set_mir_id (x_server, id);
+    x_server_xmir_set_mir_socket (x_server, unity_system_compositor_get_socket (SEAT_UNITY (seat)->priv->compositor));
     g_free (id);
 
+    number = g_strdup_printf ("%d", x_server_get_display_number (X_SERVER (x_server)));
+    cookie = x_authority_new_local_cookie (number);
+    x_server_set_authority (X_SERVER (x_server), cookie);
+    g_free (number);
+    g_object_unref (cookie);
+
     layout = seat_get_string_property (seat, "xserver-layout");
     if (layout)
-        x_server_local_set_layout (x_server, layout);
+        x_server_local_set_layout (X_SERVER_LOCAL (x_server), layout);
 
-    x_server_local_set_xdg_seat (x_server, seat_get_name (seat));
+    x_server_local_set_xdg_seat (X_SERVER_LOCAL (x_server), seat_get_name (seat));
 
     config_file = seat_get_string_property (seat, "xserver-config");
     if (config_file)
-        x_server_local_set_config (x_server, config_file);
+        x_server_local_set_config (X_SERVER_LOCAL (x_server), config_file);
 
     allow_tcp = seat_get_boolean_property (seat, "xserver-allow-tcp");
-    x_server_local_set_allow_tcp (x_server, allow_tcp);
+    x_server_local_set_allow_tcp (X_SERVER_LOCAL (x_server), allow_tcp);
 
     return x_server;
 }
 
-static DisplayServer *
-create_mir_server (Seat *seat)
-{
-    MirServer *mir_server;
-
-    mir_server = mir_server_new ();
-    mir_server_set_parent_socket (mir_server, unity_system_compositor_get_socket (SEAT_UNITY (seat)->priv->compositor));
-
-    return DISPLAY_SERVER (mir_server);
-}
-
 static DisplayServer *
 seat_unity_create_display_server (Seat *seat, Session *session)
 {
@@ -247,7 +241,7 @@ seat_unity_create_display_server (Seat *seat, Session *session)
     if (strcmp (session_type, "x") == 0)
         return DISPLAY_SERVER (create_x_server (seat));
     else if (strcmp (session_type, "mir") == 0)
-        return create_mir_server (seat);
+        return g_object_ref (SEAT_UNITY (seat)->priv->compositor);
     else
     {
         l_warning (seat, "Can't create unsupported display server '%s'", session_type);
@@ -255,21 +249,24 @@ seat_unity_create_display_server (Seat *seat, Session *session)
     }
 }
 
-static Greeter *
+static gboolean
+seat_unity_display_server_is_used (Seat *seat, DisplayServer *display_server)
+{
+    if (display_server == DISPLAY_SERVER (SEAT_UNITY (seat)->priv->compositor))
+        return TRUE;
+
+    return SEAT_CLASS (seat_unity_parent_class)->display_server_is_used (seat, display_server);
+}
+
+static GreeterSession *
 seat_unity_create_greeter_session (Seat *seat)
 {
-    Greeter *greeter_session;
-    gchar *id;
+    GreeterSession *greeter_session;
     gint vt;
 
     greeter_session = SEAT_CLASS (seat_unity_parent_class)->create_greeter_session (seat);
     session_set_env (SESSION (greeter_session), "XDG_SEAT", seat_get_name (seat));
 
-    id = g_strdup_printf ("greeter-%d", SEAT_UNITY (seat)->priv->next_greeter_id);
-    SEAT_UNITY (seat)->priv->next_greeter_id++;
-    session_set_env (SESSION (greeter_session), "MIR_SERVER_NAME", id);
-    g_free (id);
-
     vt = display_server_get_vt (DISPLAY_SERVER (SEAT_UNITY (seat)->priv->compositor));
     if (vt >= 0)
     {
@@ -285,17 +282,11 @@ static Session *
 seat_unity_create_session (Seat *seat)
 {
     Session *session;
-    gchar *id;
     gint vt;
 
     session = SEAT_CLASS (seat_unity_parent_class)->create_session (seat);
     session_set_env (session, "XDG_SEAT", seat_get_name (seat));
 
-    id = g_strdup_printf ("session-%d", SEAT_UNITY (seat)->priv->next_session_id);
-    SEAT_UNITY (seat)->priv->next_session_id++;
-    session_set_env (session, "MIR_SERVER_NAME", id);
-    g_free (id);
-
     vt = display_server_get_vt (DISPLAY_SERVER (SEAT_UNITY (seat)->priv->compositor));
     if (vt >= 0)
     {
@@ -307,37 +298,39 @@ seat_unity_create_session (Seat *seat)
     return session;
 }
 
-static void
-seat_unity_set_active_session (Seat *seat, Session *session)
+static const gchar *
+get_mir_id (Session *session)
 {
     DisplayServer *display_server;
 
-    if (session == SEAT_UNITY (seat)->priv->active_session)
-        return;
-    SEAT_UNITY (seat)->priv->active_session = g_object_ref (session);
+    if (!session)
+        return NULL;
 
-    display_server = session_get_display_server (session);
-    if (SEAT_UNITY (seat)->priv->active_display_server != display_server)
-    {
-        const gchar *id = NULL;
+    display_server = session_get_display_server (session);  
+    if (IS_UNITY_SYSTEM_COMPOSITOR (display_server))
+        return session_get_env (session, "MIR_SERVER_NAME");
+    if (IS_X_SERVER_XMIR (display_server))
+        return x_server_xmir_get_mir_id (X_SERVER_XMIR (display_server));
 
-        SEAT_UNITY (seat)->priv->active_display_server = g_object_ref (display_server);
+    return NULL;
+}
 
-        if (IS_X_SERVER_LOCAL (display_server))
-            id = x_server_local_get_mir_id (X_SERVER_LOCAL (display_server));
-        else
-            id = session_get_env (session, "MIR_SERVER_NAME");
+static void
+seat_unity_set_active_session (Seat *s, Session *session)
+{
+    SeatUnity *seat = SEAT_UNITY (s);
+    const gchar *old_id, *new_id;
 
-        if (id)
-        {
-            l_debug (seat, "Switching to Mir session %s", id);
-            unity_system_compositor_set_active_session (SEAT_UNITY (seat)->priv->compositor, id);
-        }
-        else
-            l_warning (seat, "Failed to work out session ID");
-    }
+    old_id = get_mir_id (seat->priv->active_session);
+    new_id = get_mir_id (session);
 
-    SEAT_CLASS (seat_unity_parent_class)->set_active_session (seat, session);
+    g_clear_object (&seat->priv->active_session);
+    seat->priv->active_session = g_object_ref (session);
+
+    if (g_strcmp0 (old_id, new_id) != 0)
+        unity_system_compositor_set_active_session (seat->priv->compositor, new_id);
+
+    SEAT_CLASS (seat_unity_parent_class)->set_active_session (s, session);
 }
 
 static Session *
@@ -358,7 +351,7 @@ seat_unity_set_next_session (Seat *seat, Session *session)
     display_server = session_get_display_server (session);
 
     if (IS_X_SERVER_LOCAL (display_server))
-        id = x_server_local_get_mir_id (X_SERVER_LOCAL (display_server));
+        id = x_server_xmir_get_mir_id (X_SERVER_XMIR (display_server));
     else
         id = session_get_env (session, "MIR_SERVER_NAME");
 
@@ -378,13 +371,13 @@ seat_unity_set_next_session (Seat *seat, Session *session)
 static void
 seat_unity_run_script (Seat *seat, DisplayServer *display_server, Process *script)
 {
-    if (IS_X_SERVER_LOCAL (display_server))
+    if (IS_X_SERVER_XMIR (display_server))
     {
-        XServerLocal *x_server;
+        XServerXmir *x_server;
         const gchar *path;
 
-        x_server = X_SERVER_LOCAL (display_server);
-        path = x_server_local_get_authority_file_path (x_server);
+        x_server = X_SERVER_XMIR (display_server);
+        path = x_server_local_get_authority_file_path (X_SERVER_LOCAL (x_server));
         process_set_env (script, "DISPLAY", x_server_get_address (X_SERVER (x_server)));
         process_set_env (script, "XAUTHORITY", path);
     }
@@ -439,6 +432,7 @@ seat_unity_class_init (SeatUnityClass *klass)
     seat_class->setup = seat_unity_setup;
     seat_class->start = seat_unity_start;
     seat_class->create_display_server = seat_unity_create_display_server;
+    seat_class->display_server_is_used = seat_unity_display_server_is_used;
     seat_class->create_greeter_session = seat_unity_create_greeter_session;
     seat_class->create_session = seat_unity_create_session;
     seat_class->set_active_session = seat_unity_set_active_session;