mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-25 20:19:18 -05:00
graph: %BAG-WITH-ORIGINS-NODE-TYPE includes the origin's guile.
Before that it would include #f for most origins since that the default value of 'origin-patch-guile'. * guix/scripts/graph.scm (bag-node-edges): When 'origin-patch-guile' returns #f, use (default-guile). * tests/graph.scm ("bag DAG, including origins"): Check for an edge from O to (default-guile).
This commit is contained in:
parent
f88282af38
commit
51385362f7
2 changed files with 10 additions and 2 deletions
|
@ -113,7 +113,7 @@ (define (bag-node-edges thing)
|
||||||
(((labels things . outputs) ...)
|
(((labels things . outputs) ...)
|
||||||
things)))
|
things)))
|
||||||
((origin? thing)
|
((origin? thing)
|
||||||
(cons (origin-patch-guile thing)
|
(cons (or (origin-patch-guile thing) (default-guile))
|
||||||
(if (or (pair? (origin-patches thing))
|
(if (or (pair? (origin-patches thing))
|
||||||
(origin-snippet thing))
|
(origin-snippet thing))
|
||||||
(match (origin-patch-inputs thing)
|
(match (origin-patch-inputs thing)
|
||||||
|
|
|
@ -150,7 +150,8 @@ (define (edge->tuple source target)
|
||||||
(let-values (((nodes edges) (nodes+edges)))
|
(let-values (((nodes edges) (nodes+edges)))
|
||||||
(run-with-store %store
|
(run-with-store %store
|
||||||
(mlet %store-monad ((o* (lower-object o))
|
(mlet %store-monad ((o* (lower-object o))
|
||||||
(p* (lower-object p)))
|
(p* (lower-object p))
|
||||||
|
(g (lower-object (default-guile))))
|
||||||
(return
|
(return
|
||||||
(and (find (match-lambda
|
(and (find (match-lambda
|
||||||
((file "the-uri") #t)
|
((file "the-uri") #t)
|
||||||
|
@ -160,6 +161,13 @@ (define (edge->tuple source target)
|
||||||
((source target)
|
((source target)
|
||||||
(and (string=? source (derivation-file-name p*))
|
(and (string=? source (derivation-file-name p*))
|
||||||
(string=? target o*))))
|
(string=? target o*))))
|
||||||
|
edges)
|
||||||
|
|
||||||
|
;; There must also be an edge from O to G.
|
||||||
|
(find (match-lambda
|
||||||
|
((source target)
|
||||||
|
(and (string=? source o*)
|
||||||
|
(string=? target (derivation-file-name g)))))
|
||||||
edges)))))))))
|
edges)))))))))
|
||||||
|
|
||||||
(test-assert "derivation DAG"
|
(test-assert "derivation DAG"
|
||||||
|
|
Loading…
Reference in a new issue