Class RegistryObject<T>
- All Implemented Interfaces:
Supplier<T>
-
Field Summary
Modifier and TypeFieldDescriptionprivate static final RegistryObject
<?> private @Nullable ResourceKey
<T> private final @Nullable ResourceLocation
private final boolean
private T
-
Constructor Summary
ModifierConstructorDescriptionprivate
private
RegistryObject
(ResourceLocation name, ResourceLocation registryName, String modid, boolean optionalRegistry) private
RegistryObject
(ResourceLocation name, IForgeRegistry<?> registry) -
Method Summary
Modifier and TypeMethodDescriptionstatic <T,
U extends T>
RegistryObject<U> create
(ResourceLocation name, ResourceKey<? extends Registry<T>> registryKey, String modid) Factory for aRegistryObject
that stores the value of an object from a registry once it is ready based on a lookup of the provided registry key.static <T,
U extends T>
RegistryObject<U> create
(ResourceLocation name, ResourceLocation registryName, String modid) Factory for aRegistryObject
that stores the value of an object from a registry once it is ready based on a lookup of the provided registry name.static <T,
U extends T>
RegistryObject<U> create
(ResourceLocation name, IForgeRegistry<T> registry) Factory for aRegistryObject
that stores the value of an object from the provided forge registry once it is ready.static <T,
U extends T>
RegistryObject<U> createOptional
(ResourceLocation name, ResourceKey<? extends Registry<T>> registryKey, String modid) Factory for aRegistryObject
that optionally stores the value of an object from a registry once it is ready if the registry exists based on a lookup of the provided registry key.static <T,
U extends T>
RegistryObject<U> createOptional
(ResourceLocation name, ResourceLocation registryName, String modid) Factory for aRegistryObject
that optionally stores the value of an object from a registry once it is ready if the registry exists based on a lookup of the provided registry name.private static <T> RegistryObject
<T> empty()
boolean
If a mod object is present, and the mod object matches the given predicate, return anRegistryObject
describing the value, otherwise return an emptyRegistryObject
.<U> Optional
<U> If a value is present, apply the providedOptional
-bearing mapping function to it, return that result, otherwise return an emptyOptional
.get()
Retrieves the wrapped object in the registry.Returns an optionalHolder
instance pointing to this RegistryObject's name and value.getId()
@Nullable ResourceKey
<T> getKey()
Returns the resource key that points to the registry and name of this registry object.int
hashCode()
void
If a mod object is present, invoke the specified consumer with the object, otherwise do nothing.boolean
Returntrue
if there is a mod object present, otherwisefalse
.<U> Supplier
<U> If a mod object is present, lazily apply the provided mapping function to it, returning a supplier for the transformed result.<U> Optional
<U> If a mod object is present, apply the provided mapping function to it, and if the result is non-null, return anOptional
describing the result.Return the mod object if present, otherwise returnother
.Return the mod object if present, otherwise invokeother
and return the result of that invocation.orElseThrow
(Supplier<? extends X> exceptionSupplier) Return the contained mod object, if present, otherwise throw an exception to be created by the provided supplier.private static boolean
registryExists
(ResourceLocation registryName) stream()
(package private) void
updateReference
(Registry<? extends T> registry) (package private) void
updateReference
(ResourceLocation registryName) (package private) void
updateReference
(IForgeRegistry<? extends T> registry) (package private) void
updateReference
(RegisterEvent event)
-
Field Details
-
name
-
key
-
optionalRegistry
private final boolean optionalRegistry -
value
-
holder
-
EMPTY
-
-
Constructor Details
-
RegistryObject
private RegistryObject() -
RegistryObject
-
RegistryObject
private RegistryObject(ResourceLocation name, ResourceLocation registryName, String modid, boolean optionalRegistry)
-
-
Method Details
-
create
public static <T,U extends T> RegistryObject<U> create(ResourceLocation name, IForgeRegistry<T> registry) Factory for aRegistryObject
that stores the value of an object from the provided forge registry once it is ready.- Parameters:
name
- the name of the object to look up in the forge registryregistry
- the forge registry- Returns:
- a
RegistryObject
that stores the value of an object from the provided forge registry once it is ready
-
create
public static <T,U extends T> RegistryObject<U> create(ResourceLocation name, ResourceKey<? extends Registry<T>> registryKey, String modid) Factory for aRegistryObject
that stores the value of an object from a registry once it is ready based on a lookup of the provided registry key.If a registry with the given key cannot be found, an exception will be thrown when trying to fill this RegistryObject. Use
createOptional(ResourceLocation, ResourceKey, String)
for RegistryObjects of optional registries.- Parameters:
name
- the name of the object to look up in a registryregistryKey
- the key of the registry. Supports lookups onBuiltInRegistries
andRegistryManager.ACTIVE
.modid
- the mod id calling context- Returns:
- a
RegistryObject
that stores the value of an object from a registry once it is ready - See Also:
-
createOptional
public static <T,U extends T> RegistryObject<U> createOptional(ResourceLocation name, ResourceKey<? extends Registry<T>> registryKey, String modid) Factory for aRegistryObject
that optionally stores the value of an object from a registry once it is ready if the registry exists based on a lookup of the provided registry key.If a registry with the given key cannot be found, it will be silently ignored and this RegistryObject will not be filled. Use
create(ResourceLocation, ResourceKey, String)
for RegistryObjects that should throw exceptions on missing registry.- Parameters:
name
- the name of the object to look up in a registryregistryKey
- the key of the registry. Supports lookups onBuiltInRegistries
andRegistryManager.ACTIVE
.modid
- the mod id calling context- Returns:
- a
RegistryObject
that stores the value of an object from a registry once it is ready - See Also:
-
create
public static <T,U extends T> RegistryObject<U> create(ResourceLocation name, ResourceLocation registryName, String modid) Factory for aRegistryObject
that stores the value of an object from a registry once it is ready based on a lookup of the provided registry name.If a registry with the given name cannot be found, an exception will be thrown when trying to fill this RegistryObject. Use
createOptional(ResourceLocation, ResourceLocation, String)
for RegistryObjects of optional registries.- Parameters:
name
- the name of the object to look up in a registryregistryName
- the name of the registry. Supports lookups onBuiltInRegistries
andRegistryManager.ACTIVE
.modid
- the mod id calling context- Returns:
- a
RegistryObject
that stores the value of an object from a registry once it is ready - See Also:
-
createOptional
public static <T,U extends T> RegistryObject<U> createOptional(ResourceLocation name, ResourceLocation registryName, String modid) Factory for aRegistryObject
that optionally stores the value of an object from a registry once it is ready if the registry exists based on a lookup of the provided registry name.If a registry with the given name cannot be found, it will be silently ignored and this RegistryObject will not be filled. Use
create(ResourceLocation, ResourceLocation, String)
for RegistryObjects that should throw exceptions on missing registry.- Parameters:
name
- the name of the object to look up in a registryregistryName
- the name of the registry. Supports lookups onBuiltInRegistries
andRegistryManager.ACTIVE
.modid
- the mod id calling context- Returns:
- a
RegistryObject
that stores the value of an object from a registry once it is ready - See Also:
-
empty
-
get
Retrieves the wrapped object in the registry. This value will automatically be updated when the backing registry is updated.- Specified by:
get
in interfaceSupplier<T>
- Throws:
NullPointerException
- If the value is null. UseisPresent()
to check if the value exists first.- See Also:
-
updateReference
-
updateReference
-
updateReference
-
updateReference
-
registryExists
-
getId
-
getKey
Returns the resource key that points to the registry and name of this registry object. Nullable only if this RegistryObject is empty and has no name.- Returns:
- the resource key that points to the registry and name of this registry object
-
stream
-
isPresent
public boolean isPresent()Returntrue
if there is a mod object present, otherwisefalse
.- Returns:
true
if there is a mod object present, otherwisefalse
-
ifPresent
If a mod object is present, invoke the specified consumer with the object, otherwise do nothing.- Parameters:
consumer
- block to be executed if a mod object is present- Throws:
NullPointerException
- if mod object is present andconsumer
is null
-
filter
If a mod object is present, and the mod object matches the given predicate, return anRegistryObject
describing the value, otherwise return an emptyRegistryObject
.- Parameters:
predicate
- a predicate to apply to the mod object, if present- Returns:
- an
RegistryObject
describing the value of thisRegistryObject
if a mod object is present and the mod object matches the given predicate, otherwise an emptyRegistryObject
- Throws:
NullPointerException
- if the predicate is null
-
map
If a mod object is present, apply the provided mapping function to it, and if the result is non-null, return anOptional
describing the result. Otherwise return an emptyOptional
.- Type Parameters:
U
- The type of the result of the mapping function- Parameters:
mapper
- a mapping function to apply to the mod object, if present- Returns:
- an
Optional
describing the result of applying a mapping function to the mod object of thisRegistryObject
, if a mod object is present, otherwise an emptyOptional
- Throws:
NullPointerException
- if the mapping function is null- API Note:
- This method supports post-processing on optional values, without the need to explicitly check for a return status.
-
flatMap
If a value is present, apply the providedOptional
-bearing mapping function to it, return that result, otherwise return an emptyOptional
. This method is similar tomap(Function)
, but the provided mapper is one whose result is already anOptional
, and if invoked,flatMap
does not wrap it with an additionalOptional
.- Type Parameters:
U
- The type parameter to theOptional
returned by- Parameters:
mapper
- a mapping function to apply to the mod object, if present the mapping function- Returns:
- the result of applying an
Optional
-bearing mapping function to the value of thisOptional
, if a value is present, otherwise an emptyOptional
- Throws:
NullPointerException
- if the mapping function is null or returns a null result
-
lazyMap
If a mod object is present, lazily apply the provided mapping function to it, returning a supplier for the transformed result. If this object is empty, or the mapping function returnsnull
, the supplier will returnnull
.- Type Parameters:
U
- The type of the result of the mapping function- Parameters:
mapper
- A mapping function to apply to the mod object, if present- Returns:
- A
Supplier
lazily providing the result of applying a mapping function to the mod object of thisRegistryObject
, if a mod object is present, otherwise a supplier returningnull
- Throws:
NullPointerException
- if the mapping function isnull
- API Note:
- This method supports post-processing on optional values, without the need to explicitly check for a return status.
-
orElse
Return the mod object if present, otherwise returnother
.- Parameters:
other
- the mod object to be returned if there is no mod object present, may be null- Returns:
- the mod object, if present, otherwise
other
-
orElseGet
Return the mod object if present, otherwise invokeother
and return the result of that invocation.- Parameters:
other
- aSupplier
whose result is returned if no mod object is present- Returns:
- the mod object if present otherwise the result of
other.get()
- Throws:
NullPointerException
- if mod object is not present andother
is null
-
orElseThrow
Return the contained mod object, if present, otherwise throw an exception to be created by the provided supplier.- Type Parameters:
X
- Type of the exception to be thrown- Parameters:
exceptionSupplier
- The supplier which will return the exception to be thrown- Returns:
- the present mod object
- Throws:
X
- if there is no mod object presentNullPointerException
- if no mod object is present andexceptionSupplier
is null- API Note:
- A method reference to the exception constructor with an empty
argument list can be used as the supplier. For example,
IllegalStateException::new
-
getHolder
Returns an optionalHolder
instance pointing to this RegistryObject's name and value.This should only be used in cases where vanilla code requires passing in a Holder. Mod-written code should rely on RegistryObjects or Suppliers instead.
The returned optional will be empty if the registry does not exist or if
returns false
.- Returns:
- an optional
Holder
instance pointing to this RegistryObject's name and value
-
equals
-
hashCode
public int hashCode()
-