diff options
| author | 2015-02-23 23:29:22 -0500 | |
|---|---|---|
| committer | 2015-02-23 23:29:22 -0500 | |
| commit | 2dc7428e37bdd7a119f53d02ce157675509b0d63 (patch) | |
| tree | 68f409ac726166e427eea3a199eb462130c53ccd /src/cuchaz/enigma/mapping/ClassMapping.java | |
| parent | make types serializable (diff) | |
| download | enigma-fork-2dc7428e37bdd7a119f53d02ce157675509b0d63.tar.gz enigma-fork-2dc7428e37bdd7a119f53d02ce157675509b0d63.tar.xz enigma-fork-2dc7428e37bdd7a119f53d02ce157675509b0d63.zip | |
lots of work in better handling of inner classes
also working on recognizing unobfuscated and deobfuscated jars
(needed for M3L)
Diffstat (limited to '')
| -rw-r--r-- | src/cuchaz/enigma/mapping/ClassMapping.java | 41 |
1 files changed, 23 insertions, 18 deletions
diff --git a/src/cuchaz/enigma/mapping/ClassMapping.java b/src/cuchaz/enigma/mapping/ClassMapping.java index 885400b..3610e33 100644 --- a/src/cuchaz/enigma/mapping/ClassMapping.java +++ b/src/cuchaz/enigma/mapping/ClassMapping.java | |||
| @@ -20,7 +20,8 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 20 | 20 | ||
| 21 | private static final long serialVersionUID = -5148491146902340107L; | 21 | private static final long serialVersionUID = -5148491146902340107L; |
| 22 | 22 | ||
| 23 | private String m_obfName; | 23 | private String m_obfFullName; |
| 24 | private String m_obfSimpleName; | ||
| 24 | private String m_deobfName; | 25 | private String m_deobfName; |
| 25 | private Map<String,ClassMapping> m_innerClassesByObf; | 26 | private Map<String,ClassMapping> m_innerClassesByObf; |
| 26 | private Map<String,ClassMapping> m_innerClassesByDeobf; | 27 | private Map<String,ClassMapping> m_innerClassesByDeobf; |
| @@ -34,7 +35,8 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 34 | } | 35 | } |
| 35 | 36 | ||
| 36 | public ClassMapping(String obfName, String deobfName) { | 37 | public ClassMapping(String obfName, String deobfName) { |
| 37 | m_obfName = obfName; | 38 | m_obfFullName = obfName; |
| 39 | m_obfSimpleName = new ClassEntry(obfName).getSimpleName(); | ||
| 38 | m_deobfName = NameValidator.validateClassName(deobfName, false); | 40 | m_deobfName = NameValidator.validateClassName(deobfName, false); |
| 39 | m_innerClassesByObf = Maps.newHashMap(); | 41 | m_innerClassesByObf = Maps.newHashMap(); |
| 40 | m_innerClassesByDeobf = Maps.newHashMap(); | 42 | m_innerClassesByDeobf = Maps.newHashMap(); |
| @@ -44,8 +46,12 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 44 | m_methodsByDeobf = Maps.newHashMap(); | 46 | m_methodsByDeobf = Maps.newHashMap(); |
| 45 | } | 47 | } |
| 46 | 48 | ||
| 47 | public String getObfName() { | 49 | public String getObfFullName() { |
| 48 | return m_obfName; | 50 | return m_obfFullName; |
| 51 | } | ||
| 52 | |||
| 53 | public String getObfSimpleName() { | ||
| 54 | return m_obfSimpleName; | ||
| 49 | } | 55 | } |
| 50 | 56 | ||
| 51 | public String getDeobfName() { | 57 | public String getDeobfName() { |
| @@ -64,8 +70,7 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 64 | } | 70 | } |
| 65 | 71 | ||
| 66 | public void addInnerClassMapping(ClassMapping classMapping) { | 72 | public void addInnerClassMapping(ClassMapping classMapping) { |
| 67 | assert (isSimpleClassName(classMapping.getObfName())); | 73 | boolean obfWasAdded = m_innerClassesByObf.put(classMapping.getObfSimpleName(), classMapping) == null; |
| 68 | boolean obfWasAdded = m_innerClassesByObf.put(classMapping.getObfName(), classMapping) == null; | ||
| 69 | assert (obfWasAdded); | 74 | assert (obfWasAdded); |
| 70 | if (classMapping.getDeobfName() != null) { | 75 | if (classMapping.getDeobfName() != null) { |
| 71 | assert (isSimpleClassName(classMapping.getDeobfName())); | 76 | assert (isSimpleClassName(classMapping.getDeobfName())); |
| @@ -75,7 +80,7 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 75 | } | 80 | } |
| 76 | 81 | ||
| 77 | public void removeInnerClassMapping(ClassMapping classMapping) { | 82 | public void removeInnerClassMapping(ClassMapping classMapping) { |
| 78 | boolean obfWasRemoved = m_innerClassesByObf.remove(classMapping.getObfName()) != null; | 83 | boolean obfWasRemoved = m_innerClassesByObf.remove(classMapping.getObfSimpleName()) != null; |
| 79 | assert (obfWasRemoved); | 84 | assert (obfWasRemoved); |
| 80 | if (classMapping.getDeobfName() != null) { | 85 | if (classMapping.getDeobfName() != null) { |
| 81 | boolean deobfWasRemoved = m_innerClassesByDeobf.remove(classMapping.getDeobfName()) != null; | 86 | boolean deobfWasRemoved = m_innerClassesByDeobf.remove(classMapping.getDeobfName()) != null; |
| @@ -112,11 +117,11 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 112 | return classMapping; | 117 | return classMapping; |
| 113 | } | 118 | } |
| 114 | 119 | ||
| 115 | public String getObfInnerClassName(String deobfName) { | 120 | public String getObfInnerClassSimpleName(String deobfName) { |
| 116 | assert (isSimpleClassName(deobfName)); | 121 | assert (isSimpleClassName(deobfName)); |
| 117 | ClassMapping classMapping = m_innerClassesByDeobf.get(deobfName); | 122 | ClassMapping classMapping = m_innerClassesByDeobf.get(deobfName); |
| 118 | if (classMapping != null) { | 123 | if (classMapping != null) { |
| 119 | return classMapping.getObfName(); | 124 | return classMapping.getObfSimpleName(); |
| 120 | } | 125 | } |
| 121 | return null; | 126 | return null; |
| 122 | } | 127 | } |
| @@ -163,7 +168,7 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 163 | public void addFieldMapping(FieldMapping fieldMapping) { | 168 | public void addFieldMapping(FieldMapping fieldMapping) { |
| 164 | String obfKey = getFieldKey(fieldMapping.getObfName(), fieldMapping.getObfType()); | 169 | String obfKey = getFieldKey(fieldMapping.getObfName(), fieldMapping.getObfType()); |
| 165 | if (m_fieldsByObf.containsKey(obfKey)) { | 170 | if (m_fieldsByObf.containsKey(obfKey)) { |
| 166 | throw new Error("Already have mapping for " + m_obfName + "." + obfKey); | 171 | throw new Error("Already have mapping for " + m_obfFullName + "." + obfKey); |
| 167 | } | 172 | } |
| 168 | String deobfKey = getFieldKey(fieldMapping.getDeobfName(), fieldMapping.getObfType()); | 173 | String deobfKey = getFieldKey(fieldMapping.getDeobfName(), fieldMapping.getObfType()); |
| 169 | if (m_fieldsByDeobf.containsKey(deobfKey)) { | 174 | if (m_fieldsByDeobf.containsKey(deobfKey)) { |
| @@ -257,7 +262,7 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 257 | public void addMethodMapping(MethodMapping methodMapping) { | 262 | public void addMethodMapping(MethodMapping methodMapping) { |
| 258 | String obfKey = getMethodKey(methodMapping.getObfName(), methodMapping.getObfSignature()); | 263 | String obfKey = getMethodKey(methodMapping.getObfName(), methodMapping.getObfSignature()); |
| 259 | if (m_methodsByObf.containsKey(obfKey)) { | 264 | if (m_methodsByObf.containsKey(obfKey)) { |
| 260 | throw new Error("Already have mapping for " + m_obfName + "." + obfKey); | 265 | throw new Error("Already have mapping for " + m_obfFullName + "." + obfKey); |
| 261 | } | 266 | } |
| 262 | boolean wasAdded = m_methodsByObf.put(obfKey, methodMapping) == null; | 267 | boolean wasAdded = m_methodsByObf.put(obfKey, methodMapping) == null; |
| 263 | assert (wasAdded); | 268 | assert (wasAdded); |
| @@ -339,7 +344,7 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 339 | @Override | 344 | @Override |
| 340 | public String toString() { | 345 | public String toString() { |
| 341 | StringBuilder buf = new StringBuilder(); | 346 | StringBuilder buf = new StringBuilder(); |
| 342 | buf.append(m_obfName); | 347 | buf.append(m_obfFullName); |
| 343 | buf.append(" <-> "); | 348 | buf.append(" <-> "); |
| 344 | buf.append(m_deobfName); | 349 | buf.append(m_deobfName); |
| 345 | buf.append("\n"); | 350 | buf.append("\n"); |
| @@ -359,7 +364,7 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 359 | buf.append("Inner Classes:\n"); | 364 | buf.append("Inner Classes:\n"); |
| 360 | for (ClassMapping classMapping : m_innerClassesByObf.values()) { | 365 | for (ClassMapping classMapping : m_innerClassesByObf.values()) { |
| 361 | buf.append("\t"); | 366 | buf.append("\t"); |
| 362 | buf.append(classMapping.getObfName()); | 367 | buf.append(classMapping.getObfSimpleName()); |
| 363 | buf.append(" <-> "); | 368 | buf.append(" <-> "); |
| 364 | buf.append(classMapping.getDeobfName()); | 369 | buf.append(classMapping.getDeobfName()); |
| 365 | buf.append("\n"); | 370 | buf.append("\n"); |
| @@ -370,10 +375,10 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 370 | @Override | 375 | @Override |
| 371 | public int compareTo(ClassMapping other) { | 376 | public int compareTo(ClassMapping other) { |
| 372 | // sort by a, b, c, ... aa, ab, etc | 377 | // sort by a, b, c, ... aa, ab, etc |
| 373 | if (m_obfName.length() != other.m_obfName.length()) { | 378 | if (m_obfFullName.length() != other.m_obfFullName.length()) { |
| 374 | return m_obfName.length() - other.m_obfName.length(); | 379 | return m_obfFullName.length() - other.m_obfFullName.length(); |
| 375 | } | 380 | } |
| 376 | return m_obfName.compareTo(other.m_obfName); | 381 | return m_obfFullName.compareTo(other.m_obfFullName); |
| 377 | } | 382 | } |
| 378 | 383 | ||
| 379 | public boolean renameObfClass(String oldObfClassName, String newObfClassName) { | 384 | public boolean renameObfClass(String oldObfClassName, String newObfClassName) { |
| @@ -399,9 +404,9 @@ public class ClassMapping implements Serializable, Comparable<ClassMapping> { | |||
| 399 | } | 404 | } |
| 400 | } | 405 | } |
| 401 | 406 | ||
| 402 | if (m_obfName.equals(oldObfClassName)) { | 407 | if (m_obfFullName.equals(oldObfClassName)) { |
| 403 | // rename this class | 408 | // rename this class |
| 404 | m_obfName = newObfClassName; | 409 | m_obfFullName = newObfClassName; |
| 405 | return true; | 410 | return true; |
| 406 | } | 411 | } |
| 407 | return false; | 412 | return false; |