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

com.gs.collections.api.stack.StackIterable Maven / Gradle / Ivy

Go to download

GS Collections is a collections framework for Java. It has JDK-compatible List, Set and Map implementations with a rich API and set of utility classes that work with any JDK compatible Collections, Arrays, Maps or Strings. The iteration protocol was inspired by the Smalltalk collection framework.

There is a newer version: 7.0.3
Show newest version
/*
 * Copyright 2013 Goldman Sachs.
 *
 * 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.gs.collections.api.stack;

import java.util.AbstractCollection;
import java.util.List;

import com.gs.collections.api.RichIterable;
import com.gs.collections.api.block.function.Function;
import com.gs.collections.api.block.function.primitive.BooleanFunction;
import com.gs.collections.api.block.function.primitive.ByteFunction;
import com.gs.collections.api.block.function.primitive.CharFunction;
import com.gs.collections.api.block.function.primitive.DoubleFunction;
import com.gs.collections.api.block.function.primitive.FloatFunction;
import com.gs.collections.api.block.function.primitive.IntFunction;
import com.gs.collections.api.block.function.primitive.LongFunction;
import com.gs.collections.api.block.function.primitive.ShortFunction;
import com.gs.collections.api.block.predicate.Predicate;
import com.gs.collections.api.block.procedure.Procedure;
import com.gs.collections.api.list.ListIterable;
import com.gs.collections.api.multimap.list.ListMultimap;
import com.gs.collections.api.partition.stack.PartitionStack;
import com.gs.collections.api.stack.primitive.BooleanStack;
import com.gs.collections.api.stack.primitive.ByteStack;
import com.gs.collections.api.stack.primitive.CharStack;
import com.gs.collections.api.stack.primitive.DoubleStack;
import com.gs.collections.api.stack.primitive.FloatStack;
import com.gs.collections.api.stack.primitive.IntStack;
import com.gs.collections.api.stack.primitive.LongStack;
import com.gs.collections.api.stack.primitive.ShortStack;
import com.gs.collections.api.tuple.Pair;

/**
 * StackIterable is a last-in-first-out data structure. All iteration methods iterate from the "top" of the stack to the
 * "bottom". In other words, it processes the most recently added elements first.
 * 

* For example: *

* {@link #forEach(Procedure)} iterates over every element, starting with the most recently added *

* {@link #getFirst()} returns the most recently added element, not the element that was added first *

* {@link #toString()} follows the same rules as {@link AbstractCollection#toString()} except it processes the elements * in the same order as {@code forEach()}. */ public interface StackIterable extends RichIterable { /** * @return the top of the stack. */ T peek(); /** * @return a ListIterable of the number of elements specified by the count, beginning with the top of the stack. */ ListIterable peek(int count); /** * @param index the location to peek into * @return the element at the specified index */ T peekAt(int index); /** * Should return the same value as peek(). */ T getFirst(); /** * Should not work as it violates the contract of a Stack. * * @throws UnsupportedOperationException */ T getLast(); /** * Follows the same rules as {@link AbstractCollection#toString()} except it processes the elements * in the same order as {@code forEach()}. */ String toString(); /** * Follows the same general contract as {@link List#equals(Object)}, but for Stacks. */ @Override boolean equals(Object o); /** * Follows the same general contract as {@link List#hashCode()}, but for Stacks. */ @Override int hashCode(); /** * Converts the stack to a MutableStack implementation. * * @since 2.0 */ MutableStack toStack(); StackIterable select(Predicate predicate); StackIterable reject(Predicate predicate); PartitionStack partition(Predicate predicate); StackIterable collect(Function function); BooleanStack collectBoolean(BooleanFunction booleanFunction); ByteStack collectByte(ByteFunction byteFunction); CharStack collectChar(CharFunction charFunction); DoubleStack collectDouble(DoubleFunction doubleFunction); FloatStack collectFloat(FloatFunction floatFunction); IntStack collectInt(IntFunction intFunction); LongStack collectLong(LongFunction longFunction); ShortStack collectShort(ShortFunction shortFunction); StackIterable collectIf(Predicate predicate, Function function); StackIterable flatCollect(Function> function); ListMultimap groupBy(Function function); ListMultimap groupByEach(Function> function); StackIterable> zip(Iterable that); StackIterable> zipWithIndex(); }