[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
05/10: installer: Desktop environment page now includes window managers.
From: |
guix-commits |
Subject: |
05/10: installer: Desktop environment page now includes window managers. |
Date: |
Wed, 17 Apr 2019 05:54:08 -0400 (EDT) |
civodul pushed a commit to branch master
in repository guix.
commit 3ad3c55842dd34adc4b1a1b65ba0abfbdf5b92ee
Author: Ludovic Courtès <address@hidden>
Date: Wed Apr 17 00:27:04 2019 +0200
installer: Desktop environment page now includes window managers.
* gnu/installer/services.scm (<system-service>)[snippet]: Change to be a
list of sexps and add default value.
[packages]: New field.
(%system-services): Adjust 'snippet' fields to be lists of sexps.
Add Openbox, awesome, i3, and ratpoison.
(system-services->configuration): Adjust 'snippet' handling. Honor
'packages' field.
---
gnu/installer/services.scm | 51 ++++++++++++++++++++++++++++++----------------
1 file changed, 33 insertions(+), 18 deletions(-)
diff --git a/gnu/installer/services.scm b/gnu/installer/services.scm
index 4dbfe74..6d9d65e 100644
--- a/gnu/installer/services.scm
+++ b/gnu/installer/services.scm
@@ -20,7 +20,6 @@
(define-module (gnu installer services)
#:use-module (guix records)
#:use-module (srfi srfi-1)
- #:use-module (ice-9 match)
#:export (system-service?
system-service-name
system-service-type
@@ -37,7 +36,10 @@
system-service?
(name system-service-name) ;string
(type system-service-type) ;'desktop | 'networking
- (snippet system-service-snippet)) ;sexp
+ (snippet system-service-snippet ;list of sexps
+ (default '()))
+ (packages system-service-packages ;list of sexps
+ (default '())))
;; This is the list of desktop environments supported as services.
(define %system-services
@@ -51,26 +53,38 @@
(list
(desktop-environment
(name "GNOME")
- (snippet '(service gnome-desktop-service-type)))
+ (snippet '((service gnome-desktop-service-type))))
(desktop-environment
(name "Xfce")
- (snippet '(service xfce-desktop-service-type)))
+ (snippet '((service xfce-desktop-service-type))))
(desktop-environment
(name "MATE")
- (snippet '(service mate-desktop-service-type)))
+ (snippet '((service mate-desktop-service-type))))
(desktop-environment
(name "Enlightenment")
- (snippet '(service enlightenment-desktop-service-type)))
+ (snippet '((service enlightenment-desktop-service-type))))
+ (desktop-environment
+ (name "Openbox")
+ (packages '((specification->package "openbox"))))
+ (desktop-environment
+ (name "awesome")
+ (packages '((specification->package "awesome"))))
+ (desktop-environment
+ (name "i3")
+ (packages '((specification->package "i3-wm"))))
+ (desktop-environment
+ (name "ratpoison")
+ (packages '((specification->package "ratpoison"))))
;; Networking.
(system-service
(name (G_ "OpenSSH secure shell daemon (sshd)"))
(type 'networking)
- (snippet '(service openssh-service-type)))
+ (snippet '((service openssh-service-type))))
(system-service
(name (G_ "Tor anonymous network router"))
(type 'networking)
- (snippet '(service tor-service-type)))
+ (snippet '((service tor-service-type))))
;; Network connectivity management.
(system-service
@@ -86,7 +100,7 @@
(system-service
(name (G_ "DHCP client (dynamic IP address assignment)"))
(type 'network-management)
- (snippet '(service dhcp-client-service-type))))))
+ (snippet '((service dhcp-client-service-type)))))))
(define (desktop-system-service? service)
"Return true if SERVICE is a desktop environment service."
@@ -98,20 +112,21 @@
(define (system-services->configuration services)
"Return the configuration field for SERVICES."
- (let* ((snippets (append-map (lambda (service)
- (match (system-service-snippet service)
- ((and lst (('service _ ...) ...))
- lst)
- (sexp
- (list sexp))))
- services))
+ (let* ((snippets (append-map system-service-snippet services))
+ (packages (append-map system-service-packages services))
(desktop? (find desktop-system-service? services))
(base (if desktop?
'%desktop-services
'%base-services)))
(if (null? snippets)
- `((services ,base))
- `((services (append (list ,@snippets
+ `(,@(if (null? packages)
+ '()
+ `((packages (list ,@packages))))
+ (services ,base))
+ `(,@(if (null? packages)
+ '()
+ `((packages (list ,@packages))))
+ (services (append (list ,@snippets
,@(if desktop?
;; XXX: Assume 'keyboard-layout' is in
- branch master updated (0682f08 -> 1475582), guix-commits, 2019/04/17
- 01/10: gnu: awesome: Update home page., guix-commits, 2019/04/17
- 02/10: self: Remove unused variable., guix-commits, 2019/04/17
- 04/10: gnu: guix: Don't pass '--with-libgcrypt-prefix'., guix-commits, 2019/04/17
- 06/10: gnu: guix: Update to b8b1e4d., guix-commits, 2019/04/17
- 07/10: installer: Change language as soon as it has been chosen., guix-commits, 2019/04/17
- 09/10: installer: Look up timezone name translations in "iso_3166-1"., guix-commits, 2019/04/17
- 08/10: installer: Display language and territory names natively., guix-commits, 2019/04/17
- 10/10: installer: Sort items with 'string-locale<?'., guix-commits, 2019/04/17
- 03/10: build: No longer substitute 'LIBGCRYPT'., guix-commits, 2019/04/17
- 05/10: installer: Desktop environment page now includes window managers.,
guix-commits <=