diff --git a/src/main/java/net/fabricmc/loader/impl/entrypoint/MixinLoadingEntrypoint.java b/src/main/java/net/fabricmc/loader/impl/entrypoint/MixinLoadingEntrypoint.java new file mode 100644 index 000000000..518ce36b4 --- /dev/null +++ b/src/main/java/net/fabricmc/loader/impl/entrypoint/MixinLoadingEntrypoint.java @@ -0,0 +1,6 @@ +package net.fabricmc.loader.impl.entrypoint; + +@FunctionalInterface +public interface MixinLoadingEntrypoint { + void onMixinLoading(); +} diff --git a/src/main/java/net/fabricmc/loader/impl/launch/knot/Knot.java b/src/main/java/net/fabricmc/loader/impl/launch/knot/Knot.java index 4e71b1451..b3d5540a3 100644 --- a/src/main/java/net/fabricmc/loader/impl/launch/knot/Knot.java +++ b/src/main/java/net/fabricmc/loader/impl/launch/knot/Knot.java @@ -38,6 +38,8 @@ import java.util.zip.ZipEntry; import java.util.zip.ZipFile; +import net.fabricmc.loader.impl.entrypoint.MixinLoadingEntrypoint; + import org.spongepowered.asm.launch.MixinBootstrap; import net.fabricmc.api.EnvType; @@ -128,8 +130,10 @@ protected ClassLoader init(String[] args) { loader.setGameProvider(provider); loader.load(); loader.freeze(); + loader.loadAccessWideners(); - FabricLoaderImpl.INSTANCE.loadAccessWideners(); + // Some mods has any API required for mixins. But they most-likely load it remotely, since its unused in any other place. + EntrypointUtils.invoke("onMixinLoading", MixinLoadingEntrypoint.class, MixinLoadingEntrypoint::onMixinLoading); MixinBootstrap.init(); FabricMixinBootstrap.init(getEnvironmentType(), loader);