mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 21:59:08 -05:00
services: gdm: Add Wayland support.
* gnu/packages/patches/gdm-wayland-session-wrapper-from-env.patch: New file. * gnu/local.mk (dist_patch_DATA): Add it. * gnu/packages/gnome.scm (gdm): Use it. * gnu/services/xorg.scm (<gdm-configuration>)[wayland-session]: New field. (gdm-wayland-session-wrapper): New procedure. (gdm-configuration-file): Point to this new procedure. * doc/guix.texi (X Window): Update it. Signed-off-by: Mathieu Othacehe <othacehe@gnu.org>
This commit is contained in:
parent
5c3f0c3e03
commit
db4681a4c1
5 changed files with 67 additions and 3 deletions
|
@ -18309,6 +18309,10 @@ The GDM package to use.
|
||||||
|
|
||||||
@item @code{wayland?} (default: @code{#f})
|
@item @code{wayland?} (default: @code{#f})
|
||||||
When true, enables Wayland in GDM, necessary to use Wayland sessions.
|
When true, enables Wayland in GDM, necessary to use Wayland sessions.
|
||||||
|
|
||||||
|
@item @code{wayland-session} (default: @code{gdm-wayland-session-wrapper})
|
||||||
|
The Wayland session wrapper to use, needed to setup the
|
||||||
|
environment.
|
||||||
@end table
|
@end table
|
||||||
@end deftp
|
@end deftp
|
||||||
|
|
||||||
|
|
|
@ -1102,6 +1102,7 @@ dist_patch_DATA = \
|
||||||
%D%/packages/patches/gdm-default-session.patch \
|
%D%/packages/patches/gdm-default-session.patch \
|
||||||
%D%/packages/patches/gdm-elogind-support.patch \
|
%D%/packages/patches/gdm-elogind-support.patch \
|
||||||
%D%/packages/patches/gdm-remove-hardcoded-xwayland-path.patch \
|
%D%/packages/patches/gdm-remove-hardcoded-xwayland-path.patch \
|
||||||
|
%D%/packages/patches/gdm-wayland-session-wrapper-from-env.patch \
|
||||||
%D%/packages/patches/geary-CVE-2020-24661.patch \
|
%D%/packages/patches/geary-CVE-2020-24661.patch \
|
||||||
%D%/packages/patches/genimage-signedness.patch \
|
%D%/packages/patches/genimage-signedness.patch \
|
||||||
%D%/packages/patches/geoclue-config.patch \
|
%D%/packages/patches/geoclue-config.patch \
|
||||||
|
|
|
@ -8150,7 +8150,8 @@ (define-public gdm
|
||||||
(search-patches
|
(search-patches
|
||||||
"gdm-default-session.patch"
|
"gdm-default-session.patch"
|
||||||
"gdm-elogind-support.patch"
|
"gdm-elogind-support.patch"
|
||||||
"gdm-remove-hardcoded-xwayland-path.patch"))))
|
"gdm-remove-hardcoded-xwayland-path.patch"
|
||||||
|
"gdm-wayland-session-wrapper-from-env.patch"))))
|
||||||
(build-system meson-build-system)
|
(build-system meson-build-system)
|
||||||
(arguments
|
(arguments
|
||||||
`(#:glib-or-gtk? #t
|
`(#:glib-or-gtk? #t
|
||||||
|
|
|
@ -0,0 +1,35 @@
|
||||||
|
Get wayland-session wrapper from environment.
|
||||||
|
|
||||||
|
---
|
||||||
|
daemon/gdm-session.c | 6 ++++--
|
||||||
|
1 file changed, 4 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/daemon/gdm-session.c b/daemon/gdm-session.c
|
||||||
|
index 4e303e70..1deca4e9 100644
|
||||||
|
--- a/daemon/gdm-session.c
|
||||||
|
+++ b/daemon/gdm-session.c
|
||||||
|
@@ -2888,8 +2888,9 @@ gdm_session_start_session (GdmSession *self,
|
||||||
|
allow_remote_connections? "--allow-remote-connections " : "",
|
||||||
|
command);
|
||||||
|
} else {
|
||||||
|
- program = g_strdup_printf (LIBEXECDIR "/gdm-wayland-session %s\"%s\"",
|
||||||
|
+ program = g_strdup_printf (LIBEXECDIR "/gdm-wayland-session %s\"%s %s\"",
|
||||||
|
register_session ? "--register-session " : "",
|
||||||
|
+ g_getenv ("GDM_WAYLAND_SESSION"),
|
||||||
|
command);
|
||||||
|
}
|
||||||
|
} else if (run_xsession_script) {
|
||||||
|
@@ -2906,8 +2907,9 @@ gdm_session_start_session (GdmSession *self,
|
||||||
|
register_session ? "--register-session " : "",
|
||||||
|
self->selected_program);
|
||||||
|
} else {
|
||||||
|
- program = g_strdup_printf (LIBEXECDIR "/gdm-wayland-session %s\"%s\"",
|
||||||
|
+ program = g_strdup_printf (LIBEXECDIR "/gdm-wayland-session %s\"%s %s\"",
|
||||||
|
register_session ? "--register-session " : "",
|
||||||
|
+ g_getenv ("GDM_WAYLAND_SESSION"),
|
||||||
|
self->selected_program);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
--
|
||||||
|
2.33.0
|
||||||
|
|
|
@ -870,6 +870,24 @@ (define profiles
|
||||||
(apply execl (string-append #$dbus "/bin/dbus-daemon")
|
(apply execl (string-append #$dbus "/bin/dbus-daemon")
|
||||||
(program-arguments)))))
|
(program-arguments)))))
|
||||||
|
|
||||||
|
;; Wrapper script for Wayland sessions, similar to Xsession.
|
||||||
|
;;
|
||||||
|
;; See `xinitrc`. By default, it launches the specified session through a
|
||||||
|
;; login shell. With the default Guix configuration, this should source
|
||||||
|
;; /etc/profile, setting up the Guix profile environment variables. However,
|
||||||
|
;; gdm launches its own graphical session through the same method, so we need
|
||||||
|
;; to ignore this case, since `gdm` doesn't have a login shell.
|
||||||
|
(define gdm-wayland-session-wrapper
|
||||||
|
(program-file
|
||||||
|
"gdm-wayland-session-wrapper"
|
||||||
|
#~((let* ((user (getpw (getuid)))
|
||||||
|
(name (passwd:name user))
|
||||||
|
(shell (passwd:shell user))
|
||||||
|
(args (cdr (command-line))))
|
||||||
|
(if (string=? name "gdm")
|
||||||
|
(apply execl (cons (car args) args))
|
||||||
|
(execl shell shell "--login" "-c" (string-join args)))))))
|
||||||
|
|
||||||
(define-record-type* <gdm-configuration>
|
(define-record-type* <gdm-configuration>
|
||||||
gdm-configuration make-gdm-configuration
|
gdm-configuration make-gdm-configuration
|
||||||
gdm-configuration?
|
gdm-configuration?
|
||||||
|
@ -885,7 +903,9 @@ (define-record-type* <gdm-configuration>
|
||||||
(default (xorg-configuration)))
|
(default (xorg-configuration)))
|
||||||
(x-session gdm-configuration-x-session
|
(x-session gdm-configuration-x-session
|
||||||
(default (xinitrc)))
|
(default (xinitrc)))
|
||||||
(wayland? gdm-configuration-wayland? (default #f)))
|
(wayland? gdm-configuration-wayland? (default #f))
|
||||||
|
(wayland-session gdm-configuration-wayland-session
|
||||||
|
(default gdm-wayland-session-wrapper)))
|
||||||
|
|
||||||
(define (gdm-configuration-file config)
|
(define (gdm-configuration-file config)
|
||||||
(mixed-text-file "gdm-custom.conf"
|
(mixed-text-file "gdm-custom.conf"
|
||||||
|
@ -983,7 +1003,10 @@ (define (gdm-shepherd-service config)
|
||||||
;; Add XCURSOR_PATH so that mutter can find its
|
;; Add XCURSOR_PATH so that mutter can find its
|
||||||
;; cursors. gdm doesn't login so doesn't source
|
;; cursors. gdm doesn't login so doesn't source
|
||||||
;; the corresponding line in /etc/profile.
|
;; the corresponding line in /etc/profile.
|
||||||
"XCURSOR_PATH=/run/current-system/profile/share/icons"))))
|
"XCURSOR_PATH=/run/current-system/profile/share/icons"
|
||||||
|
(string-append
|
||||||
|
"GDM_WAYLAND_SESSION="
|
||||||
|
#$(gdm-configuration-wayland-session config))))))
|
||||||
(stop #~(make-kill-destructor))
|
(stop #~(make-kill-destructor))
|
||||||
(respawn? #t))))
|
(respawn? #t))))
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue