summary refs log tree commit diff
path: root/gnu/installer/services.scm
blob: 2b6625f6af8a30abbd2d6a9557243c74c4477738 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2018 Mathieu Othacehe <m.othacehe@gmail.com>
;;;
;;; This file is part of GNU Guix.
;;;
;;; GNU Guix is free software; you can redistribute it and/or modify it
;;; under the terms of the GNU General Public License as published by
;;; the Free Software Foundation; either version 3 of the License, or (at
;;; your option) any later version.
;;;
;;; GNU Guix is distributed in the hope that it will be useful, but
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
;;; GNU General Public License for more details.
;;;
;;; You should have received a copy of the GNU General Public License
;;; along with GNU Guix.  If not, see <http://www.gnu.org/licenses/>.

(define-module (gnu installer services)
  #:use-module (guix records)
  #:export (<desktop-environment>
            desktop-environment
            make-desktop-environment
            desktop-environment-name
            desktop-environment-snippet

            %desktop-environments
            desktop-environments->configuration))

(define-record-type* <desktop-environment>
  desktop-environment make-desktop-environment
  desktop-environment?
  (name            desktop-environment-name) ;string
  (snippet         desktop-environment-snippet)) ;symbol

;; This is the list of desktop environments supported as services.
(define %desktop-environments
  (list
   (desktop-environment
    (name "GNOME")
    (snippet '(service gnome-desktop-service-type)))
   (desktop-environment
    (name "Xfce")
    ;; TODO: Use 'xfce-desktop-service-type' when the 'guix' package provides
    ;; it with a default value.
    (snippet '(xfce-desktop-service)))
   (desktop-environment
    (name "MATE")
    (snippet '(service mate-desktop-service-type)))
   (desktop-environment
    (name "Enlightenment")
    (snippet '(service enlightenment-desktop-service-type)))))

(define (desktop-environments->configuration desktop-environments)
  "Return the configuration field for DESKTOP-ENVIRONMENTS."
  (let ((snippets
         (map desktop-environment-snippet desktop-environments)))
    `(,@(if (null? snippets)
            '()
            `((services (cons* ,@snippets
                               %desktop-services)))))))