mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-12 06:06:53 -05:00
union: Delete duplicates when passed the same input several times.
* guix/build/union.scm (union-build): Prepend "." to the result of `union-tree', to match the expectations of `delete-duplicate-leaves'. Don't do mkdir when SUBDIR is ".". * tests/union.scm ("union-build"): Keep duplicates in %BOOTSTRAP-INPUTS.
This commit is contained in:
parent
44ce77ff52
commit
6211223021
2 changed files with 10 additions and 7 deletions
|
@ -150,8 +150,9 @@ (define (resolve-collision leaves)
|
|||
|
||||
(mkdir output)
|
||||
(let loop ((tree (delete-duplicate-leaves
|
||||
(tree-union (append-map (compose tree-leaves file-tree)
|
||||
directories))
|
||||
(cons "."
|
||||
(tree-union (append-map (compose tree-leaves file-tree)
|
||||
directories)))
|
||||
leaf=?
|
||||
resolve-collision))
|
||||
(dir '()))
|
||||
|
@ -165,8 +166,9 @@ (define (resolve-collision leaves)
|
|||
(symlink tree target)))
|
||||
(((? string? subdir) leaves ...)
|
||||
;; A sub-directory: create it in OUTPUT, and iterate over LEAVES.
|
||||
(let ((dir (string-join dir "/")))
|
||||
(mkdir (string-append output "/" dir "/" subdir)))
|
||||
(unless (string=? subdir ".")
|
||||
(let ((dir (string-join dir "/")))
|
||||
(mkdir (string-append output "/" dir "/" subdir))))
|
||||
(for-each (cute loop <> `(,@dir ,subdir))
|
||||
leaves))
|
||||
((leaves ...)
|
||||
|
|
|
@ -94,9 +94,10 @@ (define %store
|
|||
(let* ((inputs (map (match-lambda
|
||||
((name package)
|
||||
`(,name ,(package-derivation %store package))))
|
||||
(delete-duplicates %bootstrap-inputs
|
||||
(lambda (i1 i2)
|
||||
(eq? (second i1) (second i2))))))
|
||||
|
||||
;; Purposefully leave duplicate entries.
|
||||
(append %bootstrap-inputs
|
||||
(take %bootstrap-inputs 3))))
|
||||
(builder `(begin
|
||||
(use-modules (guix build union))
|
||||
(union-build (assoc-ref %outputs "out")
|
||||
|
|
Loading…
Reference in a new issue