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:
Ludovic Courtès 2017-07-17 23:21:55 +02:00
parent 1cbcbc8600
commit 578dfbe07b
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5
2 changed files with 19 additions and 9 deletions

View file

@ -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)))

View file

@ -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))