mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-12 06:06:53 -05:00
derivation: Coalesce multiple occurrences of the same input.
* guix/derivations.scm (write-derivation)[coalesce-duplicate-inputs]: New procedure. Use it to process INPUTS. * tests/derivations.scm ("user of multiple-output derivation"): New test.
This commit is contained in:
parent
5f904ffbb1
commit
d66ac374e9
2 changed files with 58 additions and 1 deletions
|
@ -206,6 +206,29 @@ (define (list->string lst)
|
||||||
(define (write-list lst)
|
(define (write-list lst)
|
||||||
(display (list->string lst) port))
|
(display (list->string lst) port))
|
||||||
|
|
||||||
|
(define (coalesce-duplicate-inputs inputs)
|
||||||
|
;; Return a list of inputs, such that when INPUTS contains the same DRV
|
||||||
|
;; twice, they are coalesced, with their sub-derivations merged. This is
|
||||||
|
;; needed because Nix itself keeps only one of them.
|
||||||
|
(fold (lambda (input result)
|
||||||
|
(match input
|
||||||
|
(($ <derivation-input> path sub-drvs)
|
||||||
|
;; XXX: quadratic
|
||||||
|
(match (find (match-lambda
|
||||||
|
(($ <derivation-input> p s)
|
||||||
|
(string=? p path)))
|
||||||
|
result)
|
||||||
|
(#f
|
||||||
|
(cons input result))
|
||||||
|
((and dup ($ <derivation-input> _ sub-drvs2))
|
||||||
|
;; Merge DUP with INPUT.
|
||||||
|
(let ((sub-drvs (delete-duplicates
|
||||||
|
(append sub-drvs sub-drvs2))))
|
||||||
|
(cons (make-derivation-input path sub-drvs)
|
||||||
|
(delq dup result))))))))
|
||||||
|
'()
|
||||||
|
inputs))
|
||||||
|
|
||||||
;; Note: lists are sorted alphabetically, to conform with the behavior of
|
;; Note: lists are sorted alphabetically, to conform with the behavior of
|
||||||
;; C++ `std::map' in Nix itself.
|
;; C++ `std::map' in Nix itself.
|
||||||
|
|
||||||
|
@ -229,7 +252,7 @@ (define (write-list lst)
|
||||||
(format #f "(~s,~a)" path
|
(format #f "(~s,~a)" path
|
||||||
(list->string (map object->string
|
(list->string (map object->string
|
||||||
(sort sub-drvs string<?))))))
|
(sort sub-drvs string<?))))))
|
||||||
(sort inputs
|
(sort (coalesce-duplicate-inputs inputs)
|
||||||
(lambda (i1 i2)
|
(lambda (i1 i2)
|
||||||
(string<? (derivation-input-path i1)
|
(string<? (derivation-input-path i1)
|
||||||
(derivation-input-path i2))))))
|
(derivation-input-path i2))))))
|
||||||
|
@ -400,6 +423,8 @@ (define (env-vars-with-empty-outputs)
|
||||||
system builder args env-vars))
|
system builder args env-vars))
|
||||||
(drv (add-output-paths drv-masked)))
|
(drv (add-output-paths drv-masked)))
|
||||||
|
|
||||||
|
;; (write-derivation drv-masked (current-error-port))
|
||||||
|
;; (newline (current-error-port))
|
||||||
(values (add-text-to-store store (string-append name ".drv")
|
(values (add-text-to-store store (string-append name ".drv")
|
||||||
(call-with-output-string
|
(call-with-output-string
|
||||||
(cut write-derivation drv <>))
|
(cut write-derivation drv <>))
|
||||||
|
|
|
@ -163,6 +163,38 @@ (define prefix-len (string-length dir))
|
||||||
(and (eq? 'one (call-with-input-file one read))
|
(and (eq? 'one (call-with-input-file one read))
|
||||||
(eq? 'two (call-with-input-file two read)))))))
|
(eq? 'two (call-with-input-file two read)))))))
|
||||||
|
|
||||||
|
(test-assert "user of multiple-output derivation"
|
||||||
|
;; Check whether specifying several inputs coming from the same
|
||||||
|
;; multiple-output derivation works.
|
||||||
|
(let* ((builder1 (add-text-to-store %store "my-mo-builder.sh"
|
||||||
|
"echo one > $out ; echo two > $two"
|
||||||
|
'()))
|
||||||
|
(mdrv (derivation %store "multiple-output" (%current-system)
|
||||||
|
"/bin/sh" `(,builder1)
|
||||||
|
'()
|
||||||
|
`((,builder1))
|
||||||
|
#:outputs '("out" "two")))
|
||||||
|
(builder2 (add-text-to-store %store "my-mo-user-builder.sh"
|
||||||
|
"read x < $one;
|
||||||
|
read y < $two;
|
||||||
|
echo \"($x $y)\" > $out"
|
||||||
|
'()))
|
||||||
|
(udrv (derivation %store "multiple-output-user"
|
||||||
|
(%current-system)
|
||||||
|
"/bin/sh" `(,builder2)
|
||||||
|
`(("one" . ,(derivation-path->output-path
|
||||||
|
mdrv "out"))
|
||||||
|
("two" . ,(derivation-path->output-path
|
||||||
|
mdrv "two")))
|
||||||
|
`((,builder2)
|
||||||
|
;; two occurrences of MDRV:
|
||||||
|
(,mdrv)
|
||||||
|
(,mdrv "two")))))
|
||||||
|
(and (build-derivations %store (list (pk 'udrv udrv)))
|
||||||
|
(let ((p (derivation-path->output-path udrv)))
|
||||||
|
(and (valid-path? %store p)
|
||||||
|
(equal? '(one two) (call-with-input-file p read)))))))
|
||||||
|
|
||||||
|
|
||||||
(define %coreutils
|
(define %coreutils
|
||||||
(false-if-exception (nixpkgs-derivation "coreutils")))
|
(false-if-exception (nixpkgs-derivation "coreutils")))
|
||||||
|
|
Loading…
Reference in a new issue