diff options
| author | 2018-07-17 19:14:08 +0200 | |
|---|---|---|
| committer | 2018-07-17 19:14:08 +0200 | |
| commit | a88175ffc95792b88a8724f66db6dda2b8cc32ee (patch) | |
| tree | 65895bbc6cf1766f4ca01e1257619ab1993e71dc /src/main/java/cuchaz/enigma/analysis/EntryReference.java | |
| parent | Merge pull request #3 from thiakil/src-jar (diff) | |
| download | enigma-fork-a88175ffc95792b88a8724f66db6dda2b8cc32ee.tar.gz enigma-fork-a88175ffc95792b88a8724f66db6dda2b8cc32ee.tar.xz enigma-fork-a88175ffc95792b88a8724f66db6dda2b8cc32ee.zip | |
ASM Based Class Translator (#1)
* Initial port to ASM
* Package updates
* Annotation + inner class translation
* Fix inner class mapping
* More bytecode translation
* Signature refactoring
* Fix highlighting of mapped names
* Fix parameter name offset
* Fix anonymous class generation
* Fix issues with inner class signature transformation
* Fix bridged method detection
* Fix compile issues
* Resolve all failed tests
* Apply deobfuscated name to transformed classes
* Fix class signatures not being translated
* Fix frame array type translation
* Fix frame array type translation
* Fix array translation in method calls
* Fix method reference and bridge detection
* Fix handling of null deobf mappings
* Parameter translation in interfaces
* Fix enum parameter index offset
* Fix parsed local variable indexing
* Fix stackoverflow on rebuilding method names
* Ignore invalid decompiled variable indices
* basic source jar
* Output directly to file on source export
* Make decompile parallel
* fix incorrect super calls
* Use previous save state to delete old mapping files
* Fix old mappings not properly being removed
* Fix old mappings not properly being removed
* make isMethodProvider public
(cherry picked from commit ebad6a9)
* speed up Deobfuscator's getSources by using a single TranslatingTypeloader and caching the ClassLoaderTypeloader
* ignore .idea project folders
* move SynchronizedTypeLoader to a non-inner
* fix signature remap of inners for now
* index & resolve method/field references for usages view
* Allow reader/writer subclasses to provide the underlying file operations
* fix giving obf classes a name not removing them from the panel
* buffer the ParsedJar class entry inputstream, allow use with a jarinputstream
* make CachingClasspathTypeLoader public
* make CachingClasspathTypeLoader public
* support enum switches with obfuscated SwitchMaps
Diffstat (limited to 'src/main/java/cuchaz/enigma/analysis/EntryReference.java')
| -rw-r--r-- | src/main/java/cuchaz/enigma/analysis/EntryReference.java | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/src/main/java/cuchaz/enigma/analysis/EntryReference.java b/src/main/java/cuchaz/enigma/analysis/EntryReference.java index 3761fca..101729d 100644 --- a/src/main/java/cuchaz/enigma/analysis/EntryReference.java +++ b/src/main/java/cuchaz/enigma/analysis/EntryReference.java | |||
| @@ -11,9 +11,9 @@ | |||
| 11 | 11 | ||
| 12 | package cuchaz.enigma.analysis; | 12 | package cuchaz.enigma.analysis; |
| 13 | 13 | ||
| 14 | import cuchaz.enigma.mapping.ClassEntry; | 14 | import cuchaz.enigma.mapping.entry.ClassEntry; |
| 15 | import cuchaz.enigma.mapping.ConstructorEntry; | 15 | import cuchaz.enigma.mapping.entry.Entry; |
| 16 | import cuchaz.enigma.mapping.Entry; | 16 | import cuchaz.enigma.mapping.entry.MethodEntry; |
| 17 | import cuchaz.enigma.utils.Utils; | 17 | import cuchaz.enigma.utils.Utils; |
| 18 | 18 | ||
| 19 | import java.util.Arrays; | 19 | import java.util.Arrays; |
| @@ -21,7 +21,7 @@ import java.util.List; | |||
| 21 | 21 | ||
| 22 | public class EntryReference<E extends Entry, C extends Entry> { | 22 | public class EntryReference<E extends Entry, C extends Entry> { |
| 23 | 23 | ||
| 24 | private static final List<String> ConstructorNonNames = Arrays.asList("this", "super", "static"); | 24 | private static final List<String> CONSTRUCTOR_NON_NAMES = Arrays.asList("this", "super", "static"); |
| 25 | public E entry; | 25 | public E entry; |
| 26 | public C context; | 26 | public C context; |
| 27 | 27 | ||
| @@ -40,7 +40,7 @@ public class EntryReference<E extends Entry, C extends Entry> { | |||
| 40 | this.context = context; | 40 | this.context = context; |
| 41 | 41 | ||
| 42 | this.sourceName = sourceName != null && !sourceName.isEmpty(); | 42 | this.sourceName = sourceName != null && !sourceName.isEmpty(); |
| 43 | if (entry instanceof ConstructorEntry && ConstructorNonNames.contains(sourceName)) { | 43 | if (entry instanceof MethodEntry && ((MethodEntry) entry).isConstructor() && CONSTRUCTOR_NON_NAMES.contains(sourceName)) { |
| 44 | this.sourceName = false; | 44 | this.sourceName = false; |
| 45 | } | 45 | } |
| 46 | } | 46 | } |
| @@ -53,9 +53,9 @@ public class EntryReference<E extends Entry, C extends Entry> { | |||
| 53 | 53 | ||
| 54 | public ClassEntry getLocationClassEntry() { | 54 | public ClassEntry getLocationClassEntry() { |
| 55 | if (context != null) { | 55 | if (context != null) { |
| 56 | return context.getClassEntry(); | 56 | return context.getOwnerClassEntry(); |
| 57 | } | 57 | } |
| 58 | return entry.getClassEntry(); | 58 | return entry.getOwnerClassEntry(); |
| 59 | } | 59 | } |
| 60 | 60 | ||
| 61 | public boolean isNamed() { | 61 | public boolean isNamed() { |
| @@ -63,9 +63,9 @@ public class EntryReference<E extends Entry, C extends Entry> { | |||
| 63 | } | 63 | } |
| 64 | 64 | ||
| 65 | public Entry getNameableEntry() { | 65 | public Entry getNameableEntry() { |
| 66 | if (entry instanceof ConstructorEntry) { | 66 | if (entry instanceof MethodEntry && ((MethodEntry) entry).isConstructor()) { |
| 67 | // renaming a constructor really means renaming the class | 67 | // renaming a constructor really means renaming the class |
| 68 | return entry.getClassEntry(); | 68 | return entry.getOwnerClassEntry(); |
| 69 | } | 69 | } |
| 70 | return entry; | 70 | return entry; |
| 71 | } | 71 | } |