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

com.tangosol.internal.net.management.MBeanAttribute Maven / Gradle / Ivy

There is a newer version: 24.03
Show newest version
/*
 * Copyright (c) 2000, 2020, Oracle and/or its affiliates.
 *
 * Licensed under the Universal Permissive License v 1.0 as shown at
 * http://oss.oracle.com/licenses/upl.
 */
package com.tangosol.internal.net.management;

import java.util.EnumSet;
import java.util.Set;

import java.util.function.BiConsumer;
import java.util.function.BinaryOperator;
import java.util.function.Function;
import java.util.function.Supplier;

import java.util.stream.Collector;

/**
 * MBeanAttribute represents an attribute of an MBean that can be aggregated.
 * This interface allows an attribute to specialize the {@link Collector} that
 * should be used to reduce many values to a single value. It also allows
 * specializing the name of the attribute and whether this attribute should
 * be avoided.
 *
 * @author hr 2016.07.21
 * @since 12.2.1.4.0
 */
public interface MBeanAttribute
    {
    /**
     * A {@link Collector} to reduce many MBean attribute values.
     *
     * @return a Collector to reduce many MBean attribute values
     */
    public Collector collector();

    /**
     * Return a description to be used instead of the attribute name or null.
     *
     * @return a description to be used instead of the attribute name or null
     */
    public String description();

    /**
     * Return whether this attribute should be visible.
     *
     * @return whether this attribute should be visible
     */
    public default boolean isVisible()
        {
        return true;
        }

    // ----- inner class: NullCollector -------------------------------------

    /**
     * A {@link Collector} implementation that results in a null result.
     *
     * @param  the type of input elements to the reduction operation
     * @param  the mutable accumulation type of the reduction operation (often
     *            hidden as an implementation detail)
     * @param  the result type of the reduction operation
     */
    public static class NullCollector
        implements Collector
        {
        // ----- Collector interface ----------------------------------------

        @Override
        public Supplier supplier()
            {
            return () -> null;
            }

        @Override
        public BiConsumer accumulator()
            {
            return (result, element) -> {};
            }

        @Override
        public BinaryOperator combiner()
            {
            return (result1, result2) -> result1;
            }

        @Override
        public Function finisher()
            {
            return (result) -> (R) result;
            }

        @Override
        public Set characteristics()
            {
            return EnumSet.allOf(Characteristics.class);
            }

        // ----- constants --------------------------------------------------

        /**
         * An instance of a NullCollector.
         */
        public static Collector INSTANCE = new NullCollector<>();

        /**
         * Return a type-safe instance of a NullCollector.
         *
         * @return a type-safe instance of a NullCollector
         */
        public static  Collector INSTANCE()
            {
            return INSTANCE;
            }
        }
    }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy