1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
|
package cuchaz.enigma.convert;
import java.util.Collection;
import java.util.Set;
import com.google.common.collect.BiMap;
import com.google.common.collect.HashBiMap;
import com.google.common.collect.HashMultimap;
import com.google.common.collect.Multimap;
import com.google.common.collect.Sets;
import cuchaz.enigma.mapping.ClassEntry;
import cuchaz.enigma.mapping.Entry;
public class MemberMatches<T extends Entry> {
private BiMap<T,T> m_matches;
private Multimap<ClassEntry,T> m_matchedSourceEntries;
private Multimap<ClassEntry,T> m_unmatchedSourceEntries;
private Multimap<ClassEntry,T> m_unmatchedDestEntries;
private Multimap<ClassEntry,T> m_unmatchableSourceEntries;
public MemberMatches() {
m_matches = HashBiMap.create();
m_matchedSourceEntries = HashMultimap.create();
m_unmatchedSourceEntries = HashMultimap.create();
m_unmatchedDestEntries = HashMultimap.create();
m_unmatchableSourceEntries = HashMultimap.create();
}
public void addMatch(T srcEntry, T destEntry) {
boolean wasAdded = m_matches.put(srcEntry, destEntry) == null;
assert (wasAdded);
wasAdded = m_matchedSourceEntries.put(srcEntry.getClassEntry(), srcEntry);
assert (wasAdded);
}
public void addUnmatchedSourceEntry(T sourceEntry) {
boolean wasAdded = m_unmatchedSourceEntries.put(sourceEntry.getClassEntry(), sourceEntry);
assert (wasAdded);
}
public void addUnmatchedSourceEntries(Iterable<T> sourceEntries) {
for (T sourceEntry : sourceEntries) {
addUnmatchedSourceEntry(sourceEntry);
}
}
public void addUnmatchedDestEntry(T destEntry) {
boolean wasAdded = m_unmatchedDestEntries.put(destEntry.getClassEntry(), destEntry);
assert (wasAdded);
}
public void addUnmatchedDestEntries(Iterable<T> destEntriesntries) {
for (T entry : destEntriesntries) {
addUnmatchedDestEntry(entry);
}
}
public void addUnmatchableSourceEntry(T sourceEntry) {
boolean wasAdded = m_unmatchableSourceEntries.put(sourceEntry.getClassEntry(), sourceEntry);
assert (wasAdded);
}
public Set<ClassEntry> getSourceClassesWithUnmatchedEntries() {
return m_unmatchedSourceEntries.keySet();
}
public Collection<ClassEntry> getSourceClassesWithoutUnmatchedEntries() {
Set<ClassEntry> out = Sets.newHashSet();
out.addAll(m_matchedSourceEntries.keySet());
out.removeAll(m_unmatchedSourceEntries.keySet());
return out;
}
public Collection<T> getUnmatchedSourceEntries() {
return m_unmatchedSourceEntries.values();
}
public Collection<T> getUnmatchedSourceEntries(ClassEntry sourceClass) {
return m_unmatchedSourceEntries.get(sourceClass);
}
public Collection<T> getUnmatchedDestEntries() {
return m_unmatchedDestEntries.values();
}
public Collection<T> getUnmatchedDestEntries(ClassEntry destClass) {
return m_unmatchedDestEntries.get(destClass);
}
public Collection<T> getUnmatchableSourceEntries() {
return m_unmatchableSourceEntries.values();
}
public boolean hasSource(T sourceEntry) {
return m_matches.containsKey(sourceEntry) || m_unmatchedSourceEntries.containsValue(sourceEntry);
}
public boolean hasDest(T destEntry) {
return m_matches.containsValue(destEntry) || m_unmatchedDestEntries.containsValue(destEntry);
}
public BiMap<T,T> matches() {
return m_matches;
}
public boolean isMatchedSourceEntry(T sourceEntry) {
return m_matches.containsKey(sourceEntry);
}
public boolean isMatchedDestEntry(T destEntry) {
return m_matches.containsValue(destEntry);
}
public void makeMatch(T sourceEntry, T destEntry) {
boolean wasRemoved = m_unmatchedSourceEntries.remove(sourceEntry.getClassEntry(), sourceEntry);
assert (wasRemoved);
wasRemoved = m_unmatchedDestEntries.remove(destEntry.getClassEntry(), destEntry);
assert (wasRemoved);
addMatch(sourceEntry, destEntry);
}
public boolean isMatched(T sourceEntry, T destEntry) {
T match = m_matches.get(sourceEntry);
return match != null && match.equals(destEntry);
}
public void unmakeMatch(T sourceEntry, T destEntry) {
boolean wasRemoved = m_matches.remove(sourceEntry) != null;
assert (wasRemoved);
wasRemoved = m_matchedSourceEntries.remove(sourceEntry.getClassEntry(), sourceEntry);
assert (wasRemoved);
addUnmatchedSourceEntry(sourceEntry);
addUnmatchedDestEntry(destEntry);
}
public void makeSourceUnmatchable(T sourceEntry) {
assert(!isMatchedSourceEntry(sourceEntry));
boolean wasRemoved = m_unmatchedSourceEntries.remove(sourceEntry.getClassEntry(), sourceEntry);
assert (wasRemoved);
addUnmatchableSourceEntry(sourceEntry);
}
}
|