diff options
author | Aaron <51387595+AzureAaron@users.noreply.github.com> | 2023-10-20 19:28:02 -0400 |
---|---|---|
committer | Aaron <51387595+AzureAaron@users.noreply.github.com> | 2023-10-20 19:28:02 -0400 |
commit | 99a538292ac344aa9fd6087a2752e20563bf310c (patch) | |
tree | 498874667851b47ed5e10d735568fb31eb0e3b7f /src/main/java/de/hysky/skyblocker/compatibility/MixinPlugin.java | |
parent | e3177643df14bc08cd4544eed85898c723f02b4f (diff) | |
download | Skyblocker-99a538292ac344aa9fd6087a2752e20563bf310c.tar.gz Skyblocker-99a538292ac344aa9fd6087a2752e20563bf310c.tar.bz2 Skyblocker-99a538292ac344aa9fd6087a2752e20563bf310c.zip |
Patch Float/Double Field Controller Bug
Diffstat (limited to 'src/main/java/de/hysky/skyblocker/compatibility/MixinPlugin.java')
-rw-r--r-- | src/main/java/de/hysky/skyblocker/compatibility/MixinPlugin.java | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/src/main/java/de/hysky/skyblocker/compatibility/MixinPlugin.java b/src/main/java/de/hysky/skyblocker/compatibility/MixinPlugin.java index c7fc6973..145f7ec4 100644 --- a/src/main/java/de/hysky/skyblocker/compatibility/MixinPlugin.java +++ b/src/main/java/de/hysky/skyblocker/compatibility/MixinPlugin.java @@ -4,13 +4,17 @@ import java.util.List; import java.util.Set; import org.objectweb.asm.tree.ClassNode; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import org.spongepowered.asm.mixin.extensibility.IMixinConfigPlugin; import org.spongepowered.asm.mixin.extensibility.IMixinInfo; import net.fabricmc.loader.api.FabricLoader; public class MixinPlugin implements IMixinConfigPlugin { + private static final Logger LOGGER = LoggerFactory.getLogger(MixinPlugin.class); private static final boolean OPTIFABRIC_LOADED = FabricLoader.getInstance().isModLoaded("optifabric"); + private static final String YACL_VERSION = FabricLoader.getInstance().getModContainer("yet_another_config_lib_v3").get().getMetadata().getVersion().getFriendlyString(); @Override public void onLoad(String mixinPackage) { @@ -26,6 +30,17 @@ public class MixinPlugin implements IMixinConfigPlugin { public boolean shouldApplyMixin(String targetClassName, String mixinClassName) { //OptiFabric Compatibility if (mixinClassName.endsWith("WorldRendererMixin") && OPTIFABRIC_LOADED) return false; + + //YACL#103 Patch + if (mixinClassName.endsWith("DoubleFieldControllerMixin") || mixinClassName.endsWith("FloatFieldControllerMixin") || mixinClassName.endsWith("IntegerFieldControllerMixin") || mixinClassName.endsWith("LongFieldControllerMixin") || mixinClassName.endsWith("NumberFieldControllerMixin")) { + if (YACL_VERSION.equals("3.2.1+1.20.2")) { + LOGGER.info("[Skyblocker] Applying patch for " + targetClassName + " from " + mixinClassName); + } else { + LOGGER.info("[Skyblocker] Skipping patch on " + targetClassName + " due to an Unknown YACL version being found! Version: {}", YACL_VERSION); + + return false; + } + } return true; } |