diff options
Diffstat (limited to 'src/main/java/cuchaz/enigma/bytecode')
| -rw-r--r-- | src/main/java/cuchaz/enigma/bytecode/translators/TranslationClassVisitor.java | 25 |
1 files changed, 11 insertions, 14 deletions
diff --git a/src/main/java/cuchaz/enigma/bytecode/translators/TranslationClassVisitor.java b/src/main/java/cuchaz/enigma/bytecode/translators/TranslationClassVisitor.java index 5fdfaf1..dcc221e 100644 --- a/src/main/java/cuchaz/enigma/bytecode/translators/TranslationClassVisitor.java +++ b/src/main/java/cuchaz/enigma/bytecode/translators/TranslationClassVisitor.java | |||
| @@ -13,7 +13,9 @@ package cuchaz.enigma.bytecode.translators; | |||
| 13 | 13 | ||
| 14 | import cuchaz.enigma.analysis.JarIndex; | 14 | import cuchaz.enigma.analysis.JarIndex; |
| 15 | import cuchaz.enigma.bytecode.AccessFlags; | 15 | import cuchaz.enigma.bytecode.AccessFlags; |
| 16 | import cuchaz.enigma.mapping.*; | 16 | import cuchaz.enigma.mapping.MethodDescriptor; |
| 17 | import cuchaz.enigma.mapping.Translator; | ||
| 18 | import cuchaz.enigma.mapping.TypeDescriptor; | ||
| 17 | import cuchaz.enigma.mapping.entry.*; | 19 | import cuchaz.enigma.mapping.entry.*; |
| 18 | import org.objectweb.asm.*; | 20 | import org.objectweb.asm.*; |
| 19 | 21 | ||
| @@ -101,18 +103,13 @@ public class TranslationClassVisitor extends ClassVisitor { | |||
| 101 | 103 | ||
| 102 | @Override | 104 | @Override |
| 103 | public void visitInnerClass(String name, String outerName, String innerName, int access) { | 105 | public void visitInnerClass(String name, String outerName, String innerName, int access) { |
| 104 | // If this is not an anonymous class | 106 | ClassDefEntry translatedEntry = translator.getTranslatedClassDef(new ClassDefEntry(name, new AccessFlags(access))); |
| 105 | if (innerName != null && outerName != null) { | 107 | String translatedName = translatedEntry.getName(); |
| 106 | ClassDefEntry translatedEntry = translator.getTranslatedClassDef(new ClassDefEntry(innerName, new AccessFlags(access))); | 108 | int separatorIndex = translatedName.lastIndexOf("$"); |
| 107 | ClassEntry outerEntry = translator.getTranslatedClass(entryPool.getClass(outerName)); | 109 | String parentName = translatedName.substring(0, separatorIndex); |
| 108 | ClassEntry innerEntry = translator.getTranslatedClass(entryPool.getClass(innerName)); | 110 | String childName = translatedName.substring(separatorIndex + 1); |
| 109 | super.visitInnerClass(translatedEntry.getName(), outerEntry.getName(), innerEntry.getName(), translatedEntry.getAccess().getFlags()); | 111 | |
| 110 | } else { | 112 | ClassEntry outerEntry = translator.getTranslatedClass(entryPool.getClass(parentName)); |
| 111 | int separatorIndex = name.lastIndexOf("$"); | 113 | super.visitInnerClass(translatedName, outerEntry.getName(), childName, translatedEntry.getAccess().getFlags()); |
| 112 | String parentName = name.substring(0, separatorIndex); | ||
| 113 | String childName = name.substring(separatorIndex + 1); | ||
| 114 | ClassEntry outerEntry = translator.getTranslatedClass(entryPool.getClass(parentName)); | ||
| 115 | super.visitInnerClass(outerEntry.getName() + "$" + childName, outerName, innerName, access); | ||
| 116 | } | ||
| 117 | } | 114 | } |
| 118 | } | 115 | } |