environment: Export 'load-manifest'.

* guix/scripts/environment.scm (load-manifest): New procedure.
(options/resolve-packages): Use it.
This commit is contained in:
Ludovic Courtès 2022-03-31 12:12:20 +02:00
parent f54f2aa9df
commit 6fed836a6f
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5

View file

@ -56,6 +56,7 @@ (define-module (guix scripts environment)
#:use-module (srfi srfi-37)
#:use-module (srfi srfi-98)
#:export (assert-container-features
load-manifest
guix-environment
guix-environment*
show-environment-options-help
@ -285,6 +286,11 @@ (define same-key? (cut eq? key <>))
(_ memo)))
'() alist))
(define (load-manifest file) ;TODO: factorize
"Load the user-profile manifest (Scheme code) from FILE and return it."
(let ((user-module (make-user-module '((guix profiles) (gnu)))))
(load* file user-module)))
(define (options/resolve-packages store opts)
"Return OPTS with package specification strings replaced by manifest entries
for the corresponding packages."
@ -331,8 +337,7 @@ (define (packages->outputs packages mode)
(let ((module (make-user-module '())))
(packages->outputs (load* file module) mode)))
(('manifest . file)
(let ((module (make-user-module '((guix profiles) (gnu)))))
(manifest-entries (load* file module))))
(manifest-entries (load-manifest file)))
(_ '()))
opts)
manifest-entry=?)))