MetadataValue
FixedMetadataValue
public class LazyMetadataValue extends MetadataValueAdapter
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.
Modifier and Type | Class | Description |
---|---|---|
static class |
LazyMetadataValue.CacheStrategy |
Describes possible caching strategies for metadata.
|
owningPlugin
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.
|
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.
|
asBoolean, asByte, asDouble, asFloat, asInt, asLong, asShort, asString, getOwningPlugin
public LazyMetadataValue(@NotNull Plugin owningPlugin, @NotNull Callable<Object> lazyValue)
owningPlugin
- the Plugin
that created this metadata
value.lazyValue
- the lazy value assigned to this metadata value.public LazyMetadataValue(@NotNull Plugin owningPlugin, @NotNull LazyMetadataValue.CacheStrategy cacheStrategy, @NotNull Callable<Object> lazyValue)
owningPlugin
- the Plugin
that created this metadata
value.cacheStrategy
- determines the rules for caching this metadata
value.lazyValue
- the lazy value assigned to this metadata value.protected LazyMetadataValue(@NotNull Plugin owningPlugin)
owningPlugin
- the owning plugin@Nullable public Object value()
MetadataValue
public void invalidate()
MetadataValue
Copyright © 2019. All rights reserved.