blob: 35ffb9833cea76edb4466394968e1478d13fc7f4 [file] [log] [blame]
Aharoni, Pavel (pa0916)8c70f072018-11-18 00:07:12 +02001/*-
2 * ============LICENSE_START=======================================================
3 * OSAM
4 * ================================================================================
5 * Copyright (C) 2018 AT&T
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
10 *
11 * http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
19 */
20package org.onap.osam.job.utils;
21
22import java.util.Iterator;
23import java.util.Spliterator;
24import java.util.Spliterators;
25import java.util.function.Consumer;
26import java.util.function.Predicate;
27import java.util.stream.Stream;
28import java.util.stream.StreamSupport;
29
30public class Streams {
31 public static <R> Predicate<R> not(Predicate<R> predicate) {
32 return predicate.negate();
33 }
34
35 public static <T> Stream<T> fromIterator(final Iterator<T> iterator) {
36 Iterable<T> iterable = () -> iterator;
37 return StreamSupport.<T>stream(iterable.spliterator(), false);
38 }
39
40
41 // https://stackoverflow.com/questions/20746429/limit-a-stream-by-a-predicate
42 private static <T> Spliterator<T> takeWhile(
43 Spliterator<T> splitr, Predicate<? super T> predicate) {
44 return new Spliterators.AbstractSpliterator<T>(splitr.estimateSize(), 0) {
45 boolean stillGoing = true;
46 @Override public boolean tryAdvance(Consumer<? super T> consumer) {
47 if (stillGoing) {
48 boolean hadNext = splitr.tryAdvance(elem -> {
49 if (predicate.test(elem)) {
50 consumer.accept(elem);
51 } else {
52 stillGoing = false;
53 }
54 });
55 return hadNext && stillGoing;
56 }
57 return false;
58 }
59 };
60 }
61
62 public static <T> Stream<T> takeWhile(Stream<T> stream, Predicate<? super T> predicate) {
63 return StreamSupport.stream(takeWhile(stream.spliterator(), predicate), false);
64 }
65
66}