mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-26 12:39:36 -05:00
derivations: Add a search path parameter for module derivations.
* guix/derivations.scm (imported-modules, compiled-modules): Add a `module-path' parameter. Use it instead of %LOAD-PATH.
This commit is contained in:
parent
3c81cdf19c
commit
e95da44576
1 changed files with 8 additions and 5 deletions
|
@ -558,9 +558,10 @@ (define* (imported-files store files
|
|||
(define* (imported-modules store modules
|
||||
#:key (name "module-import")
|
||||
(system (%current-system))
|
||||
(guile (%guile-for-build)))
|
||||
(guile (%guile-for-build))
|
||||
(module-path %load-path))
|
||||
"Return a derivation that contains the source files of MODULES, a list of
|
||||
module names such as `(ice-9 q)'. All of MODULES must be in the current
|
||||
module names such as `(ice-9 q)'. All of MODULES must be in the MODULE-PATH
|
||||
search path."
|
||||
;; TODO: Determine the closure of MODULES, build the `.go' files,
|
||||
;; canonicalize the source files through read/write, etc.
|
||||
|
@ -568,7 +569,7 @@ (define* (imported-modules store modules
|
|||
(let ((f (string-append
|
||||
(string-join (map symbol->string m) "/")
|
||||
".scm")))
|
||||
(cons f (search-path %load-path f))))
|
||||
(cons f (search-path module-path f))))
|
||||
modules)))
|
||||
(imported-files store files #:name name #:system system
|
||||
#:guile guile)))
|
||||
|
@ -576,13 +577,15 @@ (define* (imported-modules store modules
|
|||
(define* (compiled-modules store modules
|
||||
#:key (name "module-import-compiled")
|
||||
(system (%current-system))
|
||||
(guile (%guile-for-build)))
|
||||
(guile (%guile-for-build))
|
||||
(module-path %load-path))
|
||||
"Return a derivation that builds a tree containing the `.go' files
|
||||
corresponding to MODULES. All the MODULES are built in a context where
|
||||
they can refer to each other."
|
||||
(let* ((module-drv (imported-modules store modules
|
||||
#:system system
|
||||
#:guile guile))
|
||||
#:guile guile
|
||||
#:module-path module-path))
|
||||
(module-dir (derivation-path->output-path module-drv))
|
||||
(files (map (lambda (m)
|
||||
(let ((f (string-join (map symbol->string m)
|
||||
|
|
Loading…
Reference in a new issue