Interface PersistentDataContainer
- 
 public interface PersistentDataContainerThis interface represents a map like object, capable of storing custom tags in it.
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description <T,Z>
 Zget(NamespacedKey key, PersistentDataType<T,Z> type)Returns the metadata value that is stored on thePersistentDataHolderinstance.PersistentDataAdapterContextgetAdapterContext()Returns the adapter context this tag container uses.<T,Z>
 ZgetOrDefault(NamespacedKey key, PersistentDataType<T,Z> type, Z defaultValue)Returns the metadata value that is stored on thePersistentDataHolderinstance.<T,Z>
 booleanhas(NamespacedKey key, PersistentDataType<T,Z> type)Returns if the persistent metadata provider has metadata registered matching the provided parameters.booleanisEmpty()Returns if the container instance is empty, therefore has no entries inside it.voidremove(NamespacedKey key)Removes a custom key from thePersistentDataHolderinstance.<T,Z>
 voidset(NamespacedKey key, PersistentDataType<T,Z> type, Z value)Stores a metadata value on thePersistentDataHolderinstance.
 
- 
- 
- 
Method Detail- 
set<T,Z> void set(@NotNull NamespacedKey key, @NotNull PersistentDataType<T,Z> type, @NotNull Z value)Stores a metadata value on thePersistentDataHolderinstance.This API cannot be used to manipulate minecraft data, as the values will be stored using your namespace. This method will override any existing value the PersistentDataHoldermay have stored under the provided key.- Type Parameters:
- T- the generic java type of the tag value
- Z- the generic type of the object to store
- Parameters:
- key- the key this value will be stored under
- type- the type this tag uses
- value- the value stored in the tag
- Throws:
- NullPointerException- if the key is null
- NullPointerException- if the type is null
- NullPointerException- if the value is null. Removing a tag should be done using- remove(NamespacedKey)
- IllegalArgumentException- if no suitable adapter will be found for the- PersistentDataType.getPrimitiveType()
 
 - 
has<T,Z> boolean has(@NotNull NamespacedKey key, @NotNull PersistentDataType<T,Z> type)Returns if the persistent metadata provider has metadata registered matching the provided parameters.This method will only return if the found value has the same primitive data type as the provided key. Storing a value using a custom PersistentDataTypeimplementation will not store the complex data type. Therefore storing a UUID (by storing a byte[]) will match has("key" ,PersistentDataType.BYTE_ARRAY). Likewise a stored byte[] will always match your UUIDPersistentDataTypeeven if it is not 16 bytes long.This method is only usable for custom object keys. Overwriting existing tags, like the the display name, will not work as the values are stored using your namespace. - Type Parameters:
- T- the generic type of the stored primitive
- Z- the generic type of the eventually created complex object
- Parameters:
- key- the key the value is stored under
- type- the type which primitive storage type has to match the value
- Returns:
- if a value
- Throws:
- NullPointerException- if the key to look up is null
- NullPointerException- if the type to cast the found object to is null
 
 - 
get@Nullable <T,Z> Z get(@NotNull NamespacedKey key, @NotNull PersistentDataType<T,Z> type)Returns the metadata value that is stored on thePersistentDataHolderinstance.- Type Parameters:
- T- the generic type of the stored primitive
- Z- the generic type of the eventually created complex object
- Parameters:
- key- the key to look up in the custom tag map
- type- the type the value must have and will be casted to
- Returns:
- the value or nullif no value was mapped under the given value
- Throws:
- NullPointerException- if the key to look up is null
- NullPointerException- if the type to cast the found object to is null
- IllegalArgumentException- if the value exists under the given key, but cannot be access using the given type
- IllegalArgumentException- if no suitable adapter will be found for the- PersistentDataType.getPrimitiveType()
 
 - 
getOrDefault@NotNull <T,Z> Z getOrDefault(@NotNull NamespacedKey key, @NotNull PersistentDataType<T,Z> type, @NotNull Z defaultValue)Returns the metadata value that is stored on thePersistentDataHolderinstance. If the value does not exist in the container, the default value provided is returned.- Type Parameters:
- T- the generic type of the stored primitive
- Z- the generic type of the eventually created complex object
- Parameters:
- key- the key to look up in the custom tag map
- type- the type the value must have and will be casted to
- defaultValue- the default value to return if no value was found for the provided key
- Returns:
- the value or the default value if no value was mapped under the given value
- Throws:
- NullPointerException- if the key to look up is null
- NullPointerException- if the type to cast the found object to is null
- IllegalArgumentException- if the value exists under the given key, but cannot be access using the given type
- IllegalArgumentException- if no suitable adapter will be found for the- PersistentDataType.getPrimitiveType()
 
 - 
removevoid remove(@NotNull NamespacedKey key)Removes a custom key from thePersistentDataHolderinstance.- Parameters:
- key- the key
- Throws:
- NullPointerException- if the provided key is null
 
 - 
isEmptyboolean isEmpty() Returns if the container instance is empty, therefore has no entries inside it.- Returns:
- the boolean
 
 - 
getAdapterContext@NotNull PersistentDataAdapterContext getAdapterContext() Returns the adapter context this tag container uses.- Returns:
- the tag context
 
 
- 
 
-