[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[bug#33405] [PATCH 10/10] guix system: Clarify 'perform-action'.
From: |
Ludovic Courtès |
Subject: |
[bug#33405] [PATCH 10/10] guix system: Clarify 'perform-action'. |
Date: |
Fri, 16 Nov 2018 10:36:24 +0100 |
* guix/scripts/system.scm (perform-action): Move non-monadic local
variables outside the 'mlet' form.
---
guix/scripts/system.scm | 42 +++++++++++++++++++++--------------------
1 file changed, 22 insertions(+), 20 deletions(-)
diff --git a/guix/scripts/system.scm b/guix/scripts/system.scm
index 6f00f12509..6cf3704d88 100644
--- a/guix/scripts/system.scm
+++ b/guix/scripts/system.scm
@@ -833,6 +833,25 @@ static checks."
(define println
(cut format #t "~a~%" <>))
+ (define menu-entries
+ (if (eq? 'init action)
+ '()
+ (map boot-parameters->menu-entry (profile-boot-parameters))))
+
+ (define bootloader
+ (bootloader-configuration-bootloader (operating-system-bootloader os)))
+
+ (define bootcfg
+ (and (not (eq? 'container action))
+ (operating-system-bootcfg os menu-entries)))
+
+ (define bootloader-script
+ (let ((installer (bootloader-installer bootloader))
+ (target (or target "/")))
+ (bootloader-installer-script installer
+ (bootloader-package bootloader)
+ bootloader-target target)))
+
(when (eq? action 'reconfigure)
(maybe-suggest-running-guix-pull))
@@ -852,23 +871,6 @@ static checks."
#:image-size image-size
#:full-boot? full-boot?
#:mappings mappings))
- (bootloader -> (bootloader-configuration-bootloader
- (operating-system-bootloader os)))
- (bootcfg -> (and (not (eq? 'container action))
- (operating-system-bootcfg
- os
- (if (eq? 'init action)
- '()
- (map boot-parameters->menu-entry
- (profile-boot-parameters))))))
- (bootcfg-file -> (bootloader-configuration-file bootloader))
- (bootloader-installer
- ->
- (let ((installer (bootloader-installer bootloader))
- (target (or target "/")))
- (bootloader-installer-script installer
- (bootloader-package bootloader)
- bootloader-target target)))
;; For 'init' and 'reconfigure', always build BOOTCFG, even if
;; --no-bootloader is passed, because we then use it as a GC root.
@@ -876,7 +878,7 @@ static checks."
(drvs (mapm %store-monad lower-object
(if (memq action '(init reconfigure))
(if install-bootloader?
- (list sys bootcfg bootloader-installer)
+ (list sys bootcfg bootloader-script)
(list sys bootcfg))
(list sys))))
(% (if derivations-only?
@@ -887,7 +889,7 @@ static checks."
(if (or dry-run? derivations-only?)
(return #f)
- (begin
+ (let ((bootcfg-file (bootloader-configuration-file bootloader)))
(for-each (compose println derivation->output-path)
drvs)
@@ -896,7 +898,7 @@ static checks."
(mbegin %store-monad
(switch-to-system os)
(mwhen install-bootloader?
- (install-bootloader bootloader-installer
+ (install-bootloader bootloader-script
#:bootcfg bootcfg
#:bootcfg-file bootcfg-file
#:target "/"))))
--
2.19.1
- [bug#33405] [PATCH 00/10] De-monadify and clean up system code, Ludovic Courtès, 2018/11/16
- [bug#33405] [PATCH 01/10] bootloader: De-monadify configuration file generators., Ludovic Courtès, 2018/11/16
- [bug#33405] [PATCH 10/10] guix system: Clarify 'perform-action'.,
Ludovic Courtès <=
- [bug#33405] [PATCH 08/10] guix system: Simplify bootloader package handling., Ludovic Courtès, 2018/11/16
- [bug#33405] [PATCH 04/10] system: De-monadify 'operating-system-boot-parameters'., Ludovic Courtès, 2018/11/16
- [bug#33405] [PATCH 03/10] linux-initrd: Return file-like objects instead of monadic values., Ludovic Courtès, 2018/11/16
- [bug#33405] [PATCH 05/10] system: Please Emacs., Ludovic Courtès, 2018/11/16
- [bug#33405] [PATCH 06/10] system: De-monadify 'operating-system-bootcfg'., Ludovic Courtès, 2018/11/16
- [bug#33405] [PATCH 07/10] vm: Remove explicit calls to 'operating-system-derivation'., Ludovic Courtès, 2018/11/16
- [bug#33405] [PATCH 09/10] guix system: De-monadify bootloader installation script., Ludovic Courtès, 2018/11/16
- [bug#33405] [PATCH 02/10] system: Simplify kernel argument handling., Ludovic Courtès, 2018/11/16
- [bug#33405] [PATCH 00/10] De-monadify and clean up system code, Mathieu Othacehe, 2018/11/16