image: Make 'find-image' non-monadic.

* gnu/system/image.scm (find-image): Make non-monadic.  Add 'target'
parameter.
* gnu/tests/install.scm (run-install): Update caller,
passing (%current-target-system).
* guix/scripts/system.scm (perform-action): Likewise.
This commit is contained in:
Jan (janneke) Nieuwenhuizen 2020-06-11 22:52:12 +02:00 committed by Jan Nieuwenhuizen
parent 3857aba7ab
commit 7ca533c723
No known key found for this signature in database
GPG key ID: F3C1A0D9C1D65273
3 changed files with 22 additions and 19 deletions

View file

@ -1,5 +1,6 @@
;;; GNU Guix --- Functional package management for GNU ;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2020 Mathieu Othacehe <m.othacehe@gmail.com> ;;; Copyright © 2020 Mathieu Othacehe <m.othacehe@gmail.com>
;;; Copyright © 2020 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
;;; ;;;
;;; This file is part of GNU Guix. ;;; This file is part of GNU Guix.
;;; ;;;
@ -556,13 +557,10 @@ (define substitutable? (image-substitutable? image))
#:grub-mkrescue-environment #:grub-mkrescue-environment
'(("MKRESCUE_SED_MODE" . "mbr_only"))))))) '(("MKRESCUE_SED_MODE" . "mbr_only")))))))
(define (find-image file-system-type) (define (find-image file-system-type target)
"Find and return an image that could match the given FILE-SYSTEM-TYPE. This "Find and return an image built that could match the given FILE-SYSTEM-TYPE,
is useful to adapt to interfaces written before the addition of the <image> built for TARGET. This is useful to adapt to interfaces written before the
record." addition of the <image> record."
(mlet %store-monad ((target (current-target-system)))
(mbegin %store-monad
(return
(match file-system-type (match file-system-type
("iso9660" iso9660-image) ("iso9660" iso9660-image)
(_ (cond (_ (cond
@ -570,6 +568,6 @@ (define (find-image file-system-type)
(hurd-triplet? target)) (hurd-triplet? target))
hurd-disk-image) hurd-disk-image)
(else (else
efi-disk-image)))))))) efi-disk-image)))))
;;; image.scm ends here ;;; image.scm ends here

View file

@ -3,6 +3,7 @@
;;; Copyright © 2017, 2019 Tobias Geerinckx-Rice <me@tobias.gr> ;;; Copyright © 2017, 2019 Tobias Geerinckx-Rice <me@tobias.gr>
;;; Copyright © 2020 Mathieu Othacehe <m.othacehe@gmail.com> ;;; Copyright © 2020 Mathieu Othacehe <m.othacehe@gmail.com>
;;; Copyright © 2020 Danny Milosavljevic <dannym@scratchpost.org> ;;; Copyright © 2020 Danny Milosavljevic <dannym@scratchpost.org>
;;; Copyright © 2020 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
;;; ;;;
;;; This file is part of GNU Guix. ;;; This file is part of GNU Guix.
;;; ;;;
@ -227,15 +228,17 @@ (define* (run-install target-os target-os-source
(mlet* %store-monad ((_ (set-grafting #f)) (mlet* %store-monad ((_ (set-grafting #f))
(system (current-system)) (system (current-system))
(target (operating-system-derivation target-os)) (target (current-target-system))
(base-image (find-image (base-image -> (find-image
installation-disk-image-file-system-type)) installation-disk-image-file-system-type
target))
;; Since the installation system has no network access, ;; Since the installation system has no network access,
;; we cheat a little bit by adding TARGET to its GC ;; we cheat a little bit by adding TARGET to its GC
;; roots. This way, we know 'guix system init' will ;; roots. This way, we know 'guix system init' will
;; succeed. Also add guile-final, which is pulled in ;; succeed. Also add guile-final, which is pulled in
;; through provenance.drv and may not always be present. ;; through provenance.drv and may not always be present.
(target (operating-system-derivation target-os))
(image -> (image ->
(system-image (system-image
(image (image

View file

@ -5,6 +5,7 @@
;;; Copyright © 2017, 2019 Mathieu Othacehe <m.othacehe@gmail.com> ;;; Copyright © 2017, 2019 Mathieu Othacehe <m.othacehe@gmail.com>
;;; Copyright © 2018 Ricardo Wurmus <rekado@elephly.net> ;;; Copyright © 2018 Ricardo Wurmus <rekado@elephly.net>
;;; Copyright © 2019 Christopher Baines <mail@cbaines.net> ;;; Copyright © 2019 Christopher Baines <mail@cbaines.net>
;;; Copyright © 2020 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
;;; ;;;
;;; This file is part of GNU Guix. ;;; This file is part of GNU Guix.
;;; ;;;
@ -801,7 +802,8 @@ (define bootcfg
(check-initrd-modules os))) (check-initrd-modules os)))
(mlet* %store-monad (mlet* %store-monad
((image (find-image file-system-type)) ((target (current-target-system))
(image -> (find-image file-system-type target))
(sys (system-derivation-for-action os image action (sys (system-derivation-for-action os image action
#:file-system-type file-system-type #:file-system-type file-system-type
#:image-size image-size #:image-size image-size