diff options
| author | 2019-08-26 00:55:44 -0400 | |
|---|---|---|
| committer | 2019-08-26 06:55:44 +0200 | |
| commit | c31b70da2f88c41936a3fd7d69f445ef1db6548d (patch) | |
| tree | 3c8d419f8d895a8345464c43c0dac315764e8a30 /src/main/java/cuchaz/enigma/ProposingTranslator.java | |
| parent | Put class opening brace on same line (#160) (diff) | |
| download | enigma-fork-c31b70da2f88c41936a3fd7d69f445ef1db6548d.tar.gz enigma-fork-c31b70da2f88c41936a3fd7d69f445ef1db6548d.tar.xz enigma-fork-c31b70da2f88c41936a3fd7d69f445ef1db6548d.zip | |
Use name proposal service when exporting deobfuscated jar or decompiled sources (#159)
Diffstat (limited to 'src/main/java/cuchaz/enigma/ProposingTranslator.java')
| -rw-r--r-- | src/main/java/cuchaz/enigma/ProposingTranslator.java | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/src/main/java/cuchaz/enigma/ProposingTranslator.java b/src/main/java/cuchaz/enigma/ProposingTranslator.java new file mode 100644 index 0000000..0807880 --- /dev/null +++ b/src/main/java/cuchaz/enigma/ProposingTranslator.java | |||
| @@ -0,0 +1,43 @@ | |||
| 1 | package cuchaz.enigma; | ||
| 2 | |||
| 3 | import cuchaz.enigma.api.service.NameProposalService; | ||
| 4 | import cuchaz.enigma.translation.Translatable; | ||
| 5 | import cuchaz.enigma.translation.Translator; | ||
| 6 | import cuchaz.enigma.translation.mapping.*; | ||
| 7 | import cuchaz.enigma.translation.representation.entry.Entry; | ||
| 8 | |||
| 9 | import java.util.Optional; | ||
| 10 | |||
| 11 | public class ProposingTranslator implements Translator { | ||
| 12 | private final EntryRemapper mapper; | ||
| 13 | private final NameProposalService nameProposalService; | ||
| 14 | |||
| 15 | public ProposingTranslator(EntryRemapper mapper, NameProposalService nameProposalService) { | ||
| 16 | this.mapper = mapper; | ||
| 17 | this.nameProposalService = nameProposalService; | ||
| 18 | } | ||
| 19 | |||
| 20 | @Override | ||
| 21 | @SuppressWarnings("unchecked") | ||
| 22 | public <T extends Translatable> T translate(T translatable) { | ||
| 23 | if (translatable == null) { | ||
| 24 | return null; | ||
| 25 | } | ||
| 26 | |||
| 27 | T deobfuscated = mapper.deobfuscate(translatable); | ||
| 28 | |||
| 29 | if (translatable instanceof Entry && ((Entry) deobfuscated).getName().equals(((Entry<?>) translatable).getName())) { | ||
| 30 | return mapper.getObfResolver() | ||
| 31 | .resolveEntry((Entry<?>) translatable, ResolutionStrategy.RESOLVE_ROOT) | ||
| 32 | .stream() | ||
| 33 | .map(e1 -> nameProposalService.proposeName(e1, mapper)) | ||
| 34 | .filter(Optional::isPresent) | ||
| 35 | .map(Optional::get) | ||
| 36 | .findFirst() | ||
| 37 | .map(newName -> (T) ((Entry) deobfuscated).withName(newName)) | ||
| 38 | .orElse(deobfuscated); | ||
| 39 | } | ||
| 40 | |||
| 41 | return deobfuscated; | ||
| 42 | } | ||
| 43 | } | ||