Package org.bukkit.metadata
Class LazyMetadataValue
java.lang.Object
org.bukkit.metadata.MetadataValueAdapter
org.bukkit.metadata.LazyMetadataValue
- All Implemented Interfaces:
MetadataValue
- Direct Known Subclasses:
FixedMetadataValue
public class LazyMetadataValue extends MetadataValueAdapter
The LazyMetadataValue class implements a type of metadata that is not
computed until another plugin asks for it.
By making metadata values lazy, no computation is done by the providing
plugin until absolutely necessary (if ever). Additionally,
LazyMetadataValue objects cache their values internally unless overridden
by a LazyMetadataValue.CacheStrategy
or invalidated at the individual or plugin
level. Once invalidated, the LazyMetadataValue will recompute its value
when asked.
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
LazyMetadataValue.CacheStrategy
Describes possible caching strategies for metadata. -
Field Summary
-
Constructor Summary
Constructors Modifier Constructor Description protected
LazyMetadataValue(Plugin owningPlugin)
Protected special constructor used by FixedMetadataValue to bypass standard setup.LazyMetadataValue(Plugin owningPlugin, Callable<Object> lazyValue)
Initialized a LazyMetadataValue object with the default CACHE_AFTER_FIRST_EVAL cache strategy.LazyMetadataValue(Plugin owningPlugin, LazyMetadataValue.CacheStrategy cacheStrategy, Callable<Object> lazyValue)
Initializes a LazyMetadataValue object with a specific cache strategy. -
Method Summary
Modifier and Type Method Description void
invalidate()
Invalidates this metadata item, forcing it to recompute when next accessed.Object
value()
Fetches the value of this metadata item.Methods inherited from class org.bukkit.metadata.MetadataValueAdapter
asBoolean, asByte, asDouble, asFloat, asInt, asLong, asShort, asString, getOwningPlugin
-
Constructor Details
-
LazyMetadataValue
Initialized a LazyMetadataValue object with the default CACHE_AFTER_FIRST_EVAL cache strategy.- Parameters:
owningPlugin
- thePlugin
that created this metadata value.lazyValue
- the lazy value assigned to this metadata value.
-
LazyMetadataValue
public LazyMetadataValue(@NotNull Plugin owningPlugin, @NotNull LazyMetadataValue.CacheStrategy cacheStrategy, @NotNull Callable<Object> lazyValue)Initializes a LazyMetadataValue object with a specific cache strategy.- Parameters:
owningPlugin
- thePlugin
that created this metadata value.cacheStrategy
- determines the rules for caching this metadata value.lazyValue
- the lazy value assigned to this metadata value.
-
LazyMetadataValue
Protected special constructor used by FixedMetadataValue to bypass standard setup.- Parameters:
owningPlugin
- the owning plugin
-
-
Method Details
-
value
Description copied from interface:MetadataValue
Fetches the value of this metadata item.- Returns:
- the metadata value.
-
invalidate
public void invalidate()Description copied from interface:MetadataValue
Invalidates this metadata item, forcing it to recompute when next accessed.
-