package org.jooq.lambda.tuple;
import java.io.Serializable;
import java.util.Arrays;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.function.Function;
import java.util.function.Supplier;
import org.jooq.lambda.Seq;
import org.jooq.lambda.function.Function1;
import org.jooq.lambda.function.Function4;
public class Tuple4<T1, T2, T3, T4> implements Tuple, Comparable<Tuple4<T1, T2, T3, T4>>, Serializable, Cloneable {
private static final long serialVersionUID = 1L;
public final T1 v1;
public final T2 v2;
public final T3 v3;
public final T4 v4;
public T1 v1() {
return v1;
}
public T2 v2() {
return v2;
}
public T3 v3() {
return v3;
}
public T4 v4() {
return v4;
}
public Tuple4(Tuple4<T1, T2, T3, T4> tuple) {
this.v1 = tuple.v1;
this.v2 = tuple.v2;
this.v3 = tuple.v3;
this.v4 = tuple.v4;
}
public Tuple4(T1 v1, T2 v2, T3 v3, T4 v4) {
this.v1 = v1;
this.v2 = v2;
this.v3 = v3;
this.v4 = v4;
}
public final <T5> Tuple5<T1, T2, T3, T4, T5> concat(T5 value) {
return new Tuple5<>(v1, v2, v3, v4, value);
}
public final <T5> Tuple5<T1, T2, T3, T4, T5> concat(Tuple1<T5> tuple) {
return new Tuple5<>(v1, v2, v3, v4, tuple.v1);
}
public final <T5, T6> Tuple6<T1, T2, T3, T4, T5, T6> concat(Tuple2<T5, T6> tuple) {
return new Tuple6<>(v1, v2, v3, v4, tuple.v1, tuple.v2);
}
public final <T5, T6, T7> Tuple7<T1, T2, T3, T4, T5, T6, T7> concat(Tuple3<T5, T6, T7> tuple) {
return new Tuple7<>(v1, v2, v3, v4, tuple.v1, tuple.v2, tuple.v3);
}
public final <T5, T6, T7, T8> Tuple8<T1, T2, T3, T4, T5, T6, T7, T8> concat(Tuple4<T5, T6, T7, T8> tuple) {
return new Tuple8<>(v1, v2, v3, v4, tuple.v1, tuple.v2, tuple.v3, tuple.v4);
}
public final <T5, T6, T7, T8, T9> Tuple9<T1, T2, T3, T4, T5, T6, T7, T8, T9> concat(Tuple5<T5, T6, T7, T8, T9> tuple) {
return new Tuple9<>(v1, v2, v3, v4, tuple.v1, tuple.v2, tuple.v3, tuple.v4, tuple.v5);
}
public final <T5, T6, T7, T8, T9, T10> Tuple10<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> concat(Tuple6<T5, T6, T7, T8, T9, T10> tuple) {
return new Tuple10<>(v1, v2, v3, v4, tuple.v1, tuple.v2, tuple.v3, tuple.v4, tuple.v5, tuple.v6);
}
public final <T5, T6, T7, T8, T9, T10, T11> Tuple11<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> concat(Tuple7<T5, T6, T7, T8, T9, T10, T11> tuple) {
return new Tuple11<>(v1, v2, v3, v4, tuple.v1, tuple.v2, tuple.v3, tuple.v4, tuple.v5, tuple.v6, tuple.v7);
}
public final <T5, T6, T7, T8, T9, T10, T11, T12> Tuple12<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> concat(Tuple8<T5, T6, T7, T8, T9, T10, T11, T12> tuple) {
return new Tuple12<>(v1, v2, v3, v4, tuple.v1, tuple.v2, tuple.v3, tuple.v4, tuple.v5, tuple.v6, tuple.v7, tuple.v8);
}
public final <T5, T6, T7, T8, T9, T10, T11, T12, T13> Tuple13<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> concat(Tuple9<T5, T6, T7, T8, T9, T10, T11, T12, T13> tuple) {
return new Tuple13<>(v1, v2, v3, v4, tuple.v1, tuple.v2, tuple.v3, tuple.v4, tuple.v5, tuple.v6, tuple.v7, tuple.v8, tuple.v9);
}
public final <T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> Tuple14<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> concat(Tuple10<T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> tuple) {
return new Tuple14<>(v1, v2, v3, v4, tuple.v1, tuple.v2, tuple.v3, tuple.v4, tuple.v5, tuple.v6, tuple.v7, tuple.v8, tuple.v9, tuple.v10);
}
public final <T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> Tuple15<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> concat(Tuple11<T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> tuple) {
return new Tuple15<>(v1, v2, v3, v4, tuple.v1, tuple.v2, tuple.v3, tuple.v4, tuple.v5, tuple.v6, tuple.v7, tuple.v8, tuple.v9, tuple.v10, tuple.v11);
}
public final <T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15, T16> Tuple16<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15, T16> concat(Tuple12<T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15, T16> tuple) {
return new Tuple16<>(v1, v2, v3, v4, tuple.v1, tuple.v2, tuple.v3, tuple.v4, tuple.v5, tuple.v6, tuple.v7, tuple.v8, tuple.v9, tuple.v10, tuple.v11, tuple.v12);
}
public final Tuple2<Tuple0, Tuple4<T1, T2, T3, T4>> split0() {
return new Tuple2<>(limit0(), skip0());
}
public final Tuple2<Tuple1<T1>, Tuple3<T2, T3, T4>> split1() {
return new Tuple2<>(limit1(), skip1());
}
public final Tuple2<Tuple2<T1, T2>, Tuple2<T3, T4>> split2() {
return new Tuple2<>(limit2(), skip2());
}
public final Tuple2<Tuple3<T1, T2, T3>, Tuple1<T4>> split3() {
return new Tuple2<>(limit3(), skip3());
}
public final Tuple2<Tuple4<T1, T2, T3, T4>, Tuple0> split4() {
return new Tuple2<>(limit4(), skip4());
}
public final Tuple0 limit0() {
return new Tuple0();
}
public final Tuple1<T1> limit1() {
return new Tuple1<>(v1);
}
public final Tuple2<T1, T2> limit2() {
return new Tuple2<>(v1, v2);
}
public final Tuple3<T1, T2, T3> limit3() {
return new Tuple3<>(v1, v2, v3);
}
public final Tuple4<T1, T2, T3, T4> limit4() {
return this;
}
public final Tuple4<T1, T2, T3, T4> skip0() {
return this;
}
public final Tuple3<T2, T3, T4> skip1() {
return new Tuple3<>(v2, v3, v4);
}
public final Tuple2<T3, T4> skip2() {
return new Tuple2<>(v3, v4);
}
public final Tuple1<T4> skip3() {
return new Tuple1<>(v4);
}
public final Tuple0 skip4() {
return new Tuple0();
}
public final <R> R map(Function4<? super T1, ? super T2, ? super T3, ? super T4, ? extends R> function) {
return function.apply(v1, v2, v3, v4);
}
public final <U1> Tuple4<U1, T2, T3, T4> map1(Function<? super T1, ? extends U1> function) {
return Tuple.tuple(function.apply(v1), v2, v3, v4);
}
public final <U2> Tuple4<T1, U2, T3, T4> map2(Function<? super T2, ? extends U2> function) {
return Tuple.tuple(v1, function.apply(v2), v3, v4);
}
public final <U3> Tuple4<T1, T2, U3, T4> map3(Function<? super T3, ? extends U3> function) {
return Tuple.tuple(v1, v2, function.apply(v3), v4);
}
public final <U4> Tuple4<T1, T2, T3, U4> map4(Function<? super T4, ? extends U4> function) {
return Tuple.tuple(v1, v2, v3, function.apply(v4));
}
@Override
@Deprecated
public final Object[] array() {
return toArray();
}
@Override
public final Object[] toArray() {
return new Object[] { v1, v2, v3, v4 };
}
@Override
@Deprecated
public final List<?> list() {
return toList();
}
@Override
public final List<?> toList() {
return Arrays.asList(toArray());
}
@Override
public final Seq<?> toSeq() {
return Seq.seq(toList());
}
@Override
public final Map<String, ?> toMap() {
return toMap(i -> "v" + (i + 1));
}
@Override
public final <K> Map<K, ?> toMap(Function<? super Integer, ? extends K> keyMapper) {
Map<K, Object> result = new LinkedHashMap<>();
Object[] array = toArray();
for (int i = 0; i < array.length; i++)
result.put(keyMapper.apply(i), array[i]);
return result;
}
public final <K> Map<K, ?> toMap(
Supplier<? extends K> keySupplier1,
Supplier<? extends K> keySupplier2,
Supplier<? extends K> keySupplier3,
Supplier<? extends K> keySupplier4
) {
Map<K, Object> result = new LinkedHashMap<>();
result.put(keySupplier1.get(), v1);
result.put(keySupplier2.get(), v2);
result.put(keySupplier3.get(), v3);
result.put(keySupplier4.get(), v4);
return result;
}
public final <K> Map<K, ?> toMap(
K key1,
K key2,
K key3,
K key4
) {
Map<K, Object> result = new LinkedHashMap<>();
result.put(key1, v1);
result.put(key2, v2);
result.put(key3, v3);
result.put(key4, v4);
return result;
}
@Override
public final int degree() {
return 4;
}
@Override
@SuppressWarnings("unchecked")
public final Iterator<Object> iterator() {
return (Iterator<Object>) list().iterator();
}
@Override
public int compareTo(Tuple4<T1, T2, T3, T4> other) {
int result = 0;
result = Tuples.compare(v1, other.v1); if (result != 0) return result;
result = Tuples.compare(v2, other.v2); if (result != 0) return result;
result = Tuples.compare(v3, other.v3); if (result != 0) return result;
result = Tuples.compare(v4, other.v4); if (result != 0) return result;
return result;
}
@Override
public boolean equals(Object o) {
if (this == o)
return true;
if (!(o instanceof Tuple4))
return false;
@SuppressWarnings({ "unchecked", "rawtypes" })
final Tuple4<T1, T2, T3, T4> that = (Tuple4) o;
if (!Objects.equals(v1, that.v1)) return false;
if (!Objects.equals(v2, that.v2)) return false;
if (!Objects.equals(v3, that.v3)) return false;
if (!Objects.equals(v4, that.v4)) return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((v1 == null) ? 0 : v1.hashCode());
result = prime * result + ((v2 == null) ? 0 : v2.hashCode());
result = prime * result + ((v3 == null) ? 0 : v3.hashCode());
result = prime * result + ((v4 == null) ? 0 : v4.hashCode());
return result;
}
@Override
public String toString() {
return "("
+ v1
+ ", " + v2
+ ", " + v3
+ ", " + v4
+ ")";
}
@Override
public Tuple4<T1, T2, T3, T4> clone() {
return new Tuple4<>(this);
}
}