inferior: Add 'gexp->derivation-in-inferior'.

* guix/inferior.scm (gexp->derivation-in-inferior): New procedure.
This commit is contained in:
Ludovic Courtès 2019-01-12 18:19:13 +01:00
parent e2a903c807
commit ae92782240
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5

View file

@ -81,6 +81,8 @@ (define-module (guix inferior)
inferior-package->manifest-entry
gexp->derivation-in-inferior
%inferior-cache-directory
inferior-for-channels))
@ -484,6 +486,30 @@ (define-gexp-compiler (package-compiler (package <inferior-package>) system
;; Compile PACKAGE for SYSTEM, optionally cross-building for TARGET.
(inferior-package->derivation package system #:target target))
(define* (gexp->derivation-in-inferior name exp guix
#:rest rest)
"Return a derivation that evaluates EXP with GUIX, an instance of Guix as
returned for example by 'channel-instances->derivation'. Other arguments are
passed as-is to 'gexp->derivation'."
(define trampoline
;; This is a crude way to run EXP on GUIX. TODO: use 'raw-derivation' and
;; make 'guix repl' the "builder"; this will require "opening up" the
;; mechanisms behind 'gexp->derivation', and adding '-l' to 'guix repl'.
#~(begin
(use-modules (ice-9 popen))
(let ((pipe (open-pipe* OPEN_WRITE
#+(file-append guix "/bin/guix")
"repl" "-t" "machine")))
;; Unquote EXP right here so that its references to #$output
;; propagate to the surrounding gexp.
(write '#$exp pipe) ;XXX: load path for EXP?
(unless (zero? (close-pipe pipe))
(error "inferior failed" #+guix)))))
(apply gexp->derivation name trampoline rest))
;;;
;;; Manifest entries.