An automatic content loader for Fabric mods.
In order to use Lodestone directly, please ensure that you add it as a dependency for your mod. This mod does not add any content by itself.
Lodestone provides basic interfaces and APIs for easily registering modded content during initialization. The most
important type provided is the Loaded
interface, which the mod is built around. For a basic example, see the
basic test mod.
To create an automatically registered type, simply implement the target environment's associated interface.
/** An item that is loaded at runtime. */
public class LoadedItem extends Item implements CommonLoaded {
// Required for all instances of `Loaded`. Allows Lodestone to group registered values by mod identifier.
@Override
public Identifier getLoaderId() {
return Identifier.of(YourMod.MOD_ID, "your_item");
}
// A function that registers the value at runtime.
@Override
public void loadCommon() {
Registry.register(Registries.ITEM, this.getLoaderId(), this);
}
}
Each mod environment has its own dedicated interface:
CommonLoaded
loads the value on the "common" environment, meaning both the client and the server.ClientLoaded
only loads the value on the client instance.ServerLoaded
only loads the value on the server instance.DataGenerating
only loads the value during Fabric's data generation task.
These are intended to be used within each mod initializer to load it properly.
public class YourMod implements ModInitializer {
public static final String MOD_ID = "your_mod";
public static final LoadedItem YOUR_ITEM = new LoadedItem(new Settings());
@Override
public void onInitialize() {
// Registers this item for later loading.
Lodestone.register(CommonLoaded.class, YOUR_ITEM);
// Which is then done here.
Lodestone.load(CommonLoaded.class, MOD_ID);
}
}
Lodestone also provides an abstract class and two annotations for automatic registration of values.
public final class ItemLoader extends AutoLoader {
@LoadingPriority(-1) // Controls the loading order. In this case, this loads last.
public static final LoadedItem ITEM_1 = new LoadedItem("item_1", new Settings());
public static final LoadedItem ITEM_2 = new LoadedItem("item_2", new Settings());
public static final LoadedItem ITEM_3 = new LoadedItem("item_3", new Settings());
public static final LoadedItem ITEM_4 = new LoadedItem("item_4", new Settings());
public static final LoadedItem ITEM_5 = new LoadedItem("item_5", new Settings());
@IgnoreLoading({ }) // Prevents this value from being loaded.
public static final LoadedItem NULL = null;
@Override
public Identifier getLoaderId() {
return Identifier.of(YourMod.MOD_ID, "items");
}
}
This is then registered in a very similar way.
public class YourMod implements ModInitializer {
public static final String MOD_ID = "your_mod";
public static final ItemLoader ITEMS = new ItemLoader();
@Override
public void onInitialize() {
// Registers all items for later loading.
ITEMS.register();
// Which is then done here.
Lodestone.load(CommonLoaded.class, MOD_ID);
}
}
Lodestone's most up-to-date JAR file may be downloaded from its GitHub Releases page. This mod is also be available on Modrinth, if that is preferred.
Once downloaded, the JAR file must be placed within your client's mods
directory, and the game should be run using
the Fabric Loader.
Alternatively, you may build Lodestone from its source code by running the following commands in order. To build from Lodestone's source code, you must have both Java 21 and Git installed.
git clone https://github.com/Jaxydog/Lodestone.git
cd ./Lodestone/
./gradlew build
The compiled JAR files will be located within the ./build/libs/
directory.
Lodestone's sole purpose is to be used as a library for other mods. If you would like to depend on Lodestone for your Fabric mod, add the following to your Gradle manifest:
# gradle.properties
lodestone_version = 1.6.1
// build.gradle
repositories {
maven { url 'https://jitpack.io' }
}
dependencies {
modImplementation "com.github.Jaxydog:Lodestone:${project.lodestone_version}"
// Or, to alternatively depend on the most recent commit:
modImplementation 'com.github.Jaxydog:Lodestone:main-SNAPSHOT'
}
Lodestone should work with many older versions of Minecraft, but only the latest game version is guaranteed to have proper support. I am currently not interested in backporting to versions prior to roughly 1.18, but if you encounter any issues feel free to let me know anyway.
Contributions are always welcome! If you're interested in helping development, please read this project's Contribution Guidelines. If you ever need help, feel free to contact me here or on Discord, and I'll do my best to aid you.
Lodestone is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
Lodestone is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along with Lodestone (located within LICENSE). If not, see <https://www.gnu.org/licenses/>.