1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19 package org.apache.maven.plugins.dependency.tree;
20
21 import java.io.Writer;
22 import java.util.ArrayList;
23 import java.util.List;
24 import org.apache.maven.shared.dependency.graph.DependencyNode;
25 import org.apache.maven.shared.dependency.graph.traversal.DependencyNodeVisitor;
26
27
28
29
30
31
32
33
34 public class TGFDependencyNodeVisitor extends AbstractSerializingVisitor implements DependencyNodeVisitor {
35
36
37
38
39
40
41 static final class EdgeAppender {
42
43
44
45 private final DependencyNode from;
46
47
48
49
50 private final DependencyNode to;
51
52
53
54
55 private final String label;
56
57
58
59
60
61
62
63
64 EdgeAppender(DependencyNode from, DependencyNode to, String label) {
65 super();
66 this.from = from;
67 this.to = to;
68 this.label = label;
69 }
70
71
72
73
74 @Override
75 public String toString() {
76 StringBuilder result = new StringBuilder(generateId(from));
77 result.append(' ').append(generateId(to));
78 if (label != null) {
79 result.append(' ').append(label);
80 }
81 return result.toString();
82 }
83 }
84
85
86
87
88 private final List<EdgeAppender> edges = new ArrayList<>();
89
90
91
92
93
94
95 public TGFDependencyNodeVisitor(Writer writer) {
96 super(writer);
97 }
98
99
100
101
102 @Override
103 public boolean endVisit(DependencyNode node) {
104 if (node.getParent() == null || node.getParent() == node) {
105
106 writer.println("#");
107 for (EdgeAppender edge : edges) {
108 writer.println(edge.toString());
109 }
110 } else {
111 DependencyNode p = node.getParent();
112
113 edges.add(new EdgeAppender(p, node, node.getArtifact().getScope()));
114 }
115 return true;
116 }
117
118
119
120
121 @Override
122 public boolean visit(DependencyNode node) {
123
124 writer.write(generateId(node));
125 writer.write(" ");
126 writer.println(node.toNodeString());
127 return true;
128 }
129
130
131
132
133
134
135
136
137
138
139 private static String generateId(DependencyNode node) {
140 return String.valueOf(node.hashCode());
141 }
142 }