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

com.hazelcast.jet.Traverser Maven / Gradle / Ivy

There is a newer version: 4.5.4
Show newest version
/*
 * Copyright (c) 2008-2017, Hazelcast, 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.hazelcast.jet;

import com.hazelcast.jet.impl.util.FlatMappingTraverser;

import javax.annotation.Nonnull;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.Predicate;

/**
 * Traverses a potentially infinite sequence of non-{@code null} items. Each
 * invocation of {@link #next()} consumes and returns the next item in the
 * sequence if it is available, or returns {@code null} if not. An item may
 * still become available later on.
 * 

* An important special case is traversing a finite sequence. In this case the * {@code null} return value means "the sequence is exhausted" and all future * {@code next()} calls will return {@code null}. * * @param traversed item type */ @FunctionalInterface public interface Traverser { /** * Returns the next item in the sequence, or {@code null} if the sequence is * already exhausted */ T next(); /** * Adds a mapping layer to this traverser. The returned traverser will emit * the results of applying the mapper function to this traverser's items. */ @Nonnull default Traverser map(@Nonnull Function mapper) { return () -> { final T t = next(); return t != null ? mapper.apply(t) : null; }; } /** * Adds a filtering layer to this traverser. The returned traverser will * emit the same items as this traverser, but only those that pass the * given predicate. */ @Nonnull default Traverser filter(@Nonnull Predicate pred) { return () -> { for (T t; (t = next()) != null;) { if (pred.test(t)) { return t; } } return null; }; } /** * Returns a traverser which appends an additional item to this traverser * after it returns the first {@code null} value. */ @Nonnull default Traverser append(@Nonnull T item) { return new Traverser() { T appendedItem = item; @Override public T next() { T t = Traverser.this.next(); if (t == null) { try { return appendedItem; } finally { appendedItem = null; } } return t; } }; } /** * Returns a traverser which prepends an additional item in front of * all the items of this traverser. */ @Nonnull default Traverser prepend(@Nonnull T item) { return new Traverser() { private boolean itemReturned; @Override public T next() { if (itemReturned) { return Traverser.this.next(); } itemReturned = true; return item; } }; } /** * Adds a flat-mapping layer to this traverser. The returned traverser * will apply the given mapping function to each item retrieved from this * traverser, and will emit all the items from the resulting traverser(s). */ @Nonnull default Traverser flatMap(@Nonnull Function> mapper) { return new FlatMappingTraverser<>(this, mapper); } /** * Returns a traverser that will emit the same items as this traverser, * additionally passing each item to the supplied consumer. A {@code null} * return value is not passed to the action. */ @Nonnull default Traverser peek(@Nonnull Consumer action) { return () -> { T t = next(); if (t != null) { action.accept(t); } return t; }; } /** * Returns a traverser that will emit the same items as this traverser and * will additionally run the supplied action first time this traverser * returns {@code null}. */ @Nonnull default Traverser onFirstNull(@Nonnull Runnable action) { return new Traverser() { private boolean didRun; @Override public T next() { T t = Traverser.this.next(); if (t == null && !didRun) { action.run(); didRun = true; } return t; } }; } /** * Returns a traverser over the supplied arguments (or item array). * * @param items the items to traverse over * @param type of the items */ @SafeVarargs static Traverser over(T... items) { return Traversers.traverseArray(items); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy