All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.prometheus.metrics.model.snapshots.Exemplars Maven / Gradle / Ivy

package io.prometheus.metrics.model.snapshots;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.Iterator;
import java.util.List;

/**
 * Immutable container for Exemplars.
 * 

* This is currently backed by a {@code List}. May be refactored later to use a more efficient data structure. */ public class Exemplars implements Iterable { /** * EMPTY means no Exemplars. */ public static final Exemplars EMPTY = new Exemplars(Collections.emptyList()); private final List exemplars; private Exemplars(Collection exemplars) { ArrayList copy = new ArrayList<>(exemplars.size()); for (Exemplar exemplar : exemplars) { if (exemplar == null) { throw new NullPointerException("Illegal null value in Exemplars"); } copy.add(exemplar); } this.exemplars = Collections.unmodifiableList(copy); } /** * Create a new Exemplars instance. * You can either create Exemplars with one of the static {@code Exemplars.of(...)} methods, * or you can use the {@link Exemplars#builder()}. * * @param exemplars a copy of the exemplars collection will be created. */ public static Exemplars of(Collection exemplars) { return new Exemplars(exemplars); } /** * Create a new Exemplars instance. * You can either create Exemplars with one of the static {@code Exemplars.of(...)} methods, * or you can use the {@link Exemplars#builder()}. * * @param exemplars a copy of the exemplars array will be created. */ public static Exemplars of(Exemplar... exemplars) { return new Exemplars(Arrays.asList(exemplars)); } @Override public Iterator iterator() { return exemplars.iterator(); } public int size() { return exemplars.size(); } public Exemplar get(int index) { return exemplars.get(index); } /** * This is used by classic histograms to find an exemplar with a value between lowerBound and upperBound. * If there is more than one exemplar within the bounds the one with the newest time stamp is returned. */ public Exemplar get(double lowerBound, double upperBound) { Exemplar result = null; for (int i = 0; i < exemplars.size(); i++) { Exemplar exemplar = exemplars.get(i); double value = exemplar.getValue(); if (value > lowerBound && value <= upperBound) { if (result == null) { result = exemplar; } else if (result.hasTimestamp() && exemplar.hasTimestamp()) { if (exemplar.getTimestampMillis() > result.getTimestampMillis()) { result = exemplar; } } } } return result; } /** * Find the Exemplar with the newest timestamp. May return {@code null}. */ public Exemplar getLatest() { Exemplar latest = null; for (int i=0; i exemplars = new ArrayList<>(); private Builder() { } /** * Add an exemplar. This can be called multiple times to add multiple exemplars. */ public Builder exemplar(Exemplar exemplar) { exemplars.add(exemplar); return this; } /** * Add all exemplars form the collection. */ public Builder exemplars(Collection exemplars) { this.exemplars.addAll(exemplars); return this; } public Exemplars build() { return Exemplars.of(exemplars); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy