1 package org.apache.maven.plugins.dependency.tree;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 import org.apache.maven.shared.dependency.graph.DependencyNode;
23 import org.apache.maven.shared.dependency.graph.traversal.DependencyNodeVisitor;
24
25 import java.io.Writer;
26 import java.util.List;
27
28
29
30
31
32
33
34 public class DOTDependencyNodeVisitor
35 extends AbstractSerializingVisitor
36 implements DependencyNodeVisitor
37 {
38
39
40
41
42
43
44 public DOTDependencyNodeVisitor( Writer writer )
45 {
46 super( writer );
47 }
48
49
50
51
52 @Override
53 public boolean visit( DependencyNode node )
54 {
55 if ( node.getParent() == null || node.getParent() == node )
56 {
57 writer.write( "digraph \"" + node.toNodeString() + "\" { \n" );
58 }
59
60
61
62 List<DependencyNode> children = node.getChildren();
63
64 for ( DependencyNode child : children )
65 {
66 writer.println( "\t\"" + node.toNodeString() + "\" -> \"" + child.toNodeString() + "\" ; " );
67 }
68
69 return true;
70 }
71
72
73
74
75 @Override
76 public boolean endVisit( DependencyNode node )
77 {
78 if ( node.getParent() == null || node.getParent() == node )
79 {
80 writer.write( " } " );
81 }
82 return true;
83 }
84
85 }