mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 21:59:08 -05:00
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:
parent
3857aba7ab
commit
7ca533c723
3 changed files with 22 additions and 19 deletions
|
@ -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,20 +557,17 @@ (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)))
|
(match file-system-type
|
||||||
(mbegin %store-monad
|
("iso9660" iso9660-image)
|
||||||
(return
|
(_ (cond
|
||||||
(match file-system-type
|
((and target
|
||||||
("iso9660" iso9660-image)
|
(hurd-triplet? target))
|
||||||
(_ (cond
|
hurd-disk-image)
|
||||||
((and target
|
(else
|
||||||
(hurd-triplet? target))
|
efi-disk-image)))))
|
||||||
hurd-disk-image)
|
|
||||||
(else
|
|
||||||
efi-disk-image))))))))
|
|
||||||
|
|
||||||
;;; image.scm ends here
|
;;; image.scm ends here
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue