mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-21 01:26:43 +01:00
graph: 'export-graph' takes a #:reverse-edges? parameter.
* guix/scripts/graph.scm (export-graph): Add #:reverse-edges? parameter and honor it.
This commit is contained in:
parent
00184239c3
commit
a64cd7b65f
1 changed files with 6 additions and 2 deletions
|
@ -322,10 +322,12 @@ (define %graphviz-backend
|
|||
|
||||
(define* (export-graph sinks port
|
||||
#:key
|
||||
reverse-edges?
|
||||
(node-type %package-node-type)
|
||||
(backend %graphviz-backend))
|
||||
"Write to PORT the representation of the DAG with the given SINKS, using the
|
||||
given BACKEND. Use NODE-TYPE to traverse the DAG."
|
||||
given BACKEND. Use NODE-TYPE to traverse the DAG. When REVERSE-EDGES? is
|
||||
true, draw reverse arrows."
|
||||
(match backend
|
||||
(($ <graph-backend> emit-prologue emit-epilogue emit-node emit-edge)
|
||||
(emit-prologue (node-type-name node-type) port)
|
||||
|
@ -349,7 +351,9 @@ (define* (export-graph sinks port
|
|||
dependencies)))
|
||||
(emit-node id (node-label head) port)
|
||||
(for-each (lambda (dependency dependency-id)
|
||||
(emit-edge id dependency-id port))
|
||||
(if reverse-edges?
|
||||
(emit-edge dependency-id id port)
|
||||
(emit-edge id dependency-id port)))
|
||||
dependencies ids)
|
||||
(loop (append dependencies tail)
|
||||
(set-insert id visited)))))))))))))
|
||||
|
|
Loading…
Reference in a new issue