d0f3a672dc
* configure.ac: Require that guile-newt is available. * gnu/installer.scm: New file. * gnu/installer/aux-files/logo.txt: New file. * gnu/installer/build-installer.scm: New file. * gnu/installer/connman.scm: New file. * gnu/installer/keymap.scm: New file. * gnu/installer/locale.scm: New file. * gnu/installer/newt.scm: New file. * gnu/installer/newt/ethernet.scm: New file. * gnu/installer/newt/hostname.scm: New file. * gnu/installer/newt/keymap.scm: New file. * gnu/installer/newt/locale.scm: New file. * gnu/installer/newt/menu.scm: New file. * gnu/installer/newt/network.scm: New file. * gnu/installer/newt/page.scm: New file. * gnu/installer/newt/timezone.scm: New file. * gnu/installer/newt/user.scm: New file. * gnu/installer/newt/utils.scm: New file. * gnu/installer/newt/welcome.scm: New file. * gnu/installer/newt/wifi.scm: New file. * gnu/installer/steps.scm: New file. * gnu/installer/timezone.scm: New file. * gnu/installer/utils.scm: New file. * gnu/local.mk (GNU_SYSTEM_MODULES): Add previous files. * gnu/system.scm: Export %root-account. * gnu/system/install.scm (%installation-services): Use kmscon instead of linux VT for all tty. (installation-os)[users]: Add the graphical installer as shell of the root account. [packages]: Add font related packages. * po/guix/POTFILES.in: Add installer files.
112 lines
3.6 KiB
Scheme
112 lines
3.6 KiB
Scheme
;;; 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)
|
||
#:use-module (guix discovery)
|
||
#:use-module (guix records)
|
||
#:use-module (guix ui)
|
||
#:use-module (srfi srfi-1)
|
||
#:export (<installer>
|
||
installer
|
||
make-installer
|
||
installer?
|
||
installer-name
|
||
installer-modules
|
||
installer-init
|
||
installer-exit
|
||
installer-exit-error
|
||
installer-keymap-page
|
||
installer-locale-page
|
||
installer-menu-page
|
||
installer-network-page
|
||
installer-timezone-page
|
||
installer-hostname-page
|
||
installer-user-page
|
||
installer-welcome-page
|
||
|
||
%installers
|
||
lookup-installer-by-name))
|
||
|
||
|
||
;;;
|
||
;;; Installer record.
|
||
;;;
|
||
|
||
;; The <installer> record contains pages that will be run to prompt the user
|
||
;; for the system configuration. The goal of the installer is to produce a
|
||
;; complete <operating-system> record and install it.
|
||
|
||
(define-record-type* <installer>
|
||
installer make-installer
|
||
installer?
|
||
;; symbol
|
||
(name installer-name)
|
||
;; list of installer modules
|
||
(modules installer-modules)
|
||
;; procedure: void -> void
|
||
(init installer-init)
|
||
;; procedure: void -> void
|
||
(exit installer-exit)
|
||
;; procedure (key arguments) -> void
|
||
(exit-error installer-exit-error)
|
||
;; procedure (#:key models layouts) -> (list model layout variant)
|
||
(keymap-page installer-keymap-page)
|
||
;; procedure: (#:key supported-locales iso639-languages iso3166-territories)
|
||
;; -> glibc-locale
|
||
(locale-page installer-locale-page)
|
||
;; procedure: (steps) -> step-id
|
||
(menu-page installer-menu-page)
|
||
;; procedure void -> void
|
||
(network-page installer-network-page)
|
||
;; procedure (zonetab) -> posix-timezone
|
||
(timezone-page installer-timezone-page)
|
||
;; procedure void -> void
|
||
(hostname-page installer-hostname-page)
|
||
;; procedure void -> void
|
||
(user-page installer-user-page)
|
||
;; procedure (logo) -> void
|
||
(welcome-page installer-welcome-page))
|
||
|
||
|
||
;;;
|
||
;;; Installers.
|
||
;;;
|
||
|
||
(define (installer-top-modules)
|
||
"Return the list of installer modules."
|
||
(all-modules (map (lambda (entry)
|
||
`(,entry . "gnu/installer"))
|
||
%load-path)
|
||
#:warn warn-about-load-error))
|
||
|
||
(define %installers
|
||
;; The list of publically-known installers.
|
||
(delay (fold-module-public-variables (lambda (obj result)
|
||
(if (installer? obj)
|
||
(cons obj result)
|
||
result))
|
||
'()
|
||
(installer-top-modules))))
|
||
|
||
(define (lookup-installer-by-name name)
|
||
"Return the installer called NAME."
|
||
(or (find (lambda (installer)
|
||
(eq? name (installer-name installer)))
|
||
(force %installers))
|
||
(leave (G_ "~a: no such installer~%") name)))
|