mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-25 20:19:18 -05:00
gnu: vm: Fix inputs in 'file-union'.
* gnu/system/vm.scm (file-union): Filter out members of FILES that are outputs of INPUTS.
This commit is contained in:
parent
18fb40e414
commit
f0387dd167
1 changed files with 18 additions and 5 deletions
|
@ -467,10 +467,23 @@ (define* (file-union files
|
|||
The subset of FILES corresponding to plain store files is automatically added
|
||||
as an inputs; additional inputs, such as derivations, are taken from INPUTS."
|
||||
(mlet %store-monad ((inputs (lower-inputs inputs)))
|
||||
(let ((inputs (append inputs
|
||||
(let* ((outputs (append-map (match-lambda
|
||||
((_ (? derivation? drv))
|
||||
(list (derivation->output-path drv)))
|
||||
((_ (? derivation? drv) sub-drv ...)
|
||||
(map (cut derivation->output-path drv <>)
|
||||
sub-drv))
|
||||
(_ '()))
|
||||
inputs))
|
||||
(inputs (append inputs
|
||||
(filter (match-lambda
|
||||
((_ file)
|
||||
(direct-store-path? file)))
|
||||
;; Elements of FILES that are store
|
||||
;; files and that do not correspond to
|
||||
;; the output of INPUTS are considered
|
||||
;; inputs (still here?).
|
||||
(and (direct-store-path? file)
|
||||
(not (member file outputs)))))
|
||||
files))))
|
||||
(derivation-expression name
|
||||
`(let ((out (assoc-ref %outputs "out")))
|
||||
|
|
Loading…
Reference in a new issue