services: xorg: Rewrite using gexps.
* gnu/services/xorg.scm (xorg-start-command): Rewrite in terms of 'gexp->script'. (xinitrc): Likewise.
This commit is contained in:
parent
f6a7b21df7
commit
8779d34294
|
@ -87,77 +87,42 @@ Section \"Screen\"
|
||||||
Device \"Device-vesa\"
|
Device \"Device-vesa\"
|
||||||
EndSection"))
|
EndSection"))
|
||||||
|
|
||||||
(mlet %store-monad ((guile-bin (package-file guile "bin/guile"))
|
(mlet %store-monad ((config (xserver.conf)))
|
||||||
(xorg-bin (package-file xorg-server "bin/X"))
|
(define script
|
||||||
(dri (package-file mesa "lib/dri"))
|
|
||||||
(xkbcomp-bin (package-file xkbcomp "bin"))
|
|
||||||
(xkb-dir (package-file xkeyboard-config
|
|
||||||
"share/X11/xkb"))
|
|
||||||
(config (xserver.conf)))
|
|
||||||
(define builder
|
|
||||||
;; Write a small wrapper around the X server.
|
;; Write a small wrapper around the X server.
|
||||||
`(let ((out (assoc-ref %outputs "out")))
|
#~(begin
|
||||||
(call-with-output-file out
|
(setenv "XORG_DRI_DRIVER_PATH" (string-append #$mesa "/lib/dri"))
|
||||||
(lambda (port)
|
(setenv "XKB_BINDIR" (string-append #$xkbcomp "/bin"))
|
||||||
(format port "#!~a --no-auto-compile~%!#~%" ,guile-bin)
|
|
||||||
(write '(begin
|
|
||||||
(setenv "XORG_DRI_DRIVER_PATH" ,dri)
|
|
||||||
(setenv "XKB_BINDIR" ,xkbcomp-bin)
|
|
||||||
|
|
||||||
(apply execl
|
(apply execl (string-append #$xorg-server "/bin/X")
|
||||||
|
"-ac" "-logverbose" "-verbose"
|
||||||
,xorg-bin "-ac" "-logverbose" "-verbose"
|
"-xkbdir" (string-append #$xkeyboard-config "/share/X11/xkb")
|
||||||
"-xkbdir" ,xkb-dir
|
"-config" #$config
|
||||||
"-config" ,(derivation->output-path config)
|
|
||||||
"-nolisten" "tcp" "-terminate"
|
"-nolisten" "tcp" "-terminate"
|
||||||
|
|
||||||
;; Note: SLiM and other display managers add the
|
;; Note: SLiM and other display managers add the
|
||||||
;; '-auth' flag by themselves.
|
;; '-auth' flag by themselves.
|
||||||
(cdr (command-line))))
|
(cdr (command-line)))))
|
||||||
port)))
|
|
||||||
(chmod out #o555)
|
|
||||||
#t))
|
|
||||||
|
|
||||||
(mlet %store-monad ((inputs (lower-inputs
|
(gexp->script "start-xorg" script)))
|
||||||
`(("xorg" ,xorg-server)
|
|
||||||
("xkbcomp" ,xkbcomp)
|
|
||||||
("xkeyboard-config" ,xkeyboard-config)
|
|
||||||
("mesa" ,mesa)
|
|
||||||
("guile" ,guile)
|
|
||||||
("xorg.conf" ,config)))))
|
|
||||||
(derivation-expression "start-xorg" builder
|
|
||||||
#:inputs inputs))))
|
|
||||||
|
|
||||||
(define* (xinitrc #:key
|
(define* (xinitrc #:key
|
||||||
(guile guile-final)
|
(guile guile-final)
|
||||||
(ratpoison ratpoison)
|
(ratpoison ratpoison)
|
||||||
(windowmaker windowmaker))
|
(windowmaker windowmaker))
|
||||||
"Return a system-wide xinitrc script that starts the specified X session."
|
"Return a system-wide xinitrc script that starts the specified X session."
|
||||||
(mlet %store-monad ((guile-bin (package-file guile "bin/guile"))
|
|
||||||
(ratpoison-bin (package-file ratpoison "bin/ratpoison"))
|
|
||||||
(wmaker-bin (package-file windowmaker "bin/wmaker"))
|
|
||||||
(inputs (lower-inputs
|
|
||||||
`(("raptoison" ,ratpoison)
|
|
||||||
("wmaker" ,windowmaker)))))
|
|
||||||
(define builder
|
(define builder
|
||||||
`(let ((out (assoc-ref %outputs "out")))
|
#~(begin
|
||||||
(call-with-output-file out
|
|
||||||
(lambda (port)
|
|
||||||
(format port "#!~a --no-auto-compile~%!#~%" ,guile-bin)
|
|
||||||
(write '(begin
|
|
||||||
(use-modules (ice-9 match))
|
(use-modules (ice-9 match))
|
||||||
|
|
||||||
;; TODO: Check for ~/.xsession.
|
;; TODO: Check for ~/.xsession.
|
||||||
(match (command-line)
|
(match (command-line)
|
||||||
((_ "ratpoison")
|
((_ "ratpoison")
|
||||||
(execl ,ratpoison-bin))
|
(execl (string-append #$ratpoison "/bin/ratpoison")))
|
||||||
(_
|
(_
|
||||||
(execl ,wmaker-bin))))
|
(execl (string-append #$windowmaker "/bin/wmaker"))))))
|
||||||
port)))
|
|
||||||
(chmod out #o555)
|
|
||||||
#t))
|
|
||||||
|
|
||||||
(derivation-expression "xinitrc" builder #:inputs inputs)))
|
(gexp->script "xinitrc" builder))
|
||||||
|
|
||||||
(define* (slim-service #:key (slim slim)
|
(define* (slim-service #:key (slim slim)
|
||||||
(allow-empty-passwords? #t) auto-login?
|
(allow-empty-passwords? #t) auto-login?
|
||||||
|
|
Loading…
Reference in New Issue