Class 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 a Metadata implementation to retain multiple single valued keys, and in that situation the key at the largest index is the one that should be used.

    Multiple Metadata instances can be merged, in order, to provide a final sequence for a log statement. When Metadata instance 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, a MetadataProcessor should be created to ensure that scope and log site metadata can be merged correctly.

    See Also:
    Original Java code of Google Flogger
    • Constructor Detail

      • Metadata

        public Metadata()
    • Method Detail

      • empty

        public static Metadata empty()
        Returns an immutable Metadata that has no items.
      • size

        public abstract int size()
        Returns the number of key/value pairs for this instance.
      • getValue

        public abstract Object getValue​(int n)
        Returns the non-null value for the Nth piece of metadata.
        Throws:
        IndexOutOfBoundsException - if either n < 0 or {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 - if key is null.