Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.landawn.abacus.util.stream.EntryStream Maven / Gradle / Ivy
/*
* Copyright (C) 2017 HaiYang Li
*
* 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.landawn.abacus.util.stream;
import java.util.AbstractMap.SimpleImmutableEntry;
import java.util.Collection;
import java.util.Comparator;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Random;
import java.util.Set;
import com.landawn.abacus.annotation.Beta;
import com.landawn.abacus.util.BiIterator;
import com.landawn.abacus.util.Comparators;
import com.landawn.abacus.util.Fn;
import com.landawn.abacus.util.ImmutableMap;
import com.landawn.abacus.util.Joiner;
import com.landawn.abacus.util.ListMultimap;
import com.landawn.abacus.util.LongMultiset;
import com.landawn.abacus.util.Multimap;
import com.landawn.abacus.util.Multiset;
import com.landawn.abacus.util.N;
import com.landawn.abacus.util.ObjIterator;
import com.landawn.abacus.util.Optional;
import com.landawn.abacus.util.Pair;
import com.landawn.abacus.util.Try;
import com.landawn.abacus.util.function.BiConsumer;
import com.landawn.abacus.util.function.BiFunction;
import com.landawn.abacus.util.function.BiPredicate;
import com.landawn.abacus.util.function.BinaryOperator;
import com.landawn.abacus.util.function.BooleanSupplier;
import com.landawn.abacus.util.function.Consumer;
import com.landawn.abacus.util.function.Function;
import com.landawn.abacus.util.function.Predicate;
import com.landawn.abacus.util.function.Supplier;
import com.landawn.abacus.util.function.ToDoubleFunction;
import com.landawn.abacus.util.function.ToIntFunction;
import com.landawn.abacus.util.function.ToLongFunction;
import com.landawn.abacus.util.stream.BaseStream.Splitor;
/**
*
* @since 0.9
*
* @author Haiyang Li
*/
public final class EntryStream implements AutoCloseable {
private static final Function, Stream>> mapper_func = new Function, Stream>>() {
@Override
public Stream> apply(Map t) {
return Stream.of(t);
}
};
@SuppressWarnings("rawtypes")
private static final EntryStream EMPTY = new EntryStream(Stream. empty());
private final Map m;
private final Stream> s;
EntryStream(final Stream extends Map.Entry> s) {
this(null, s);
}
EntryStream(final Map m, final Stream extends Map.Entry> s) {
this.m = m;
this.s = (Stream>) s;
}
public Stream keys() {
if (m != null) {
return Stream.of(m.keySet());
}
final Function, K> func = Fn.key();
return s.map(func);
}
public Stream values() {
if (m != null) {
return Stream.of(m.values());
}
final Function, V> func = Fn.value();
return s.map(func);
}
public Stream> entries() {
return s;
}
@ParallelSupported
public EntryStream inversed() {
final Function, Map.Entry> mapper = Fn.inverse();
return map(mapper);
}
/**
* Returns a stream consisting of the elements of this stream which keys are
* instances of given class.
*
*
* This is an intermediate
* operation.
*
* @param a type of keys to select.
* @param clazz a class to filter the keys.
* @return the new stream
*/
@SuppressWarnings({ "unchecked" })
@SequentialOnly
public EntryStream selectByKey(Class clazz) {
if (isParallel()) {
return (EntryStream) sequential().filterByKey(Fn.instanceOf(clazz)).parallel(maxThreadNum(), splitor());
} else {
return (EntryStream) filterByKey(Fn.instanceOf(clazz));
}
}
/**
* Returns a stream consisting of the elements of this stream which values
* are instances of given class.
*
*
* This is an intermediate
* operation.
*
* @param a type of values to select.
* @param clazz a class to filter the values.
* @return the new stream
*/
@SuppressWarnings({ "unchecked" })
@SequentialOnly
public EntryStream selectByValue(Class clazz) {
if (isParallel()) {
return (EntryStream) sequential().filterByValue(Fn.instanceOf(clazz)).parallel(maxThreadNum(), splitor());
} else {
return (EntryStream) filterByValue(Fn.instanceOf(clazz));
}
}
@ParallelSupported
public EntryStream filter(final Predicate> predicate) {
return of(s.filter(predicate));
}
@ParallelSupported
public EntryStream filter(final BiPredicate super K, ? super V> predicate) {
final Predicate> predicate2 = new Predicate>() {
@Override
public boolean test(Entry entry) {
return predicate.test(entry.getKey(), entry.getValue());
}
};
return of(s.filter(predicate2));
}
@ParallelSupported
public EntryStream filterByKey(final Predicate super K> keyPredicate) {
final Predicate> predicate = Fn.testByKey(keyPredicate);
return of(s.filter(predicate));
}
@ParallelSupported
public EntryStream filterByValue(final Predicate super V> valuePredicate) {
final Predicate> predicate = Fn.testByValue(valuePredicate);
return of(s.filter(predicate));
}
@ParallelSupported
public EntryStream removeIf(final Predicate> predicate) {
return of(s.removeIf(predicate));
}
@ParallelSupported
public EntryStream removeIf(final BiPredicate super K, ? super V> predicate) {
final Predicate> predicate2 = new Predicate>() {
@Override
public boolean test(Entry entry) {
return predicate.test(entry.getKey(), entry.getValue());
}
};
return of(s.removeIf(predicate2));
}
@ParallelSupported
public EntryStream takeWhile(final Predicate> predicate) {
return of(s.takeWhile(predicate));
}
@ParallelSupported
public EntryStream takeWhile(final BiPredicate super K, ? super V> predicate) {
final Predicate> predicate2 = new Predicate>() {
@Override
public boolean test(Entry entry) {
return predicate.test(entry.getKey(), entry.getValue());
}
};
return of(s.takeWhile(predicate2));
}
@ParallelSupported
public EntryStream dropWhile(final Predicate> predicate) {
return of(s.dropWhile(predicate));
}
@ParallelSupported
public EntryStream dropWhile(final BiPredicate super K, ? super V> predicate) {
final Predicate> predicate2 = new Predicate>() {
@Override
public boolean test(Entry entry) {
return predicate.test(entry.getKey(), entry.getValue());
}
};
return of(s.dropWhile(predicate2));
}
@ParallelSupported
public EntryStream map(final Function super Map.Entry, Map.Entry> mapper) {
return s.mapToEntry(mapper);
}
@ParallelSupported
public EntryStream map(final Function super Map.Entry, KK> keyMapper, final Function super Map.Entry, VV> valueMapper) {
return s.mapToEntry(keyMapper, valueMapper);
}
@ParallelSupported
public EntryStream map(final BiFunction super K, ? super V, Map.Entry> mapper) {
final Function, Map.Entry> mapper2 = new Function, Map.Entry>() {
@Override
public Entry apply(Map.Entry entry) {
return mapper.apply(entry.getKey(), entry.getValue());
}
};
return map(mapper2);
}
@ParallelSupported
public EntryStream map(final BiFunction super K, ? super V, KK> keyMapper, final BiFunction super K, ? super V, VV> valueMapper) {
final Function, Map.Entry> mapper = new Function, Map.Entry>() {
@Override
public Entry apply(Entry t) {
return new SimpleImmutableEntry<>(keyMapper.apply(t.getKey(), t.getValue()), valueMapper.apply(t.getKey(), t.getValue()));
}
};
return map(mapper);
}
@ParallelSupported
public EntryStream mapKey(final Function super K, KK> keyMapper) {
final Function, Map.Entry> mapper = Fn.mapKey(keyMapper);
return map(mapper);
}
@ParallelSupported
public EntryStream mapValue(final Function super V, VV> valueMapper) {
final Function, Map.Entry> mapper = Fn.mapValue(valueMapper);
return map(mapper);
}
// public EntryStream flatMap(final Function super Map.Entry, EntryStream> mapper) {
// final Function, Stream>> mapper2 = new Function, Stream>>() {
// @Override
// public Stream> apply(Entry t) {
// return mapper.apply(t).s;
// }
// };
//
// return flattMap(mapper2);
// }
@ParallelSupported
public EntryStream flatMap(final Function super Map.Entry, ? extends Stream extends Map.Entry>> mapper) {
return s.flatMapToEntry(mapper);
}
@ParallelSupported
public EntryStream flattMap(final Function super Map.Entry, ? extends Map> mapper) {
return s.flattMapToEntry(mapper);
}
@ParallelSupported
public EntryStream flatMapp(final Function super Map.Entry, ? extends EntryStream> mapper) {
return s.flatMappToEntry(mapper);
}
@ParallelSupported
public EntryStream flatMapKey(final Function super K, ? extends Stream> keyMapper) {
final Function, Stream>> mapper2 = new Function, Stream>>() {
@Override
public Stream> apply(final Map.Entry e) {
return keyMapper.apply(e.getKey()).map(new Function>() {
@Override
public Map.Entry apply(KK kk) {
return new SimpleImmutableEntry<>(kk, e.getValue());
}
});
}
};
return flatMap(mapper2);
}
@ParallelSupported
public EntryStream flattMapKey(final Function super K, ? extends Collection> keyMapper) {
final Function, Stream>> mapper2 = new Function, Stream>>() {
@Override
public Stream> apply(final Map.Entry e) {
return Stream.of(keyMapper.apply(e.getKey())).map(new Function>() {
@Override
public Map.Entry apply(KK kk) {
return new SimpleImmutableEntry<>(kk, e.getValue());
}
});
}
};
return flatMap(mapper2);
}
@ParallelSupported
public EntryStream flatMapValue(final Function super V, ? extends Stream> valueMapper) {
final Function, Stream>> mapper2 = new Function, Stream>>() {
@Override
public Stream> apply(final Entry e) {
return valueMapper.apply(e.getValue()).map(new Function>() {
@Override
public Map.Entry apply(VV vv) {
return new SimpleImmutableEntry<>(e.getKey(), vv);
}
});
}
};
return flatMap(mapper2);
}
@ParallelSupported
public EntryStream flattMapValue(final Function super V, ? extends Collection> valueMapper) {
final Function, Stream>> mapper2 = new Function, Stream>>() {
@Override
public Stream> apply(final Entry e) {
return Stream.of(valueMapper.apply(e.getValue())).map(new Function>() {
@Override
public Map.Entry apply(VV vv) {
return new SimpleImmutableEntry<>(e.getKey(), vv);
}
});
}
};
return flatMap(mapper2);
}
/**
*
* @param classifier
* @return
* @see Collectors#groupingBy(Function)
*/
@SequentialOnly
public EntryStream> groupBy() {
final Function super Map.Entry, K> classifier = Fn.key();
final Function super Map.Entry, V> valueMapper = Fn.value();
if (isParallel()) {
return of(s.sequential().groupBy(classifier, valueMapper).parallel(s.maxThreadNum(), s.splitor()));
} else {
return of(s.groupBy(classifier, valueMapper));
}
}
/**
*
* @param classifier
* @param mapFactory
* @return
* @see Collectors#groupingBy(Function, Supplier)
*/
@SequentialOnly
public EntryStream> groupBy(final Supplier extends Map>> mapFactory) {
final Function super Map.Entry, K> classifier = Fn.key();
final Function super Map.Entry, V> valueMapper = Fn.value();
if (isParallel()) {
return of(s.sequential().groupBy(classifier, valueMapper, mapFactory).parallel(s.maxThreadNum(), s.splitor()));
} else {
return of(s.groupBy(classifier, valueMapper, mapFactory));
}
}
@ParallelSupported
public EntryStream> groupBy(final Function super Map.Entry, ? extends KK> keyExtractor,
final Function super Map.Entry, ? extends VV> valueMapper) {
return of(s.groupBy(keyExtractor, valueMapper));
}
/**
*
* @param keyExtractor
* @param valueMapper
* @param mapFactory
* @return
* @see Collectors#toMultimap(Function, Function, Supplier)
*/
@ParallelSupported
public EntryStream> groupBy(final Function super Map.Entry, ? extends KK> keyExtractor,
final Function super Map.Entry, ? extends VV> valueMapper, final Supplier extends Map>> mapFactory) {
return of(s.groupBy(keyExtractor, valueMapper, mapFactory));
}
/**
*
* @param downstream
* @return
* @see Collectors#groupingBy(Function, Collector)
*/
@ParallelSupported
public EntryStream groupBy(final Collector super Map.Entry, A, D> downstream) {
final Function super Map.Entry, K> classifier = Fn.key();
return of(s.groupBy(classifier, downstream));
}
/**
*
* @param downstream
* @param mapFactory
* @return
* @see Collectors#groupingBy(Function, Collector)
*/
@ParallelSupported
public EntryStream groupBy(final Collector super Map.Entry, A, D> downstream, final Supplier extends Map> mapFactory) {
final Function super Map.Entry, K> classifier = Fn.key();
return of(s.groupBy(classifier, downstream, mapFactory));
}
/**
*
* @param classifier
* @param downstream
* @param mapFactory
* @return
* @see Collectors#groupingBy(Function, Collector, Supplier)
*/
@ParallelSupported
public EntryStream groupBy(final Function super Map.Entry, ? extends KK> classifier,
final Collector super Map.Entry, A, D> downstream) {
return of(s.groupBy(classifier, downstream));
}
/**
*
* @param classifier
* @param downstream
* @return
* @see Collectors#groupingBy(Function, Collector)
*/
@ParallelSupported
public EntryStream groupBy(final Function super Map.Entry, ? extends KK> classifier,
final Collector super Map.Entry, A, D> downstream, final Supplier extends Map> mapFactory) {
return of(s.groupBy(classifier, downstream, mapFactory));
}
/**
*
* @param mergeFunction
* @return
*/
@SequentialOnly
public EntryStream groupBy(final BinaryOperator mergeFunction) {
final Function super Map.Entry, K> classifier = Fn.key();
final Function super Map.Entry, V> valueMapper = Fn.value();
if (isParallel()) {
return of(s.sequential().groupBy(classifier, valueMapper, mergeFunction).parallel(s.maxThreadNum(), s.splitor()));
} else {
return of(s.groupBy(classifier, valueMapper, mergeFunction));
}
}
/**
*
* @param mergeFunction
* @param mapFactory
* @return
*/
@SequentialOnly
public EntryStream groupBy(final BinaryOperator mergeFunction, final Supplier extends Map> mapFactory) {
final Function super Map.Entry, K> classifier = Fn.key();
final Function super Map.Entry, V> valueMapper = Fn.value();
if (isParallel()) {
return of(s.sequential().groupBy(classifier, valueMapper, mergeFunction, mapFactory).parallel(s.maxThreadNum(), s.splitor()));
} else {
return of(s.groupBy(classifier, valueMapper, mergeFunction, mapFactory));
}
}
/**
*
* @param keyExtractor
* @param valueMapper
* @param mergeFunction
* @return
* @see Collectors#groupBy(Function, Function, BinaryOperator)
*/
@ParallelSupported
public EntryStream groupBy(final Function super Map.Entry, ? extends KK> keyExtractor,
final Function super Map.Entry, ? extends VV> valueMapper, final BinaryOperator mergeFunction) {
return of(s.groupBy(keyExtractor, valueMapper, mergeFunction));
}
/**
*
* @param keyExtractor
* @param valueMapper
* @param mergeFunction
* @param mapFactory
* @return
* @see Collectors#groupBy(Function, Function, BinaryOperator, Supplier)
*/
@ParallelSupported
public EntryStream groupBy(final Function super Map.Entry, ? extends KK> keyExtractor,
final Function super Map.Entry, ? extends VV> valueMapper, final BinaryOperator mergeFunction,
final Supplier extends Map> mapFactory) {
return of(s.groupBy(keyExtractor, valueMapper, mergeFunction, mapFactory));
}
@ParallelSupported
public EntryStream sorted(final Comparator super Map.Entry> comparator) {
return of(s.sorted(comparator));
}
@ParallelSupported
public EntryStream sortedByKey(final Comparator super K> keyComparator) {
final Comparator> comparator = Comparators.comparingByKey(keyComparator);
return of(s.sorted(comparator));
}
@ParallelSupported
public EntryStream sortedByValue(final Comparator super V> valueComparator) {
final Comparator> comparator = Comparators.comparingByValue(valueComparator);
return of(s.sorted(comparator));
}
@SuppressWarnings("rawtypes")
@ParallelSupported
public EntryStream sortedBy(Function super Map.Entry, ? extends Comparable> keyExtractor) {
return of(s.sortedBy(keyExtractor));
}
/**
*
* @param keyExtractor
* @return
*/
@ParallelSupported
public EntryStream sortedByInt(final ToIntFunction super Map.Entry> keyExtractor) {
final Comparator super Map.Entry> comparator = Comparators.comparingInt(keyExtractor);
return sorted(comparator);
}
/**
*
* @param keyExtractor
* @return
*/
@ParallelSupported
public EntryStream sortedByLong(final ToLongFunction super Map.Entry> keyExtractor) {
final Comparator super Map.Entry> comparator = Comparators.comparingLong(keyExtractor);
return sorted(comparator);
}
/**
*
* @param keyExtractor
* @return
*/
@ParallelSupported
public EntryStream sortedByDouble(final ToDoubleFunction super Map.Entry> keyExtractor) {
final Comparator super Map.Entry> comparator = Comparators.comparingDouble(keyExtractor);
return sorted(comparator);
}
@SequentialOnly
public EntryStream distinct() {
return of(s.distinct());
}
@SequentialOnly
public EntryStream distinctByKey() {
final Function super Entry, K> keyExtractor = Fn.key();
if (isParallel()) {
return of(s.sequential().distinctBy(keyExtractor).parallel(s.maxThreadNum(), s.splitor()));
} else {
return of(s.distinctBy(keyExtractor));
}
}
@SequentialOnly
public EntryStream distinctByValue() {
final Function super Entry, V> keyExtractor = Fn.value();
if (isParallel()) {
return of(s.sequential().distinctBy(keyExtractor).parallel(s.maxThreadNum(), s.splitor()));
} else {
return of(s.distinctBy(keyExtractor));
}
}
@ParallelSupported
public EntryStream distinctBy(final Function super Map.Entry