aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/net/fabricmc/loom/decompilers/fernflower
diff options
context:
space:
mode:
authorshedaniel <daniel@shedaniel.me>2021-11-06 17:19:57 +0800
committershedaniel <daniel@shedaniel.me>2021-11-06 17:19:57 +0800
commitc412c1135474e7ec3db1ef8f9894113336b7c78f (patch)
treec664533cc80a73d93620476edc2f3528412aa2f9 /src/main/java/net/fabricmc/loom/decompilers/fernflower
parenta48989057d62dc573eb919d6cbbd1cabc471f5f1 (diff)
parentcb5c009e1a8978f86e1ce0a0f872ddc20686ae6d (diff)
downloadarchitectury-loom-c412c1135474e7ec3db1ef8f9894113336b7c78f.tar.gz
architectury-loom-c412c1135474e7ec3db1ef8f9894113336b7c78f.tar.bz2
architectury-loom-c412c1135474e7ec3db1ef8f9894113336b7c78f.zip
Merge remote-tracking branch 'FabricMC/dev/0.10' into dev/0.10.0
# Conflicts: # src/main/java/net/fabricmc/loom/api/LoomGradleExtensionAPI.java # src/main/java/net/fabricmc/loom/extension/MinecraftGradleExtension.java
Diffstat (limited to 'src/main/java/net/fabricmc/loom/decompilers/fernflower')
-rw-r--r--src/main/java/net/fabricmc/loom/decompilers/fernflower/FabricFernFlowerDecompiler.java23
1 files changed, 14 insertions, 9 deletions
diff --git a/src/main/java/net/fabricmc/loom/decompilers/fernflower/FabricFernFlowerDecompiler.java b/src/main/java/net/fabricmc/loom/decompilers/fernflower/FabricFernFlowerDecompiler.java
index c3009448..9ad8111e 100644
--- a/src/main/java/net/fabricmc/loom/decompilers/fernflower/FabricFernFlowerDecompiler.java
+++ b/src/main/java/net/fabricmc/loom/decompilers/fernflower/FabricFernFlowerDecompiler.java
@@ -25,6 +25,7 @@
package net.fabricmc.loom.decompilers.fernflower;
import java.nio.file.Path;
+import java.util.HashMap;
import java.util.Map;
import org.jetbrains.java.decompiler.main.Fernflower;
@@ -38,21 +39,25 @@ import net.fabricmc.loom.api.decompilers.LoomDecompiler;
public final class FabricFernFlowerDecompiler implements LoomDecompiler {
@Override
public String name() {
- return "FabricFlower"; // Or something else?
+ return "FernFlower";
}
@Override
public void decompile(Path compiledJar, Path sourcesDestination, Path linemapDestination, DecompilationMetadata metaData) {
- Map<String, Object> options = Map.of(
- IFernflowerPreferences.DECOMPILE_GENERIC_SIGNATURES, "1",
- IFernflowerPreferences.BYTECODE_SOURCE_MAPPING, "1",
- IFernflowerPreferences.REMOVE_SYNTHETIC, "1",
- IFernflowerPreferences.LOG_LEVEL, "trace",
- IFernflowerPreferences.THREADS, String.valueOf(metaData.numberOfThreads()),
- IFernflowerPreferences.INDENT_STRING, "\t",
- IFabricJavadocProvider.PROPERTY_NAME, new TinyJavadocProvider(metaData.javaDocs().toFile())
+ final Map<String, Object> options = new HashMap<>(
+ Map.of(
+ IFernflowerPreferences.DECOMPILE_GENERIC_SIGNATURES, "1",
+ IFernflowerPreferences.BYTECODE_SOURCE_MAPPING, "1",
+ IFernflowerPreferences.REMOVE_SYNTHETIC, "1",
+ IFernflowerPreferences.LOG_LEVEL, "trace",
+ IFernflowerPreferences.THREADS, String.valueOf(metaData.numberOfThreads()),
+ IFernflowerPreferences.INDENT_STRING, "\t",
+ IFabricJavadocProvider.PROPERTY_NAME, new TinyJavadocProvider(metaData.javaDocs().toFile())
+ )
);
+ options.putAll(metaData.options());
+
IResultSaver saver = new ThreadSafeResultSaver(sourcesDestination::toFile, linemapDestination::toFile);
Fernflower ff = new Fernflower(FernFlowerUtils::getBytecode, saver, options, new FernflowerLogger(metaData.logger()));