summaryrefslogtreecommitdiff
path: root/src/main/java/cuchaz/enigma/analysis/IndexTreeBuilder.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/cuchaz/enigma/analysis/IndexTreeBuilder.java')
-rw-r--r--src/main/java/cuchaz/enigma/analysis/IndexTreeBuilder.java31
1 files changed, 9 insertions, 22 deletions
diff --git a/src/main/java/cuchaz/enigma/analysis/IndexTreeBuilder.java b/src/main/java/cuchaz/enigma/analysis/IndexTreeBuilder.java
index 4ca7cd1..0c2dfd7 100644
--- a/src/main/java/cuchaz/enigma/analysis/IndexTreeBuilder.java
+++ b/src/main/java/cuchaz/enigma/analysis/IndexTreeBuilder.java
@@ -1,13 +1,14 @@
1package cuchaz.enigma.analysis; 1package cuchaz.enigma.analysis;
2 2
3import com.google.common.collect.Lists; 3import com.google.common.collect.Lists;
4import cuchaz.enigma.analysis.index.EntryIndex;
5import cuchaz.enigma.analysis.index.JarIndex; 4import cuchaz.enigma.analysis.index.JarIndex;
6import cuchaz.enigma.translation.Translator; 5import cuchaz.enigma.translation.Translator;
6import cuchaz.enigma.translation.mapping.EntryResolver;
7import cuchaz.enigma.translation.mapping.ResolutionStrategy; 7import cuchaz.enigma.translation.mapping.ResolutionStrategy;
8import cuchaz.enigma.translation.representation.entry.ClassEntry; 8import cuchaz.enigma.translation.representation.entry.ClassEntry;
9import cuchaz.enigma.translation.representation.entry.MethodEntry; 9import cuchaz.enigma.translation.representation.entry.MethodEntry;
10 10
11import java.util.Collection;
11import java.util.List; 12import java.util.List;
12 13
13public class IndexTreeBuilder { 14public class IndexTreeBuilder {
@@ -52,34 +53,20 @@ public class IndexTreeBuilder {
52 ); 53 );
53 54
54 // expand the full tree 55 // expand the full tree
55 rootNode.load(index, true); 56 rootNode.load(index);
56 57
57 return rootNode; 58 return rootNode;
58 } 59 }
59 60
60 public List<MethodImplementationsTreeNode> buildMethodImplementations(Translator translator, MethodEntry obfMethodEntry) { 61 public List<MethodImplementationsTreeNode> buildMethodImplementations(Translator translator, MethodEntry obfMethodEntry) {
61 EntryIndex entryIndex = index.getEntryIndex(); 62 EntryResolver resolver = index.getEntryResolver();
62 63 Collection<MethodEntry> resolvedEntries = resolver.resolveEntry(obfMethodEntry, ResolutionStrategy.RESOLVE_ROOT);
63 List<MethodEntry> ancestorMethodEntries = Lists.newArrayList();
64
65 if (entryIndex.hasMethod(obfMethodEntry)) {
66 ancestorMethodEntries.add(obfMethodEntry);
67 }
68
69 for (ClassEntry ancestorEntry : index.getInheritanceIndex().getAncestors(obfMethodEntry.getParent())) {
70 MethodEntry ancestorMethod = obfMethodEntry.withParent(ancestorEntry);
71 if (entryIndex.hasMethod(ancestorMethod)) {
72 ancestorMethodEntries.add(ancestorMethod);
73 }
74 }
75 64
76 List<MethodImplementationsTreeNode> nodes = Lists.newArrayList(); 65 List<MethodImplementationsTreeNode> nodes = Lists.newArrayList();
77 if (!ancestorMethodEntries.isEmpty()) { 66 for (MethodEntry resolvedEntry : resolvedEntries) {
78 for (MethodEntry interfaceMethodEntry : ancestorMethodEntries) { 67 MethodImplementationsTreeNode node = new MethodImplementationsTreeNode(translator, resolvedEntry);
79 MethodImplementationsTreeNode node = new MethodImplementationsTreeNode(translator, interfaceMethodEntry); 68 node.load(index);
80 node.load(index); 69 nodes.add(node);
81 nodes.add(node);
82 }
83 } 70 }
84 71
85 return nodes; 72 return nodes;