mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-26 12:39:36 -05:00
inferior: Add 'gexp->derivation-in-inferior'.
* guix/inferior.scm (gexp->derivation-in-inferior): New procedure.
This commit is contained in:
parent
e2a903c807
commit
ae92782240
1 changed files with 26 additions and 0 deletions
|
@ -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.
|
||||
|
|
Loading…
Reference in a new issue