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

com.speedment.common.function.collector.IntToDoubleCollector Maven / Gradle / Ivy

Go to download

A Speedment bundle that shades all dependencies into one jar. This is useful when deploying an application on a server.

The newest version!
/*
 *
 * Copyright (c) 2006-2019, Speedment, Inc. All Rights Reserved.
 *
 * 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 com.speedment.common.function.collector;

import java.util.Set;
import java.util.function.BinaryOperator;
import java.util.function.ObjIntConsumer;
import java.util.function.Supplier;
import java.util.function.ToDoubleFunction;
import java.util.stream.Collector.Characteristics;
import java.util.stream.Collector;

/**
 * Primitive collector that operates on {@code int} values, resulting in a
 * single {@code double}.
 * 
 * @param  the intermediary accumulating type
 * 
 * @author Emil Forslund
 * @since  1.0.3
 * 
 * @see Collector
 */
public interface IntToDoubleCollector {
    
    /**
     * Returns a supplier that can create an intermediary accumulating object.
     * 
     * @return the supplier for the accumulating object
     * 
     * @see Collector#supplier()
     */
    Supplier supplier();
    
    /**
     * Stateless function that takes an accumulating object returned by{@link
     * #supplier()} and adds a single {@code int} value to it.
     * 
     * @return the accumulator
     * 
     * @see Collector#accumulator()
     */
    ObjIntConsumer accumulator();
    
    /**
     * Stateless function that takes two accumulating objects and returns a
     * single one representing the combined result. This can be either one of
     * the two instances or a completely new instance.
     * 
     * @return the combiner
     * 
     * @see Collector#combiner()
     */
    BinaryOperator combiner();
    
    /**
     * Returns a finisher function that takes an accumulating object and turns
     * it into the final {@code double}.
     * 
     * @return the finisher
     * 
     * @see Collector#finisher()
     */
    ToDoubleFunction finisher();
    
    /**
     * Returns a set of characteristics for this collector.
     * 
     * @return the characteristics for this collector
     * 
     * @see Collector#characteristics()
     */
    Set characteristics();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy