Package net.minecraftforge.registries
Class ObjectHolderRegistry
java.lang.Object
net.minecraftforge.registries.ObjectHolderRegistry
Internal registry for tracking 
ObjectHolder references- 
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprivate static final record - 
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final org.apache.logging.log4j.Loggerprivate static final org.objectweb.asm.Typeprivate static final org.objectweb.asm.Typeprivate static final Set<Consumer<Predicate<ResourceLocation>>>private static final List<ObjectHolderRegistry.VanillaObjectHolderData> - 
Constructor Summary
Constructors - 
Method Summary
Modifier and TypeMethodDescriptionstatic voidExposed to allow modders to register their own notification handlers.static voidstatic voidapplyObjectHolders(Predicate<ResourceLocation> filter) static voidprivate static ResourceLocationgetRegistryName(Map<org.objectweb.asm.Type, ResourceLocation> classRegistryNames, @Nullable String registryName, org.objectweb.asm.Type targetClass, Object declaration) static booleanRemoved the specified handler from the notification list.private static voidscanClassForFields(Map<org.objectweb.asm.Type, String> classModIds, org.objectweb.asm.Type targetClass, ResourceLocation registryName, Class<?> registryClass, String value, Class<?> clazz, boolean extractFromExistingValues) private static voidscanTarget(Map<org.objectweb.asm.Type, String> classModIds, Map<org.objectweb.asm.Type, Class<?>> classCache, org.objectweb.asm.Type type, @Nullable String annotationTarget, @Nullable Class<?> registryClass, String registryName, String value, boolean isClass, boolean extractFromValue)  
- 
Field Details
- 
LOGGER
private static final org.apache.logging.log4j.Logger LOGGER - 
objectHolders
 - 
OBJECT_HOLDER
private static final org.objectweb.asm.Type OBJECT_HOLDER - 
MOD
private static final org.objectweb.asm.Type MOD - 
VANILLA_OBJECT_HOLDERS
 
 - 
 - 
Constructor Details
- 
ObjectHolderRegistry
public ObjectHolderRegistry() 
 - 
 - 
Method Details
- 
addHandler
Exposed to allow modders to register their own notification handlers. This runnable will be called after a registry snapshot has been injected and finalized. The internal list is backed by a HashSet so it is HIGHLY recommended you implement a proper equals and hashCode function to de-duplicate callers here. The default @ObjectHolder implementation uses the hashCode/equals for the field the annotation is on. - 
removeHandler
Removed the specified handler from the notification list. The internal list is backed by a hash set, and so proper hashCode and equals operations are required for success. The default @ObjectHolder implementation uses the hashCode/equals for the field the annotation is on.- Returns:
 - true if handler was matched and removed.
 
 - 
findObjectHolders
public static void findObjectHolders() - 
scanTarget
private static void scanTarget(Map<org.objectweb.asm.Type, String> classModIds, Map<org.objectweb.asm.Type, Class<?>> classCache, org.objectweb.asm.Type type, @Nullable @Nullable String annotationTarget, @Nullable @Nullable Class<?> registryClass, String registryName, String value, boolean isClass, boolean extractFromValue)  - 
scanClassForFields
 - 
getRegistryName
private static ResourceLocation getRegistryName(Map<org.objectweb.asm.Type, ResourceLocation> classRegistryNames, @Nullable @Nullable String registryName, org.objectweb.asm.Type targetClass, Object declaration)  - 
applyObjectHolders
public static void applyObjectHolders() - 
applyObjectHolders
 
 -