mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-19 14:07:01 +01:00
derivations: Improve complexity of 'substitution-oracle'.
* guix/derivations.scm (substitution-oracle): Use a final 'concatenate' instead of repeated 'append's.
This commit is contained in:
parent
1bd4e6db15
commit
b59df2434a
1 changed files with 10 additions and 10 deletions
|
@ -264,16 +264,16 @@ (define (dependencies drv)
|
|||
(derivation-prerequisites drv valid-input?)))
|
||||
|
||||
(let* ((paths (delete-duplicates
|
||||
(fold (lambda (drv result)
|
||||
(let ((self (match (derivation->output-paths drv)
|
||||
(((names . paths) ...)
|
||||
paths))))
|
||||
(if (every valid? self)
|
||||
result
|
||||
(append (append self (dependencies drv))
|
||||
result))))
|
||||
'()
|
||||
drv)))
|
||||
(concatenate
|
||||
(fold (lambda (drv result)
|
||||
(let ((self (match (derivation->output-paths drv)
|
||||
(((names . paths) ...)
|
||||
paths))))
|
||||
(if (every valid? self)
|
||||
result
|
||||
(cons* self (dependencies drv) result))))
|
||||
'()
|
||||
drv))))
|
||||
(subst (list->set (substitutable-paths store paths))))
|
||||
(cut set-contains? subst <>)))
|
||||
|
||||
|
|
Loading…
Reference in a new issue