aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/de/hysky/skyblocker/compatibility/MixinPlugin.java
diff options
context:
space:
mode:
authorYasin <LifeIsAParadox@users.noreply.github.com>2023-10-21 11:42:59 +0200
committerGitHub <noreply@github.com>2023-10-21 11:42:59 +0200
commit5fcda4237f4171c77a89e73cac6bd9cd07a10b15 (patch)
tree7acf9d8f560e0c8899ad4ea7932398b66c21cc39 /src/main/java/de/hysky/skyblocker/compatibility/MixinPlugin.java
parentcb13f32c5ed304fa921358682b752a19451f5e0e (diff)
parent99a538292ac344aa9fd6087a2752e20563bf310c (diff)
downloadSkyblocker-5fcda4237f4171c77a89e73cac6bd9cd07a10b15.tar.gz
Skyblocker-5fcda4237f4171c77a89e73cac6bd9cd07a10b15.tar.bz2
Skyblocker-5fcda4237f4171c77a89e73cac6bd9cd07a10b15.zip
Merge pull request #377 from AzureAaron/new-prefix
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.java15
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;
}