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

org.infinispan.util.AbstractDelegatingDoubleCacheStream Maven / Gradle / Ivy

package org.infinispan.util;

import java.util.DoubleSummaryStatistics;
import java.util.OptionalDouble;
import java.util.PrimitiveIterator;
import java.util.Set;
import java.util.Spliterator;
import java.util.concurrent.TimeUnit;
import java.util.function.BiConsumer;
import java.util.function.DoubleBinaryOperator;
import java.util.function.DoubleConsumer;
import java.util.function.DoubleFunction;
import java.util.function.DoublePredicate;
import java.util.function.DoubleToIntFunction;
import java.util.function.DoubleToLongFunction;
import java.util.function.DoubleUnaryOperator;
import java.util.function.ObjDoubleConsumer;
import java.util.function.Supplier;
import java.util.stream.DoubleStream;

import org.infinispan.BaseCacheStream;
import org.infinispan.Cache;
import org.infinispan.CacheStream;
import org.infinispan.DoubleCacheStream;
import org.infinispan.IntCacheStream;
import org.infinispan.LongCacheStream;
import org.infinispan.commons.util.IntSet;

/**
 * Abstract Delegating handler that passes DoubleStream operations off to the underlying DoubleCacheStream but delegates
 * {@link org.infinispan.BaseCacheStream} operations to the provided {@link CacheStream}. This allows for intercepting
 * methods defined on BaseCacheStream.
 * 

* This class is package private as it should only be created by using a map operator from another * AbstractDelegating*CacheStream instance. Note that {@link AbstractDelegatingCacheStream} is public as this is * the defined approach to create such a delegated stream. * @author wburns * @since 9.2 */ class AbstractDelegatingDoubleCacheStream implements DoubleCacheStream { protected AbstractDelegatingCacheStream delegateCacheStream; protected DoubleCacheStream underlyingStream; AbstractDelegatingDoubleCacheStream(AbstractDelegatingCacheStream delegateCacheStream, DoubleCacheStream underlyingStream) { this.delegateCacheStream = delegateCacheStream; this.underlyingStream = underlyingStream; } // These are methods that convert to a different AbstractDelegating*CacheStream @Override public IntCacheStream mapToInt(DoubleToIntFunction mapper) { return underlyingStream.mapToInt(mapper); } @Override public LongCacheStream mapToLong(DoubleToLongFunction mapper) { return new AbstractDelegatingLongCacheStream(delegateCacheStream, underlyingStream.mapToLong(mapper)); } @Override public CacheStream mapToObj(DoubleFunction mapper) { delegateCacheStream.underlyingStream = underlyingStream.mapToObj(mapper); return (CacheStream) delegateCacheStream; } @Override public CacheStream boxed() { delegateCacheStream.underlyingStream = underlyingStream.boxed(); return (CacheStream) delegateCacheStream; } // These are methods that should delegate to the original cache stream @Override public DoubleCacheStream sequentialDistribution() { delegateCacheStream = delegateCacheStream.sequentialDistribution(); return this; } @Override public DoubleCacheStream parallelDistribution() { delegateCacheStream = delegateCacheStream.parallelDistribution(); return this; } @Override public DoubleCacheStream filterKeySegments(Set segments) { delegateCacheStream = delegateCacheStream.filterKeySegments(segments); return this; } @Override public BaseCacheStream filterKeySegments(IntSet segments) { delegateCacheStream = delegateCacheStream.filterKeySegments(segments); return this; } @Override public DoubleCacheStream filterKeys(Set keys) { delegateCacheStream = delegateCacheStream.filterKeys(keys); return this; } @Override public DoubleCacheStream distributedBatchSize(int batchSize) { delegateCacheStream = delegateCacheStream.distributedBatchSize(batchSize); return this; } @Override public DoubleCacheStream segmentCompletionListener(SegmentCompletionListener listener) { delegateCacheStream = delegateCacheStream.segmentCompletionListener(listener); return this; } @Override public DoubleCacheStream disableRehashAware() { delegateCacheStream = delegateCacheStream.disableRehashAware(); return this; } @Override public DoubleCacheStream timeout(long timeout, TimeUnit unit) { delegateCacheStream = delegateCacheStream.timeout(timeout, unit); return this; } // Actual DoubleStream operations @Override public DoubleCacheStream filter(DoublePredicate predicate) { underlyingStream = underlyingStream.filter(predicate); return this; } @Override public DoubleCacheStream map(DoubleUnaryOperator mapper) { underlyingStream = underlyingStream.map(mapper); return this; } @Override public DoubleCacheStream flatMap(DoubleFunction mapper) { underlyingStream = underlyingStream.flatMap(mapper); return this; } @Override public DoubleCacheStream distinct() { underlyingStream = underlyingStream.distinct(); return this; } @Override public DoubleCacheStream sorted() { underlyingStream = underlyingStream.sorted(); return this; } @Override public DoubleCacheStream peek(DoubleConsumer action) { underlyingStream = underlyingStream.peek(action); return this; } @Override public DoubleCacheStream limit(long maxSize) { underlyingStream = underlyingStream.limit(maxSize); return this; } @Override public DoubleCacheStream skip(long n) { underlyingStream = underlyingStream.skip(n); return this; } @Override public void forEach(DoubleConsumer action) { underlyingStream.forEach(action); } @Override public void forEachOrdered(DoubleConsumer action) { underlyingStream.forEachOrdered(action); } @Override public double[] toArray() { return underlyingStream.toArray(); } @Override public double reduce(double identity, DoubleBinaryOperator op) { return underlyingStream.reduce(identity, op); } @Override public OptionalDouble reduce(DoubleBinaryOperator op) { return underlyingStream.reduce(op); } @Override public R collect(Supplier supplier, ObjDoubleConsumer accumulator, BiConsumer combiner) { return underlyingStream.collect(supplier, accumulator, combiner); } @Override public double sum() { return underlyingStream.sum(); } @Override public OptionalDouble min() { return underlyingStream.min(); } @Override public OptionalDouble max() { return underlyingStream.max(); } @Override public long count() { return underlyingStream.count(); } @Override public OptionalDouble average() { return underlyingStream.average(); } @Override public DoubleSummaryStatistics summaryStatistics() { return underlyingStream.summaryStatistics(); } @Override public boolean anyMatch(DoublePredicate predicate) { return underlyingStream.anyMatch(predicate); } @Override public boolean allMatch(DoublePredicate predicate) { return underlyingStream.allMatch(predicate); } @Override public boolean noneMatch(DoublePredicate predicate) { return underlyingStream.noneMatch(predicate); } @Override public OptionalDouble findFirst() { return underlyingStream.findFirst(); } @Override public OptionalDouble findAny() { return underlyingStream.findAny(); } @Override public void forEach(ObjDoubleConsumer> action) { underlyingStream.forEach(action); } @Override public DoubleCacheStream sequential() { underlyingStream = underlyingStream.sequential(); return this; } @Override public DoubleCacheStream parallel() { underlyingStream = underlyingStream.parallel(); return this; } @Override public PrimitiveIterator.OfDouble iterator() { return underlyingStream.iterator(); } @Override public Spliterator.OfDouble spliterator() { return underlyingStream.spliterator(); } @Override public boolean isParallel() { return underlyingStream.isParallel(); } @Override public DoubleCacheStream unordered() { underlyingStream = underlyingStream.unordered(); return this; } @Override public DoubleCacheStream onClose(Runnable closeHandler) { underlyingStream = underlyingStream.onClose(closeHandler); return this; } @Override public void close() { underlyingStream.close(); } }