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

io.helidon.metrics.api.Gauge Maven / Gradle / Ivy

There is a newer version: 4.1.4
Show newest version
/*
 * Copyright (c) 2023, 2024 Oracle and/or its affiliates.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package io.helidon.metrics.api;

import java.util.function.Supplier;
import java.util.function.ToDoubleFunction;

/**
 * Measures a value that can increase or decrease and is updated by external logic, not by explicit invocations
 * of methods on this type.
 *
 * @param  subtype of {@link Number} which a specific gauge reports
 */
public interface Gauge extends Meter {

    /**
     * Creates a builder for creating a new gauge based on applying a function to a state object.
     *
     * @param name        gauge name
     * @param stateObject state object which maintains the gauge value
     * @param fn          function which, when applied to the state object, returns the gauge value
     * @param          type of the state object
     * @return new builder
     */
    static  Builder builder(String name, T stateObject, ToDoubleFunction fn) {
        return MetricsFactory.getInstance().gaugeBuilder(name, stateObject, fn);
    }

    /**
     * Creates a builder for a supplier-based gauge.
     *
     * @param name           gauge name
     * @param numberSupplier {@link java.util.function.Supplier} for an instance of a type which extends {@link Number}
     * @param             subtype of {@code Number} which the supplier provides
     * @return new builder
     */
    static  Builder builder(String name, Supplier numberSupplier) {
        return MetricsFactory.getInstance().gaugeBuilder(name, numberSupplier);
    }

    /**
     * Returns the value of the gauge.
     * 

* Invoking this method triggers the sampling of the value or invocation of the function provided when the gauge was * registered. *

* * @return current value of the gauge */ N value(); /** * Builder for a new gauge. * * @see MeterRegistry#getOrCreate(Meter.Builder) * * @param specific subtype of {@code Number} for the gauge this builder will produce */ interface Builder extends Meter.Builder, Gauge> { /** * Returns a {@link java.util.function.Supplier} for the values the gauge will produce. * * @return supplier for the values */ Supplier supplier(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy