A library to enable/disable mixins using annotations.
Annotations can be applied to mixin classes to toggle the whole mixin, or individual fields/methods for more precision.
MixinConstraints is available through Maven Central.
Gradle
dependencies {
include(implementation("com.moulberry:mixinconstraints:1.0.2"))
}
Next, you will need to bootstrap the library to affect your mixins.
The easiest way to do so is by using the provided Mixin Plugin by adding the following to your modid.mixins.json:
{
"plugin": "com.moulberry.mixinconstraints.ConstraintsMixinPlugin",
}
If you already have your own mixin plugin, you can use the ConstraintsMixinPlugin class as a reference to add support.
The library provides 4 annotations
- @IfModLoaded (checks if a mod is loaded)
- @IfModAbsent (checks if a mod is absent)
- @IfMinecraftVersion (checks if the Minecraft version matches a range)
- @IfDevEnvironment (checks if the game is running inside a development environment)
These annotations can be applied to classes to control whether the whole mixin is applied
For example, the following mixin will only be applied if sodium or embeddium is present
@IfModLoaded(value = "sodium", aliases = {"embeddium"})
@Mixin(BlockOcclusionCache.class)
public class MixinSodiumBlockOcclusionCache {
...
}
Additionally, the annotations can also be applied to individual fields/methods
For example, the following mixin will inject only one of the two methods depending on whether the mod is in a dev environment
@Mixin(Minecraft.class)
public class MixinMinecraft {
@IfDevEnvironment
@Inject(at = @At("HEAD"), method = "run")
private void runDev(CallbackInfo info) {
System.out.println("Hello from a dev environment!");
}
@IfDevEnvironment(negate = true)
@Inject(at = @At("HEAD"), method = "run")
private void runProd(CallbackInfo info) {
System.out.println("Hello from production!");
}
}
Some constraints support version ranges, which can be used like so:
@IfModLoaded(value = "modernfix", minVersion = "5.11", maxVersion = "5.15")
The version comparison uses Fabric API's Version. Ensure the version resembles a semver string in order for range comparison to work as expected.
The library is available under the MIT license.