Class Metadata
- java.lang.Object
-
- io.spine.logging.flogger.backend.Metadata
-
- Direct Known Subclasses:
ContextMetadata
public abstract class Metadata extends Object
A sequence of metadata key/value pairs which can be associated to a log statement, either directly via methods in the fluent API, of as part of a scoped logging context.Metadata keys can be “single valued” or “repeating” based on
MetadataKey.canRepeat(), but it is permitted for aMetadataimplementation to retain multiple single valued keys, and in that situation the key at the largest index is the one that should be used.Multiple
Metadatainstances can be merged, in order, to provide a final sequence for a log statement. WhenMetadatainstance are merged, the result is just the concatenation of the sequence of key/value pairs, and this is what results in the potential for multiple single valued keys to exist.If the value of a single valued key is required, the
findValue(FloggerMetadataKey)method should be used to look it up. For all other metadata processing, aMetadataProcessorshould be created to ensure that scope and log site metadata can be merged correctly.- See Also:
- Original Java code of Google Flogger
-
-
Constructor Summary
Constructors Constructor Description Metadata()
-
Method Summary
All Methods Static Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description static Metadataempty()Returns an immutableMetadatathat has no items.abstract <T> @Nullable TfindValue(FloggerMetadataKey<T> key)Returns the first value for the given single valued metadata key, or null if it does not exist.abstract FloggerMetadataKey<?>getKey(int n)Returns the key for the Nth piece of metadata.abstract ObjectgetValue(int n)Returns the non-null value for the Nth piece of metadata.abstract intsize()Returns the number of key/value pairs for this instance.
-
-
-
Method Detail
-
size
public abstract int size()
Returns the number of key/value pairs for this instance.
-
getKey
public abstract FloggerMetadataKey<?> getKey(int n)
Returns the key for the Nth piece of metadata.- Throws:
IndexOutOfBoundsException- if eithern < 0or {n >= getCount()}.
-
getValue
public abstract Object getValue(int n)
Returns the non-null value for the Nth piece of metadata.- Throws:
IndexOutOfBoundsException- if eithern < 0or {n >= getCount()}.
-
findValue
public abstract <T> @Nullable T findValue(FloggerMetadataKey<T> key)
Returns the first value for the given single valued metadata key, or null if it does not exist.- Throws:
NullPointerException- ifkeyisnull.
-
-