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

com.speedment.common.tuple.mutable.MutableTuple3 Maven / Gradle / Ivy

Go to download

A Speedment bundle that shades all dependencies into one jar. This is useful when deploying an application on a server.

The newest version!
/*
 *
 * Copyright (c) 2006-2019, 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.mutable;

import com.speedment.common.tuple.MutableTuple;
import com.speedment.common.tuple.Tuple;
import com.speedment.common.tuple.TupleOfNullables;
import com.speedment.common.tuple.getter.TupleGetter0;
import com.speedment.common.tuple.getter.TupleGetter1;
import com.speedment.common.tuple.getter.TupleGetter2;
import com.speedment.common.tuple.getter.TupleGetter;

import java.util.Optional;
import java.util.function.BiConsumer;

/**
 * This interface defines a generic {@link MutableTuple} of any order that can
 * hold null values. A MutableTuple is type safe but NOT thread safe.
 * For pure non-null value elements see {@link Tuple}
 * This {@link MutableTuple} has a degree of 3
 * 

* Generated by com.speedment.sources.pattern.tuple.TuplePattern * * @param type of element 0 * @param type of element 1 * @param type of element 2 * * @author Per Minborg * * @see Tuple * @see TupleOfNullables * @see MutableTuple */ public interface MutableTuple3 extends MutableTuple { /** * Returns the 0th element from this tuple. * * @return the 0th element from this tuple. */ Optional get0(); /** * Returns the 1st element from this tuple. * * @return the 1st element from this tuple. */ Optional get1(); /** * Returns the 2nd element from this tuple. * * @return the 2nd element from this tuple. */ Optional get2(); /** * Sets the 0th element in this tuple. * * @param t0 the new value for the 0th element */ void set0(T0 t0); /** * Sets the 1st element in this tuple. * * @param t1 the new value for the 1st element */ void set1(T1 t1); /** * Sets the 2nd element in this tuple. * * @param t2 the new value for the 2nd element */ void set2(T2 t2); @Override default int degree() { return 3; } @SuppressWarnings("unchecked") default Optional get(int index) { switch (index) { case 0 : return (Optional)get0(); case 1 : return (Optional)get1(); case 2 : return (Optional)get2(); default : throw new IllegalArgumentException(String.format("Index %d is outside bounds of tuple of degree %s", index, degree() )); } } /** * Returns a {@link TupleGetter getter} for the 0th element in the {@code * Tuple}. * * @return the element at the 0th position * @param the 0th element type * @param the 1st element type * @param the 2nd element type */ static TupleGetter0, Optional> getter0() { return MutableTuple3::get0; } /** * Returns the 0th element from this tuple or {@code null} if no such * element is present. * * @return the 0th element from this tuple or {@code null} if no such * element is present. */ default T0 getOrNull0() { return get0().orElse(null); } /** * Returns a {@link TupleGetter getter} for the 0th element in the {@code * Tuple}. * * @return the element at the 0th position * @param the 0th element type * @param the 1st element type * @param the 2nd element type */ static TupleGetter0, T0> getterOrNull0() { return MutableTuple3::getOrNull0; } /** * Returns a setter for the 0th element in the {@code MutableTuple}. * * @return the element at the 0th position * @param the 0th element type * @param the 1st element type * @param the 2nd element type */ static BiConsumer, T0> setter0() { return MutableTuple3::set0; } /** * Returns a {@link TupleGetter getter} for the 1st element in the {@code * Tuple}. * * @return the element at the 1st position * @param the 0th element type * @param the 1st element type * @param the 2nd element type */ static TupleGetter1, Optional> getter1() { return MutableTuple3::get1; } /** * Returns the 1st element from this tuple or {@code null} if no such * element is present. * * @return the 1st element from this tuple or {@code null} if no such * element is present. */ default T1 getOrNull1() { return get1().orElse(null); } /** * Returns a {@link TupleGetter getter} for the 1st element in the {@code * Tuple}. * * @return the element at the 1st position * @param the 0th element type * @param the 1st element type * @param the 2nd element type */ static TupleGetter1, T1> getterOrNull1() { return MutableTuple3::getOrNull1; } /** * Returns a setter for the 1st element in the {@code MutableTuple}. * * @return the element at the 1st position * @param the 0th element type * @param the 1st element type * @param the 2nd element type */ static BiConsumer, T1> setter1() { return MutableTuple3::set1; } /** * Returns a {@link TupleGetter getter} for the 2nd element in the {@code * Tuple}. * * @return the element at the 2nd position * @param the 0th element type * @param the 1st element type * @param the 2nd element type */ static TupleGetter2, Optional> getter2() { return MutableTuple3::get2; } /** * Returns the 2nd element from this tuple or {@code null} if no such * element is present. * * @return the 2nd element from this tuple or {@code null} if no such * element is present. */ default T2 getOrNull2() { return get2().orElse(null); } /** * Returns a {@link TupleGetter getter} for the 2nd element in the {@code * Tuple}. * * @return the element at the 2nd position * @param the 0th element type * @param the 1st element type * @param the 2nd element type */ static TupleGetter2, T2> getterOrNull2() { return MutableTuple3::getOrNull2; } /** * Returns a setter for the 2nd element in the {@code MutableTuple}. * * @return the element at the 2nd position * @param the 0th element type * @param the 1st element type * @param the 2nd element type */ static BiConsumer, T2> setter2() { return MutableTuple3::set2; } }