From b9095bc631db5d499850c59981b3584a74871698 Mon Sep 17 00:00:00 2001 From: Rongmario Date: Tue, 31 Oct 2023 12:14:07 +0000 Subject: [PATCH] Rebuild delegated transformers - Brought to attention in LegacyModdingMC/UniMix#4 --- .../zone/rong/mixinbooter/mixin/LoadControllerMixin.java | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/src/main/java/zone/rong/mixinbooter/mixin/LoadControllerMixin.java b/src/main/java/zone/rong/mixinbooter/mixin/LoadControllerMixin.java index 02d7a2a..91b4058 100644 --- a/src/main/java/zone/rong/mixinbooter/mixin/LoadControllerMixin.java +++ b/src/main/java/zone/rong/mixinbooter/mixin/LoadControllerMixin.java @@ -12,10 +12,13 @@ import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; import org.spongepowered.asm.mixin.transformer.IMixinTransformer; import org.spongepowered.asm.mixin.transformer.Proxy; +import org.spongepowered.asm.service.MixinService; +import org.spongepowered.asm.service.mojang.MixinServiceLaunchWrapper; import zone.rong.mixinbooter.*; import zone.rong.mixinbooter.decorator.FMLContextQuery; import zone.rong.mixinbooter.fix.MixinFixer; +import java.lang.reflect.Field; import java.lang.reflect.Method; /** @@ -82,6 +85,11 @@ private void beforeConstructing(LoaderState state, Object[] eventData, CallbackI Mixins.addConfiguration(mixinConfig); } + // Rebuild delegated transformers + Field delegatedTransformersField = MixinServiceLaunchWrapper.class.getDeclaredField("delegatedTransformers"); + delegatedTransformersField.setAccessible(true); + delegatedTransformersField.set(MixinService.getService(), null); + IMixinProcessor processor = ((IMixinTransformer) Proxy.transformer).getProcessor(); Method selectMethod = processor.getClass().getDeclaredMethod("select", MixinEnvironment.class); selectMethod.setAccessible(true);