Skip to content

A Mixin loader designed for maximum compatibility. (1.7.10~1.12.2)

License

Notifications You must be signed in to change notification settings

FIXxp/UniMixins

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

downloads builds CurseForge modrinth Discord

UniMixins

UniMixins is a Mixin loader for Minecraft 1.7.10 (with partial 1.8.9~1.12.2 support) designed for maximum compatibility. It aims to combine the features of as many mixin loaders as possible, and its modular nature makes it possible to use along other loaders if desired.

Background

Numerous Mixin loaders exist for 1.7.10, and each one provides a differing set of extra features we refer to as "extras" on top of providing Mixin.

Since each of these loaders is monolithic, different ones cannot be used at the same time due to unavoidable feature overlap. To avoid this problem, UniMixins offers each feature as a separate module (but a combined jar is still provided for convenience.)

Comparison table

Below is a table comparing the feature sets of known Mixin loaders.

Note: A more detailed version of this table is available here.

  • [NOP]: Does not do anything. (issue)
  • [SEP]: Is available as a separate mod.

Usage

Download the -all jar, and put it in your mods directory. Remove any other conflicting Mixin loaders (refer to the above table).

Note: It's important for the jar to be named so that it comes first alphabetically, to avoid a sorting issue with mods that embed Mixin. This is why the jar starts with a + character. You may need to change this to a ! character if you encounter issues with renamed jars.

For reference, here is the sorting order of some notable characters: ! < + < 0 < [ < _ < a

Advanced usage

You can also assemble your own combination of modules using the module jars. Some modules depend on other modules, see the List of modules section.

Assuming no other Mixin loaders are present, you will generally want the following modules:

  • Mixin (any single fork)
  • Compat and Mixingasm (optional but highly recommended)
  • Modules providing any extras you need

The game will crash if modules are missing dependencies. This can be disabled in the config.

Developer usage

See docs/developer-usage.md to see how to migrate an existing build script to depend on UniMixins.

List of modules

All modules depend on the Mixin module. Note that the dependents don't necessarily have to come from UniMixins modules, other mods may also be used to provide them.

Included in all-jar

  • Mixin (UniMix): Provides a Mixin fork maintained by the UniMixins developers, based on the Fabric fork.
  • SpongeMixins [1.7.10 only]: Provides an emulation of SpongeMixins's extras.
  • MixinBooterLegacy [1.7.10 only]: Provides an emulation of MixinBooterLegacy's extras, and a relocated MixinExtras.
  • MixinExtras: Provides MixinExtras.
  • GasStation [1.7.10 only]: Provides an emulation of GasStation's extras.
    • Depends on SpongeMixins.
    • Depends on MixinBooterLegacy.
    • Depends on MixinExtras
  • GTNHMixins [1.7.10 only]: Provides an emulation of GTNHMixins's extras, and a relocated MixinExtras.
    • Depends on SpongeMixins.
  • Compat: Various compatibility tweaks:
    • Remaps invalid references to Mixin classes (specifically the shaded ASM) in mods.
    • Adds information about mixins to crash reports. [1.7.10 only]
    • Adds a stub that allows loading 1.7.10 FML plugins on 1.8+. Needed to run the mod on 1.8+.
  • Mixingasm: Improves Mixin's compatibility with ASM transformers.

Optional

  • DevCompat [1.7.10 only]: Unsafe compatibility tweaks intended to only be used in dev environments. Not needed if using UniMix or GTNH's Mixin fork.

Very Optional

These are not included in releases, they mainly exist for testing purposes. (Note: You can only use a single Mixin module at the same time.)

FAQ

Why another mixin loader? Haven't you seen that one xkcd strip?

There is currently far too much fragmentation among Mixin loaders on 1.7.10, with different mods requiring different incompatible loaders. This is partly due to conflicts between their developers, and partly because of technical reasons (the loaders are designed in a monolithic way, which invites incompatibility.) This project has neither of those issues.

Why are you using the Fabric fork of Mixin? Isn't this a Forge mod?

The Fabric fork of Mixin is more actively maintained than the upstream fork, and has some extra fixes. Most of the Fabric fork's changes are not Fabric-specific.

What do the "extras" do anyway?

  • SpongeMixins, Grimoire, MixinBooterLegacy, GasStation and GTNHMixins offer various ways to let you mix into the classes of non-coremods (something Mixin does not natively support.)
  • Mixingasm fixes a Mixin issue that breaks some ASM transformers due to Mixin altering how they are called.
  • MixinExtras adds new Mixin features that mods can use to write less intrusive mixins.

Mixin? mixin? SpongeMixins? SpongePowered? What's the difference?

  • Mixin: a Java library that lets you transform Java classes in a fluent way.
  • SpongePowered: the organization that created Mixin (who also developed a modding API called Sponge.)
  • mixin: a special Java class defining a "change" that should be applied to a class. These get applied by Mixin.
  • SpongeMixins: a Mixin loader created by TimeConqueror that has a very generic name.

Contributing

When editing the source code of modules, please document your changes in the module's CREDITS file. This allows people to easily see what we have changed, and lets other developers know what changes they have to keep in mind when syncing with upstream.

Useful commands

  • ./gradlew module-XXX:build: builds the module named XXX

Build flags

  • -Plocal: use the locally built version of unimix when building the Mixin module.
    • Invoke ./gradlew publishToMavenLocal in the UniMix repo first to install a local build.
  • -PnoAltMixin: do not build alternate flavors of the Mixin module, only UniMix. Used by the release workflow.

Roadmap

A rough roadmap of the project is available here.

Test cases

See docs/testing.md for a list of mods we have used to test the functionality of various UniMixins modules.

License

UniMixins is licensed under the Unlicense, with the exception of some modules. See LICENSE for the full details.

About

A Mixin loader designed for maximum compatibility. (1.7.10~1.12.2)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 95.7%
  • Python 3.8%
  • Shell 0.5%