/**
*
* Copyright (c) 2006-2017, Speedment, 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.speedment.common.tuple;
import java.util.stream.Stream;
/**
*
* @author pemi
* @param <R> The return type of {@link #get(int)}
*/
public interface BasicTuple<R> {
/**
* Returns the degree of the BasicTuple. For example, a Tuple2 has a degree
* of 2 whereas a Tuple3 has a degree of 3.
*
* @return the degree of the Tuple
*/
int degree();
/**
* Returns the degree of the BasicTuple.
*
* @return the degree of the BasicTuple
* @deprecated use {@link #degree() } instead. This method will be removed\
* in the next major API version
*/
@Deprecated
default int length() {
return degree();
}
/**
* Gets the tuple element at the given index. For example, get(0) will
* return the first element and get(1) will return the second etc.
*
* @param index of the element to get
* @return the tuple element at the given index
* @throws IndexOutOfBoundsException if
* {@code index < 0 || index >= length()}
*/
R get(int index);
/**
* Returns a {@link Stream} of all values for this Tuple of the given class.
* I.e. all non-null members of a Tuple that can be cast to the given class
* are included in the Stream. If sequential, the Stream will start with the
* 0:th tuple and progress upwards.
*
* @param <T> The type of stream
* @param clazz The class of the type of the stream
* @return a {@link Stream} of all values for this Tuple of the given class
*/
<T> Stream<T> streamOf(Class<T> clazz);
}