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

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

There is a newer version: 15.1.0.Dev04
Show newest version
package org.infinispan.util;

import java.util.LongSummaryStatistics;
import java.util.OptionalDouble;
import java.util.OptionalLong;
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.LongBinaryOperator;
import java.util.function.LongConsumer;
import java.util.function.LongFunction;
import java.util.function.LongPredicate;
import java.util.function.LongToDoubleFunction;
import java.util.function.LongToIntFunction;
import java.util.function.LongUnaryOperator;
import java.util.function.ObjLongConsumer;
import java.util.function.Supplier;
import java.util.stream.LongStream;

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 LongStream operations off to the underlying LongCacheStream 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 AbstractDelegatingLongCacheStream implements LongCacheStream { protected AbstractDelegatingCacheStream delegateCacheStream; protected LongCacheStream underlyingStream; AbstractDelegatingLongCacheStream(AbstractDelegatingCacheStream delegateCacheStream, LongCacheStream underlyingStream) { this.delegateCacheStream = delegateCacheStream; this.underlyingStream = underlyingStream; } // These are methods that convert to a different AbstractDelegating*CacheStream @Override public IntCacheStream mapToInt(LongToIntFunction mapper) { return underlyingStream.mapToInt(mapper); } @Override public DoubleCacheStream mapToDouble(LongToDoubleFunction mapper) { return new AbstractDelegatingDoubleCacheStream(delegateCacheStream, underlyingStream.mapToDouble(mapper)); } @Override public CacheStream mapToObj(LongFunction mapper) { delegateCacheStream.underlyingStream = underlyingStream.mapToObj(mapper); return (CacheStream) delegateCacheStream; } @Override public CacheStream boxed() { delegateCacheStream.underlyingStream = underlyingStream.boxed(); return (CacheStream) delegateCacheStream; } @Override public DoubleCacheStream asDoubleStream() { return new AbstractDelegatingDoubleCacheStream(delegateCacheStream, underlyingStream.asDoubleStream()); } // These are methods that should delegate to the original cache stream @Override public LongCacheStream sequentialDistribution() { delegateCacheStream = delegateCacheStream.sequentialDistribution(); return this; } @Override public LongCacheStream parallelDistribution() { delegateCacheStream = delegateCacheStream.parallelDistribution(); return this; } @Override public LongCacheStream filterKeySegments(Set segments) { delegateCacheStream = delegateCacheStream.filterKeySegments(segments); return this; } @Override public LongCacheStream filterKeySegments(IntSet segments) { delegateCacheStream = delegateCacheStream.filterKeySegments(segments); return this; } @Override public LongCacheStream filterKeys(Set keys) { delegateCacheStream = delegateCacheStream.filterKeys(keys); return this; } @Override public LongCacheStream distributedBatchSize(int batchSize) { delegateCacheStream = delegateCacheStream.distributedBatchSize(batchSize); return this; } @Override public LongCacheStream segmentCompletionListener(SegmentCompletionListener listener) { delegateCacheStream = delegateCacheStream.segmentCompletionListener(listener); return this; } @Override public LongCacheStream disableRehashAware() { delegateCacheStream = delegateCacheStream.disableRehashAware(); return this; } @Override public LongCacheStream timeout(long timeout, TimeUnit unit) { delegateCacheStream = delegateCacheStream.timeout(timeout, unit); return this; } // Actual LongStream operations @Override public LongCacheStream filter(LongPredicate predicate) { underlyingStream = underlyingStream.filter(predicate); return this; } @Override public LongCacheStream map(LongUnaryOperator mapper) { underlyingStream = underlyingStream.map(mapper); return this; } @Override public LongCacheStream flatMap(LongFunction mapper) { underlyingStream = underlyingStream.flatMap(mapper); return this; } @Override public LongCacheStream distinct() { underlyingStream = underlyingStream.distinct(); return this; } @Override public LongCacheStream sorted() { underlyingStream = underlyingStream.sorted(); return this; } @Override public LongCacheStream peek(LongConsumer action) { underlyingStream = underlyingStream.peek(action); return this; } @Override public LongCacheStream limit(long maxSize) { underlyingStream = underlyingStream.limit(maxSize); return this; } @Override public LongCacheStream skip(long n) { underlyingStream = underlyingStream.skip(n); return this; } @Override public void forEach(LongConsumer action) { underlyingStream.forEach(action); } @Override public void forEachOrdered(LongConsumer action) { underlyingStream.forEachOrdered(action); } @Override public long[] toArray() { return underlyingStream.toArray(); } @Override public long reduce(long identity, LongBinaryOperator op) { return underlyingStream.reduce(identity, op); } @Override public OptionalLong reduce(LongBinaryOperator op) { return underlyingStream.reduce(op); } @Override public R collect(Supplier supplier, ObjLongConsumer accumulator, BiConsumer combiner) { return underlyingStream.collect(supplier, accumulator, combiner); } @Override public long sum() { return underlyingStream.sum(); } @Override public OptionalLong min() { return underlyingStream.min(); } @Override public OptionalLong max() { return underlyingStream.max(); } @Override public long count() { return underlyingStream.count(); } @Override public OptionalDouble average() { return underlyingStream.average(); } @Override public LongSummaryStatistics summaryStatistics() { return underlyingStream.summaryStatistics(); } @Override public boolean anyMatch(LongPredicate predicate) { return underlyingStream.anyMatch(predicate); } @Override public boolean allMatch(LongPredicate predicate) { return underlyingStream.allMatch(predicate); } @Override public boolean noneMatch(LongPredicate predicate) { return underlyingStream.noneMatch(predicate); } @Override public OptionalLong findFirst() { return underlyingStream.findFirst(); } @Override public OptionalLong findAny() { return underlyingStream.findAny(); } @Override public void forEach(ObjLongConsumer> action) { underlyingStream.forEach(action); } @Override public LongCacheStream sequential() { underlyingStream = underlyingStream.sequential(); return this; } @Override public LongCacheStream parallel() { underlyingStream = underlyingStream.parallel(); return this; } @Override public PrimitiveIterator.OfLong iterator() { return underlyingStream.iterator(); } @Override public Spliterator.OfLong spliterator() { return underlyingStream.spliterator(); } @Override public boolean isParallel() { return underlyingStream.isParallel(); } @Override public LongCacheStream unordered() { underlyingStream = underlyingStream.unordered(); return this; } @Override public LongCacheStream onClose(Runnable closeHandler) { underlyingStream = underlyingStream.onClose(closeHandler); return this; } @Override public void close() { underlyingStream.close(); } }