All Downloads are FREE. Search and download functionalities are using the official Maven repository.

personthecat.catlib.event.registry.RegistryAddedEvent Maven / Gradle / Ivy

package personthecat.catlib.event.registry;

import dev.architectury.injectables.annotations.ExpectPlatform;
import net.minecraft.class_2378;
import net.minecraft.class_5321;
import net.minecraft.class_5455;
import org.jetbrains.annotations.ApiStatus;
import personthecat.catlib.event.LibEvent;
import personthecat.catlib.exception.MissingOverrideException;
import personthecat.catlib.exception.RegistryLookupException;
import personthecat.catlib.registry.RegistryHandle;

public class RegistryAddedEvent {

    /**
     * Exposes the currently-available {@link RegistryAddedEvent} for a registry of the given type.
     * This event will fire any time an object is registered to this registry.
     *
     * 

Note that on the Forge platform, this event exposes a {@link RegistryHandle} which can * either be a {@link class_2378 Mojang registry} or a Forge registry. The registry handle does * allow new elements to be registered, which is guaranteed to succeed on the Forge platform * due to when this event is fired. * *

Also note that the majority of objects in this registry have likely already been registered. * For this reason, you may prefer to leverage the {@link #withRetroactive} method, which will * fire immediately for each object already in the registry. * *

Finally, you should be aware that this event will fire for a single, builtin registry only. * This means that dynamic registries will not be covered. If you wish to register additional * callbacks to the dynamic registries, use {@link #withDynamic} instead. * * @throws RegistryLookupException If no registry is found. * @param key The key of the registry which this event corresponds to. * @param The type of object in the registry. * @return A callback registrar for this registry. */ @ExpectPlatform public static LibEvent> get(final class_5321> key) { throw new MissingOverrideException(); } /** * This method registers a {@link RegistryAddedCallback} for a registry of the given type. * Unlike {@link #get}, this method will also fire the callback for every object already * contained within the registry. * *

On the Forge platform, this means the registry will be forcibly unfrozen temporarily. * Realistically speaking, this is a safe operation unless the Forge registry events have * already fired. In that case, additional registry entries will simply have no effect. * *

Note that dynamic registries are not covered by this event. * * @throws RegistryLookupException If no registry is found. * @param key The key of the registry which this event corresponds to. * @param f The callback to fire in for every element in the registry. * @param The type of object in the registry. */ @ExpectPlatform public static void withRetroactive(final class_5321> key, final RegistryAddedCallback f) { throw new MissingOverrideException(); } /** * This method registers a {@link RegistryAddedCallback} for a registry of the given type. * Unlike {@link #get}, this method will also fire the callback for every object in a * corresponding dynamic registry of the given type. It will fire every time the * dynamic registries are loaded. * *

Note that any objects already contained within the registry will not be covered by * this event. * * @throws RegistryLookupException If no active registry is found. * @throws IllegalStateException If a dynamic registry is not found on {@link RegistryAccessEvent}. * @param key The key of the registry which this event corresponds to. * @param f The callback to fire in for every element in the registry. * @param The type of object in the registry. */ @ExpectPlatform public static void withDynamic(final class_5321> key, final RegistryAddedCallback f) { throw new MissingOverrideException(); } /** * This method registers a {@link RegistryAddedCallback} for a registry of the given type. * Unlike {@link #get}, {@link #withRetroactive}, and {@link #withDynamic}, this callback * will fire all objects already in the registry and all objects in the dynamic registries. * * @throws RegistryLookupException If no active registry is found. * @throws IllegalStateException If a dynamic registry is not found on {@link RegistryAccessEvent}. * @param key The key of the registry which this event corresponds to. * @param f The callback to fire in for every element in the registry. * @param The type of object in the registry. */ @ExpectPlatform public static void exhaustive(final class_5321> key, final RegistryAddedCallback f) { throw new MissingOverrideException(); } /** * Runs any platform-specific setup required on {@link RegistryAccessEvent}. * * @param access The dynamic registries after data packs are loaded. */ @ExpectPlatform @ApiStatus.Internal public static void onRegistryAccess(final class_5455 access) { throw new MissingOverrideException(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy