/*
 * 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.ShortIterable;
import org.eclipse.collections.api.block.function.primitive.ShortIntToObjectFunction;
import org.eclipse.collections.api.block.function.primitive.ShortToObjectFunction;
import org.eclipse.collections.api.block.function.primitive.ObjectShortIntToObjectFunction;
import org.eclipse.collections.api.block.predicate.primitive.ShortPredicate;
import org.eclipse.collections.api.block.procedure.primitive.ShortIntProcedure;
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 OrderedShortIterable extends ShortIterable { short getFirst(); int indexOf(short value); @Override OrderedShortIterable select(ShortPredicate predicate); @Override OrderedShortIterable reject(ShortPredicate predicate); @Override <V> OrderedIterable<V> collect(ShortToObjectFunction<? 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(ShortIntToObjectFunction<? 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(ShortIntToObjectFunction<? extends V> function, R target) { int[] index = { 0 }; return this.collect(each -> function.value(each, index[0]++), target); } <T> T injectIntoWithIndex(T injectedValue, ObjectShortIntToObjectFunction<? super T, ? extends T> function); void forEachWithIndex(ShortIntProcedure procedure); }