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

org.qbicc.plugin.metrics.Metric Maven / Gradle / Ivy

package org.qbicc.plugin.metrics;

import java.util.Collection;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.atomic.AtomicLong;

import io.smallrye.common.constraint.Assert;

/**
 *
 */
public abstract class Metric> {
    private final String name;
    private final M parent;
    private final AtomicLong cnt = new AtomicLong();
    private final Map children = new ConcurrentHashMap<>();

    Metric(String name, M parent) {
        this.name = name;
        this.parent = parent;
    }

    abstract M constructChild(String name);

    /**
     * Get or add a child with the given name, adding it if it none is present.
     *
     * @param name the name of the child (must not be {@code null})
     * @return the child (not {@code null})
     */
    public final M getOrAddChild(String name) {
        Assert.checkNotNullParam("name", name);
        M child = children.get(name);
        if (child == null) {
            child = constructChild(name);
            M appearing = children.putIfAbsent(name, child);
            if (appearing != null) {
                child = appearing;
            }
        }
        return child;
    }

    /**
     * Get or add a child from the given path.  This is equivalent to calling {@link #getOrAddChild(String)}
     * repeatedly for each given name.
     *
     * @param names a path of names leading to the child (must not be {@code null} nor contain {@code null} elements)
     * @return the child corresponding to the given name path (not {@code null})
     */
    public M getOrAddChild(String... names) {
        M child = (M) this;
        for (String name : names) {
            child = child.getOrAddChild(name);
        }
        return child;
    }

    /**
     * Get the name of this metric.
     *
     * @return the name of this metric (not {@code null})
     */
    public final String getName() {
        return name;
    }

    public final boolean isChildOf(Metric other) {
        return other != null && other.isParentOf(this);
    }

    public final boolean isParentOf(Metric other) {
        return other != null && (other == this || isParentOf(other.parent));
    }

    /**
     * Get the parent of this metric, which will be of the same type.
     *
     * @return the parent of this metric
     */
    public final M getParent() {
        return parent;
    }

    /**
     * Get the raw value of this metric as an unsigned value.
     *
     * @return the raw value
     */
    public long getRawValue() {
        return cnt.get();
    }

    final void addRawValue(long amount) {
        cnt.getAndAdd(amount);
        M parent = getParent();
        if (parent != null) {
            parent.addRawValue(amount);
        }
    }

    /**
     * Get all the existent children of this metric.  The children are of the same type as this instance.
     *
     * @return the collection of children (not {@code null})
     */
    public final Collection getChildren() {
        return children.values();
    }

    /**
     * Get the current value of this metric, formatted readably to the given string builder.
     *
     * @param target the string builder (must not be {@code null})
     * @return the same string builder
     */
    public abstract StringBuilder getFormattedValue(StringBuilder target);

    /**
     * Get the current value of this metric, formatted readably as a string.
     *
     * @return the formatted string (not {@code null})
     */
    public final String getFormattedValue() {
        return getFormattedValue(new StringBuilder()).toString();
    }

    abstract String getDescription();

    /**
     * Get the full path of this metric, formatted readably to the given string builder.
     *
     * @param target the string builder (must not be {@code null})
     * @return the same string builder
     */
    public final StringBuilder toString(StringBuilder target) {
        M parent = getParent();
        if (parent != null) {
            parent.toString(target);
            target.append(":");
        } else {
            target.append(getDescription()).append(' ');
        }
        return target.append(name);
    }

    @Override
    public final String toString() {
        return toString(new StringBuilder()).toString();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy