/*
 * Copyright (c) 2018 Goldman Sachs and others.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * and Eclipse Distribution License v. 1.0 which accompany this distribution.
 * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
 * and the Eclipse Distribution License is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 */

package org.eclipse.collections.api.ordered.primitive;

import java.util.Collection;

import org.eclipse.collections.api.IntIterable;
import org.eclipse.collections.api.block.function.primitive.IntIntToObjectFunction;
import org.eclipse.collections.api.block.function.primitive.IntToObjectFunction;
import org.eclipse.collections.api.block.function.primitive.ObjectIntIntToObjectFunction;
import org.eclipse.collections.api.block.predicate.primitive.IntPredicate;
import org.eclipse.collections.api.block.procedure.primitive.IntIntProcedure;
import org.eclipse.collections.api.ordered.OrderedIterable;

This file was automatically generated from template file orderedPrimitiveIterable.stg.
Since:6.0.
/** * This file was automatically generated from template file orderedPrimitiveIterable.stg. * * @since 6.0. */
public interface OrderedIntIterable extends IntIterable { int getFirst(); int indexOf(int value); @Override OrderedIntIterable select(IntPredicate predicate); @Override OrderedIntIterable reject(IntPredicate predicate); @Override <V> OrderedIterable<V> collect(IntToObjectFunction<? extends V> function);
Returns a new OrderedIterable using results obtained by applying the specified function to each element and its corresponding index.
Since:9.1.
/** * Returns a new OrderedIterable using results obtained by applying the specified function to each element * and its corresponding index. * * @since 9.1. */
default <V> OrderedIterable<V> collectWithIndex(IntIntToObjectFunction<? extends V> function) { int[] index = { 0 }; return this.collect(each -> function.value(each, index[0]++)); }
Adds elements to the target Collection using results obtained by applying the specified function to each element and its corresponding index.
Since:9.1.
/** * Adds elements to the target Collection using results obtained by applying the specified function to each element * and its corresponding index. * * @since 9.1. */
default <V, R extends Collection<V>> R collectWithIndex(IntIntToObjectFunction<? extends V> function, R target) { int[] index = { 0 }; return this.collect(each -> function.value(each, index[0]++), target); } <T> T injectIntoWithIndex(T injectedValue, ObjectIntIntToObjectFunction<? super T, ? extends T> function); void forEachWithIndex(IntIntProcedure procedure); }