mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-25 20:19:18 -05:00
gexp: 'ungexp-splicing' properly accounts for nested native inputs.
Previously, (gexp-native-inputs #~#$@(list #~#+foo)) would return '().
This is a followup to 5b14a7902c
.
* guix/gexp.scm (gexp-inputs)[add-reference-inputs]: In the list case,
remove 'if' around 'fold-right'. In 'map' lambda, always inherit N?.
* tests/gexp.scm ("gexp list splicing + ungexp-splicing"): New test.
This commit is contained in:
parent
1cbcbc8600
commit
578dfbe07b
2 changed files with 19 additions and 9 deletions
|
@ -706,15 +706,17 @@ (define (add-reference-inputs ref result)
|
||||||
(cons `(,thing ,output) result)
|
(cons `(,thing ,output) result)
|
||||||
result))
|
result))
|
||||||
(($ <gexp-input> (lst ...) output n?)
|
(($ <gexp-input> (lst ...) output n?)
|
||||||
(if (eqv? native? n?)
|
(fold-right add-reference-inputs result
|
||||||
(fold-right add-reference-inputs result
|
;; XXX: For now, automatically convert LST to a list of
|
||||||
;; XXX: For now, automatically convert LST to a list of
|
;; gexp-inputs. Inherit N?.
|
||||||
;; gexp-inputs.
|
(map (match-lambda
|
||||||
(map (match-lambda
|
((? gexp-input? x)
|
||||||
((? gexp-input? x) x)
|
(%gexp-input (gexp-input-thing x)
|
||||||
(x (%gexp-input x "out" (or n? native?))))
|
(gexp-input-output x)
|
||||||
lst))
|
n?))
|
||||||
result))
|
(x
|
||||||
|
(%gexp-input x "out" n?)))
|
||||||
|
lst)))
|
||||||
(_
|
(_
|
||||||
;; Ignore references to other kinds of objects.
|
;; Ignore references to other kinds of objects.
|
||||||
result)))
|
result)))
|
||||||
|
|
|
@ -355,6 +355,14 @@ (define (match-input thing)
|
||||||
(equal? (gexp->sexp* exp) ;native
|
(equal? (gexp->sexp* exp) ;native
|
||||||
(gexp->sexp* exp "mips64el-linux")))))
|
(gexp->sexp* exp "mips64el-linux")))))
|
||||||
|
|
||||||
|
(test-assert "gexp list splicing + ungexp-splicing"
|
||||||
|
(let* ((inner (gexp (ungexp-native glibc)))
|
||||||
|
(exp (gexp (list (ungexp-splicing (list inner))))))
|
||||||
|
(and (equal? `((,glibc "out")) (gexp-native-inputs exp))
|
||||||
|
(null? (gexp-inputs exp))
|
||||||
|
(equal? (gexp->sexp* exp) ;native
|
||||||
|
(gexp->sexp* exp "mips64el-linux")))))
|
||||||
|
|
||||||
(test-equal "output list"
|
(test-equal "output list"
|
||||||
2
|
2
|
||||||
(let ((exp (gexp (begin (mkdir (ungexp output))
|
(let ((exp (gexp (begin (mkdir (ungexp output))
|
||||||
|
|
Loading…
Reference in a new issue