guix build: Extract '--with-input' replacement spec parsing.
* guix/scripts/build.scm (evaluate-replacement-specs): New procedure. (transform-package-inputs)[not-equal]: Remove. [replacements]: Define in terms of 'evaluate-replacement-specs'.
This commit is contained in:
parent
00bfd498f9
commit
5cf01aa53f
|
@ -179,27 +179,31 @@ matching URIs given in SOURCES."
|
||||||
(_
|
(_
|
||||||
obj)))))
|
obj)))))
|
||||||
|
|
||||||
(define (transform-package-inputs replacement-specs)
|
(define (evaluate-replacement-specs specs proc)
|
||||||
"Return a procedure that, when passed a package, replaces its direct
|
"Parse SPECS, a list of strings like \"guile=guile@2.1\", and invoke PROC on
|
||||||
dependencies according to REPLACEMENT-SPECS. REPLACEMENT-SPECS is a list of
|
each package pair specified by SPECS. Return the resulting list. Raise an
|
||||||
strings like \"guile=guile@2.1\" meaning that, any direct dependency on a
|
error if an element of SPECS uses invalid syntax, or if a package it refers to
|
||||||
package called \"guile\" must be replaced with a dependency on a version 2.1
|
could not be found."
|
||||||
of \"guile\"."
|
|
||||||
(define not-equal
|
(define not-equal
|
||||||
(char-set-complement (char-set #\=)))
|
(char-set-complement (char-set #\=)))
|
||||||
|
|
||||||
(define replacements
|
|
||||||
;; List of name/package pairs.
|
|
||||||
(map (lambda (spec)
|
(map (lambda (spec)
|
||||||
(match (string-tokenize spec not-equal)
|
(match (string-tokenize spec not-equal)
|
||||||
((old new)
|
((old new)
|
||||||
(cons (specification->package old)
|
(proc (specification->package old)
|
||||||
(specification->package new)))
|
(specification->package new)))
|
||||||
(x
|
(x
|
||||||
(leave (_ "invalid replacement specification: ~s~%") spec))))
|
(leave (_ "invalid replacement specification: ~s~%") spec))))
|
||||||
replacement-specs))
|
specs))
|
||||||
|
|
||||||
(let ((rewrite (package-input-rewriting replacements)))
|
(define (transform-package-inputs replacement-specs)
|
||||||
|
"Return a procedure that, when passed a package, replaces its direct
|
||||||
|
dependencies according to REPLACEMENT-SPECS. REPLACEMENT-SPECS is a list of
|
||||||
|
strings like \"guile=guile@2.1\" meaning that, any dependency on a package
|
||||||
|
called \"guile\" must be replaced with a dependency on a version 2.1 of
|
||||||
|
\"guile\"."
|
||||||
|
(let* ((replacements (evaluate-replacement-specs replacement-specs cons))
|
||||||
|
(rewrite (package-input-rewriting replacements)))
|
||||||
(lambda (store obj)
|
(lambda (store obj)
|
||||||
(if (package? obj)
|
(if (package? obj)
|
||||||
(rewrite obj)
|
(rewrite obj)
|
||||||
|
|
Loading…
Reference in New Issue