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

com.landawn.abacus.util.Tuple Maven / Gradle / Ivy

Go to download

A general programming library in Java/Android. It's easy to learn and simple to use with concise and powerful APIs.

There is a newer version: 2.1.12
Show newest version
/*
 * Copyright (c) 2017, Haiyang Li.
 * 
 * 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.landawn.abacus.util;

import java.util.Collection;
import java.util.Iterator;
import java.util.Map;

import com.landawn.abacus.util.u.Optional;

// TODO: Auto-generated Javadoc
/**
 * The Class Tuple.
 *
 * @author Haiyang Li
 * @since 0.8
 */
public abstract class Tuple {

    /** The Constant EMPTY. */
    public static final Tuple EMPTY = new Tuple() {
        @Override
        public int arity() {
            return 0;
        }

        @Override
        public boolean anyNull() {
            return false;
        }

        @Override
        public boolean allNull() {
            return true;
        }

        @Override
        public Object[] toArray() {
            return N.EMPTY_OBJECT_ARRAY;
        }

        @Override
        public  A[] toArray(A[] a) {
            return a;
        }

        @Override
        public  void forEach(Throwables.Consumer consumer) throws E {
            N.checkArgNotNull(consumer);
            // do nothing.
        }

        @Override
        public String toString() {
            return "[]";
        }
    };

    /**
     * Instantiates a new tuple.
     */
    Tuple() {
    }

    /**
     *
     * @return
     */
    public abstract int arity();

    /**
     *
     * @return true, if successful
     */
    public abstract boolean anyNull();

    /**
     *
     * @return true, if successful
     */
    public abstract boolean allNull();

    /**
     *
     * @return
     */
    public abstract Object[] toArray();

    /**
     *
     * @param 
     * @param a
     * @return
     */
    public abstract  A[] toArray(A[] a);

    /**
     *
     * @param 
     * @param consumer
     * @throws E the e
     */
    public abstract  void forEach(Throwables.Consumer consumer) throws E;

    /**
     *
     * @param 
    _1 the 1
     * @return
     */
    public static  Tuple1 of(T1 _1) {
        return new Tuple1<>(_1);
    }

    /**
     *
     * @param 
     * @param 
    _1 the 1
    _2 the 2
     * @return
     */
    public static  Tuple2 of(T1 _1, T2 _2) {
        return new Tuple2<>(_1, _2);
    }

    /**
     *
     * @param 
     * @param 
     * @param 
    _1 the 1
    _2 the 2
    _3 the 3
     * @return
     */
    public static  Tuple3 of(T1 _1, T2 _2, T3 _3) {
        return new Tuple3<>(_1, _2, _3);
    }

    /**
     *
     * @param 
     * @param 
     * @param 
     * @param 
    _1 the 1
    _2 the 2
    _3 the 3
    _4 the 4
     * @return
     */
    public static  Tuple4 of(T1 _1, T2 _2, T3 _3, T4 _4) {
        return new Tuple4<>(_1, _2, _3, _4);
    }

    /**
     *
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
    _1 the 1
    _2 the 2
    _3 the 3
    _4 the 4
    _5 the 5
     * @return
     */
    public static  Tuple5 of(T1 _1, T2 _2, T3 _3, T4 _4, T5 _5) {
        return new Tuple5<>(_1, _2, _3, _4, _5);
    }

    /**
     *
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
    _1 the 1
    _2 the 2
    _3 the 3
    _4 the 4
    _5 the 5
    _6 the 6
     * @return
     */
    public static  Tuple6 of(T1 _1, T2 _2, T3 _3, T4 _4, T5 _5, T6 _6) {
        return new Tuple6<>(_1, _2, _3, _4, _5, _6);
    }

    /**
     *
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
    _1 the 1
    _2 the 2
    _3 the 3
    _4 the 4
    _5 the 5
    _6 the 6
    _7 the 7
     * @return
     */
    public static  Tuple7 of(T1 _1, T2 _2, T3 _3, T4 _4, T5 _5, T6 _6, T7 _7) {
        return new Tuple7<>(_1, _2, _3, _4, _5, _6, _7);
    }

    /**
     *
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
    _1 the 1
    _2 the 2
    _3 the 3
    _4 the 4
    _5 the 5
    _6 the 6
    _7 the 7
    _8 the 8
     * @return
     */
    public static  Tuple8 of(T1 _1, T2 _2, T3 _3, T4 _4, T5 _5, T6 _6, T7 _7, T8 _8) {
        return new Tuple8<>(_1, _2, _3, _4, _5, _6, _7, _8);
    }

    /**
     *
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
     * @param 
    _1 the 1
    _2 the 2
    _3 the 3
    _4 the 4
    _5 the 5
    _6 the 6
    _7 the 7
    _8 the 8
    _9 the 9
     * @return
     */
    public static  Tuple9 of(T1 _1, T2 _2, T3 _3, T4 _4, T5 _5, T6 _6, T7 _7, T8 _8,
            T9 _9) {
        return new Tuple9<>(_1, _2, _3, _4, _5, _6, _7, _8, _9);
    }

    /**
     *
     * @param  the key type
     * @param  the value type
     * @param entry
     * @return
     */
    public static  Tuple2 from(final Map.Entry entry) {
        return new Tuple2<>(entry.getKey(), entry.getValue());
    }

    /**
     *
     * @param 
     * @param a
     * @return
     */
    public static  T from(final Object[] a) {
        final int len = a == null ? 0 : a.length;

        Tuple result = null;

        switch (len) {
            case 0:
                result = EMPTY;
                break;

            case 1:
                result = new Tuple1<>(a[0]);
                break;

            case 2:
                result = new Tuple2<>(a[0], a[1]);
                break;

            case 3:
                result = new Tuple3<>(a[0], a[1], a[2]);
                break;

            case 4:
                result = new Tuple4<>(a[0], a[1], a[2], a[3]);
                break;

            case 5:
                result = new Tuple5<>(a[0], a[1], a[2], a[3], a[4]);
                break;

            case 6:
                result = new Tuple6<>(a[0], a[1], a[2], a[3], a[4], a[5]);
                break;

            case 7:
                result = new Tuple7<>(a[0], a[1], a[2], a[3], a[4], a[5], a[6]);
                break;

            case 8:
                result = new Tuple8<>(a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7]);
                break;

            case 9:
                result = new Tuple9<>(a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7], a[8]);
                break;

            default:
                throw new RuntimeException("Too many elements(" + a.length + ") to fill in Tuple.");
        }

        return (T) result;
    }

    /**
     *
     * @param 
     * @param c
     * @return
     */
    public static  T from(final Collection c) {
        final int len = c == null ? 0 : c.size();
        final Iterator iter = c == null ? null : c.iterator();

        Tuple result = null;

        switch (len) {
            case 0:
                result = EMPTY;
                break;

            case 1:
                result = new Tuple1<>(iter.next());
                break;

            case 2:
                result = new Tuple2<>(iter.next(), iter.next());
                break;

            case 3:
                result = new Tuple3<>(iter.next(), iter.next(), iter.next());
                break;

            case 4:
                result = new Tuple4<>(iter.next(), iter.next(), iter.next(), iter.next());
                break;

            case 5:
                result = new Tuple5<>(iter.next(), iter.next(), iter.next(), iter.next(), iter.next());
                break;

            case 6:
                result = new Tuple6<>(iter.next(), iter.next(), iter.next(), iter.next(), iter.next(), iter.next());
                break;

            case 7:
                result = new Tuple7<>(iter.next(), iter.next(), iter.next(), iter.next(), iter.next(), iter.next(), iter.next());
                break;

            case 8:
                result = new Tuple8<>(iter.next(), iter.next(), iter.next(), iter.next(), iter.next(), iter.next(), iter.next(), iter.next());
                break;

            case 9:
                result = new Tuple9<>(iter.next(), iter.next(), iter.next(), iter.next(), iter.next(), iter.next(), iter.next(), iter.next(), iter.next());
                break;

            default:
                throw new RuntimeException("Too many elements(" + c.size() + ") to fill in Tuple.");
        }

        return (T) result;
    }

    /**
     * The Class Tuple1.
     *
     * @param 
     */
    public final static class Tuple1 extends Tuple {

        /** The  1. */
        public final T1 _1;

        /**
         * Instantiates a new tuple 1.
         */
        // For Kryo
        Tuple1() {
            this(null);
        }

        /**
         * Instantiates a new tuple 1.
         *
        _1 the 1
         */
        Tuple1(T1 _1) {
            this._1 = _1;
        }

        /**
         *
         * @return
         */
        @Override
        public int arity() {
            return 1;
        }

        /**
         *
         * @return true, if successful
         */
        @Override
        public boolean anyNull() {
            return _1 == null;
        }

        /**
         *
         * @return true, if successful
         */
        @Override
        public boolean allNull() {
            return _1 == null;
        }

        /**
         *
         * @return
         */
        @Override
        public Object[] toArray() {
            return new Object[] { _1 };
        }

        /**
         *
         * @param 
         * @param a
         * @return
         */
        @Override
        public  A[] toArray(A[] a) {
            if (a.length < 1) {
                a = N.copyOf(a, 1);
            }

            a[0] = (A) _1;

            return a;
        }

        /**
         *
         * @param 
         * @param consumer
         * @throws E the e
         */
        @Override
        public  void forEach(Throwables.Consumer consumer) throws E {
            final Throwables.Consumer objConsumer = (Throwables.Consumer) consumer;

            objConsumer.accept(_1);
        }

        /**
         *
         * @param 
         * @param action
         * @throws E the e
         */
        public  void accept(final Throwables.Consumer, E> action) throws E {
            action.accept(this);
        }

        /**
         *
         * @param 
         * @param 
         * @param mapper
         * @return
         * @throws E the e
         */
        public  U map(final Throwables.Function, U, E> mapper) throws E {
            return mapper.apply(this);
        }

        /**
         *
         * @param 
         * @param predicate
         * @return
         * @throws E the e
         */
        public  Optional> filter(final Throwables.Predicate, E> predicate) throws E {
            return predicate.test(this) ? Optional.of(this) : Optional.> empty();
        }

        /**
         * 
         * 
         * Optional#ofNullable(_1)
         * 
         * 
. * * @return * @see Optional#ofNullable(Object) */ public Optional toOptional() { return Optional.ofNullable(_1); } /** * * @return */ @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + N.hashCode(_1); return result; } /** * * @param obj * @return true, if successful */ @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj != null && obj.getClass().equals(Tuple1.class)) { final Tuple1 other = (Tuple1) obj; return N.equals(this._1, other._1); } return false; } /** * * @return */ @Override public String toString() { return "[" + N.toString(_1) + "]"; } } /** * The Class Tuple2. * * @param * @param */ public final static class Tuple2 extends Tuple { /** The 1. */ public final T1 _1; /** The 2. */ public final T2 _2; /** * Instantiates a new tuple 2. */ // For Kryo Tuple2() { this(null, null); } /** * Instantiates a new tuple 2. * _1 the 1 _2 the 2 */ Tuple2(T1 _1, T2 _2) { this._1 = _1; this._2 = _2; } /** * * @return */ @Override public int arity() { return 2; } /** * * @return true, if successful */ @Override public boolean anyNull() { return _1 == null || _2 == null; } /** * * @return true, if successful */ @Override public boolean allNull() { return _1 == null && _2 == null; } /** * * @return */ public Tuple2 reversed() { return of(_2, _1); } /** * * @return */ @Override public Object[] toArray() { return new Object[] { _1, _2 }; } /** * * @param
* @param a * @return */ @Override public A[] toArray(A[] a) { if (a.length < 2) { a = N.copyOf(a, 2); } a[0] = (A) _1; a[1] = (A) _2; return a; } /** * * @param * @param consumer * @throws E the e */ @Override public void forEach(Throwables.Consumer consumer) throws E { final Throwables.Consumer objConsumer = (Throwables.Consumer) consumer; objConsumer.accept(_1); objConsumer.accept(_2); } /** * * @param * @param action * @throws E the e */ public void accept(final Throwables.Consumer, E> action) throws E { action.accept(this); } /** * * @param * @param action * @throws E the e */ public void accept(final Throwables.BiConsumer action) throws E { action.accept(_1, _2); } /** * * @param * @param * @param mapper * @return * @throws E the e */ public U map(final Throwables.Function, U, E> mapper) throws E { return mapper.apply(this); } /** * * @param * @param * @param mapper * @return * @throws E the e */ public U map(final Throwables.BiFunction mapper) throws E { return mapper.apply(_1, _2); } /** * * @param * @param predicate * @return * @throws E the e */ public Optional> filter(final Throwables.Predicate, E> predicate) throws E { return predicate.test(this) ? Optional.of(this) : Optional.> empty(); } /** * * @param * @param predicate * @return * @throws E the e */ public Optional> filter(final Throwables.BiPredicate predicate) throws E { return predicate.test(_1, _2) ? Optional.of(this) : Optional.> empty(); } /** * * @return */ public Pair toPair() { return Pair.of(_1, _2); } /** * * @return */ @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + N.hashCode(_1); result = prime * result + N.hashCode(_2); return result; } /** * * @param obj * @return true, if successful */ @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj != null && obj.getClass().equals(Tuple2.class)) { final Tuple2 other = (Tuple2) obj; return N.equals(this._1, other._1) && N.equals(this._2, other._2); } return false; } /** * * @return */ @Override public String toString() { return "[" + N.toString(_1) + ", " + N.toString(_2) + "]"; } } /** * The Class Tuple3. * * @param * @param * @param */ public final static class Tuple3 extends Tuple { /** The 1. */ public final T1 _1; /** The 2. */ public final T2 _2; /** The 3. */ public final T3 _3; /** * Instantiates a new tuple 3. */ // For Kryo Tuple3() { this(null, null, null); } /** * Instantiates a new tuple 3. * _1 the 1 _2 the 2 _3 the 3 */ Tuple3(T1 _1, T2 _2, T3 _3) { this._1 = _1; this._2 = _2; this._3 = _3; } /** * * @return */ @Override public int arity() { return 3; } /** * * @return true, if successful */ @Override public boolean anyNull() { return _1 == null || _2 == null || _3 == null; } /** * * @return true, if successful */ @Override public boolean allNull() { return _1 == null && _2 == null && _3 == null; } /** * * @return */ public Tuple3 reversed() { return new Tuple3<>(_3, _2, _1); } /** * * @return */ @Override public Object[] toArray() { return new Object[] { _1, _2, _3 }; } /** * * @param * @param a * @return */ @Override public A[] toArray(A[] a) { if (a.length < 3) { a = N.copyOf(a, 3); } a[0] = (A) _1; a[1] = (A) _2; a[2] = (A) _3; return a; } /** * * @param * @param consumer * @throws E the e */ @Override public void forEach(Throwables.Consumer consumer) throws E { final Throwables.Consumer objConsumer = (Throwables.Consumer) consumer; objConsumer.accept(_1); objConsumer.accept(_2); objConsumer.accept(_3); } /** * * @param * @param action * @throws E the e */ public void accept(final Throwables.Consumer, E> action) throws E { action.accept(this); } /** * * @param * @param action * @throws E the e */ public void accept(final Throwables.TriConsumer action) throws E { action.accept(_1, _2, _3); } /** * * @param * @param * @param mapper * @return * @throws E the e */ public U map(final Throwables.Function, U, E> mapper) throws E { return mapper.apply(this); } /** * * @param * @param * @param mapper * @return * @throws E the e */ public U map(final Throwables.TriFunction mapper) throws E { return mapper.apply(_1, _2, _3); } /** * * @param * @param predicate * @return * @throws E the e */ public Optional> filter(final Throwables.Predicate, E> predicate) throws E { return predicate.test(this) ? Optional.of(this) : Optional.> empty(); } /** * * @param * @param predicate * @return * @throws E the e */ public Optional> filter(final Throwables.TriPredicate predicate) throws E { return predicate.test(_1, _2, _3) ? Optional.of(this) : Optional.> empty(); } /** * * @return */ public Triple toTriple() { return Triple.of(_1, _2, _3); } /** * * @return */ @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + N.hashCode(_1); result = prime * result + N.hashCode(_2); result = prime * result + N.hashCode(_3); return result; } /** * * @param obj * @return true, if successful */ @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj != null && obj.getClass().equals(Tuple3.class)) { final Tuple3 other = (Tuple3) obj; return N.equals(this._1, other._1) && N.equals(this._2, other._2) && N.equals(this._3, other._3); } return false; } /** * * @return */ @Override public String toString() { return "[" + N.toString(_1) + ", " + N.toString(_2) + ", " + N.toString(_3) + "]"; } } /** * The Class Tuple4. * * @param * @param * @param * @param */ public final static class Tuple4 extends Tuple { /** The 1. */ public final T1 _1; /** The 2. */ public final T2 _2; /** The 3. */ public final T3 _3; /** The 4. */ public final T4 _4; /** * Instantiates a new tuple 4. */ // For Kryo Tuple4() { this(null, null, null, null); } /** * Instantiates a new tuple 4. * _1 the 1 _2 the 2 _3 the 3 _4 the 4 */ Tuple4(T1 _1, T2 _2, T3 _3, T4 _4) { this._1 = _1; this._2 = _2; this._3 = _3; this._4 = _4; } /** * * @return */ @Override public int arity() { return 4; } /** * * @return true, if successful */ @Override public boolean anyNull() { return _1 == null || _2 == null || _3 == null || _4 == null; } /** * * @return true, if successful */ @Override public boolean allNull() { return _1 == null && _2 == null && _3 == null && _4 == null; } /** * * @return */ public Tuple4 reversed() { return new Tuple4<>(_4, _3, _2, _1); } /** * * @return */ @Override public Object[] toArray() { return new Object[] { _1, _2, _3, _4 }; } /** * * @param * @param a * @return */ @Override public A[] toArray(A[] a) { if (a.length < 4) { a = N.copyOf(a, 4); } a[0] = (A) _1; a[1] = (A) _2; a[2] = (A) _3; a[3] = (A) _4; return a; } /** * * @param * @param consumer * @throws E the e */ @Override public void forEach(Throwables.Consumer consumer) throws E { final Throwables.Consumer objConsumer = (Throwables.Consumer) consumer; objConsumer.accept(_1); objConsumer.accept(_2); objConsumer.accept(_3); objConsumer.accept(_4); } /** * * @param * @param action * @throws E the e */ public void accept(final Throwables.Consumer, E> action) throws E { action.accept(this); } /** * * @param * @param * @param mapper * @return * @throws E the e */ public U map(final Throwables.Function, U, E> mapper) throws E { return mapper.apply(this); } /** * * @param * @param predicate * @return * @throws E the e */ public Optional> filter(final Throwables.Predicate, E> predicate) throws E { return predicate.test(this) ? Optional.of(this) : Optional.> empty(); } /** * * @return */ @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + N.hashCode(_1); result = prime * result + N.hashCode(_2); result = prime * result + N.hashCode(_3); result = prime * result + N.hashCode(_4); return result; } /** * * @param obj * @return true, if successful */ @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj != null && obj.getClass().equals(Tuple4.class)) { final Tuple4 other = (Tuple4) obj; return N.equals(this._1, other._1) && N.equals(this._2, other._2) && N.equals(this._3, other._3) && N.equals(this._4, other._4); } return false; } /** * * @return */ @Override public String toString() { return "[" + N.toString(_1) + ", " + N.toString(_2) + ", " + N.toString(_3) + ", " + N.toString(_4) + "]"; } } /** * The Class Tuple5. * * @param * @param * @param * @param * @param */ public final static class Tuple5 extends Tuple { /** The 1. */ public final T1 _1; /** The 2. */ public final T2 _2; /** The 3. */ public final T3 _3; /** The 4. */ public final T4 _4; /** The 5. */ public final T5 _5; /** * Instantiates a new tuple 5. */ // For Kryo Tuple5() { this(null, null, null, null, null); } /** * Instantiates a new tuple 5. * _1 the 1 _2 the 2 _3 the 3 _4 the 4 _5 the 5 */ Tuple5(T1 _1, T2 _2, T3 _3, T4 _4, T5 _5) { this._1 = _1; this._2 = _2; this._3 = _3; this._4 = _4; this._5 = _5; } /** * * @return */ @Override public int arity() { return 5; } /** * * @return true, if successful */ @Override public boolean anyNull() { return _1 == null || _2 == null || _3 == null || _4 == null || _5 == null; } /** * * @return true, if successful */ @Override public boolean allNull() { return _1 == null && _2 == null && _3 == null && _4 == null && _5 == null; } /** * * @return */ public Tuple5 reversed() { return new Tuple5<>(_5, _4, _3, _2, _1); } /** * * @return */ @Override public Object[] toArray() { return new Object[] { _1, _2, _3, _4, _5 }; } /** * * @param * @param a * @return */ @Override public A[] toArray(A[] a) { if (a.length < 5) { a = N.copyOf(a, 5); } a[0] = (A) _1; a[1] = (A) _2; a[2] = (A) _3; a[3] = (A) _4; a[4] = (A) _5; return a; } /** * * @param * @param consumer * @throws E the e */ @Override public void forEach(Throwables.Consumer consumer) throws E { final Throwables.Consumer objConsumer = (Throwables.Consumer) consumer; objConsumer.accept(_1); objConsumer.accept(_2); objConsumer.accept(_3); objConsumer.accept(_4); objConsumer.accept(_5); } /** * * @param * @param action * @throws E the e */ public void accept(final Throwables.Consumer, E> action) throws E { action.accept(this); } /** * * @param * @param * @param mapper * @return * @throws E the e */ public U map(final Throwables.Function, U, E> mapper) throws E { return mapper.apply(this); } /** * * @param * @param predicate * @return * @throws E the e */ public Optional> filter(final Throwables.Predicate, E> predicate) throws E { return predicate.test(this) ? Optional.of(this) : Optional.> empty(); } /** * * @return */ @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + N.hashCode(_1); result = prime * result + N.hashCode(_2); result = prime * result + N.hashCode(_3); result = prime * result + N.hashCode(_4); result = prime * result + N.hashCode(_5); return result; } /** * * @param obj * @return true, if successful */ @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj != null && obj.getClass().equals(Tuple5.class)) { final Tuple5 other = (Tuple5) obj; return N.equals(this._1, other._1) && N.equals(this._2, other._2) && N.equals(this._3, other._3) && N.equals(this._4, other._4) && N.equals(this._5, other._5); } return false; } /** * * @return */ @Override public String toString() { return "[" + N.toString(_1) + ", " + N.toString(_2) + ", " + N.toString(_3) + ", " + N.toString(_4) + ", " + N.toString(_5) + "]"; } } /** * The Class Tuple6. * * @param * @param * @param * @param * @param * @param */ public static final class Tuple6 extends Tuple { /** The 1. */ public final T1 _1; /** The 2. */ public final T2 _2; /** The 3. */ public final T3 _3; /** The 4. */ public final T4 _4; /** The 5. */ public final T5 _5; /** The 6. */ public final T6 _6; /** * Instantiates a new tuple 6. */ // For Kryo Tuple6() { this(null, null, null, null, null, null); } /** * Instantiates a new tuple 6. * _1 the 1 _2 the 2 _3 the 3 _4 the 4 _5 the 5 _6 the 6 */ Tuple6(T1 _1, T2 _2, T3 _3, T4 _4, T5 _5, T6 _6) { this._1 = _1; this._2 = _2; this._3 = _3; this._4 = _4; this._5 = _5; this._6 = _6; } /** * * @return */ @Override public int arity() { return 6; } /** * * @return true, if successful */ @Override public boolean anyNull() { return _1 == null || _2 == null || _3 == null || _4 == null || _5 == null || _6 == null; } /** * * @return true, if successful */ @Override public boolean allNull() { return _1 == null && _2 == null && _3 == null && _4 == null && _5 == null && _6 == null; } /** * * @return */ public Tuple6 reversed() { return new Tuple6<>(_6, _5, _4, _3, _2, _1); } /** * * @return */ @Override public Object[] toArray() { return new Object[] { _1, _2, _3, _4, _5, _6 }; } /** * * @param * @param a * @return */ @Override public A[] toArray(A[] a) { if (a.length < 6) { a = N.copyOf(a, 6); } a[0] = (A) _1; a[1] = (A) _2; a[2] = (A) _3; a[3] = (A) _4; a[4] = (A) _5; a[5] = (A) _6; return a; } /** * * @param * @param consumer * @throws E the e */ @Override public void forEach(Throwables.Consumer consumer) throws E { final Throwables.Consumer objConsumer = (Throwables.Consumer) consumer; objConsumer.accept(_1); objConsumer.accept(_2); objConsumer.accept(_3); objConsumer.accept(_4); objConsumer.accept(_5); objConsumer.accept(_6); } /** * * @param * @param action * @throws E the e */ public void accept(final Throwables.Consumer, E> action) throws E { action.accept(this); } /** * * @param * @param * @param mapper * @return * @throws E the e */ public U map(final Throwables.Function, U, E> mapper) throws E { return mapper.apply(this); } /** * * @param * @param predicate * @return * @throws E the e */ public Optional> filter(final Throwables.Predicate, E> predicate) throws E { return predicate.test(this) ? Optional.of(this) : Optional.> empty(); } /** * * @return */ @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + N.hashCode(_1); result = prime * result + N.hashCode(_2); result = prime * result + N.hashCode(_3); result = prime * result + N.hashCode(_4); result = prime * result + N.hashCode(_5); result = prime * result + N.hashCode(_6); return result; } /** * * @param obj * @return true, if successful */ @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj != null && obj.getClass().equals(Tuple6.class)) { final Tuple6 other = (Tuple6) obj; return N.equals(this._1, other._1) && N.equals(this._2, other._2) && N.equals(this._3, other._3) && N.equals(this._4, other._4) && N.equals(this._5, other._5) && N.equals(this._6, other._6); } return false; } /** * * @return */ @Override public String toString() { return "[" + N.toString(_1) + ", " + N.toString(_2) + ", " + N.toString(_3) + ", " + N.toString(_4) + ", " + N.toString(_5) + ", " + N.toString(_6) + "]"; } } /** * The Class Tuple7. * * @param * @param * @param * @param * @param * @param * @param */ public static final class Tuple7 extends Tuple { /** The 1. */ public final T1 _1; /** The 2. */ public final T2 _2; /** The 3. */ public final T3 _3; /** The 4. */ public final T4 _4; /** The 5. */ public final T5 _5; /** The 6. */ public final T6 _6; /** The 7. */ public final T7 _7; /** * Instantiates a new tuple 7. */ // For Kryo Tuple7() { this(null, null, null, null, null, null, null); } /** * Instantiates a new tuple 7. * _1 the 1 _2 the 2 _3 the 3 _4 the 4 _5 the 5 _6 the 6 _7 the 7 */ Tuple7(T1 _1, T2 _2, T3 _3, T4 _4, T5 _5, T6 _6, T7 _7) { this._1 = _1; this._2 = _2; this._3 = _3; this._4 = _4; this._5 = _5; this._6 = _6; this._7 = _7; } /** * * @return */ @Override public int arity() { return 7; } /** * * @return true, if successful */ @Override public boolean anyNull() { return _1 == null || _2 == null || _3 == null || _4 == null || _5 == null || _6 == null || _7 == null; } /** * * @return true, if successful */ @Override public boolean allNull() { return _1 == null && _2 == null && _3 == null && _4 == null && _5 == null && _6 == null && _7 == null; } /** * * @return */ public Tuple7 reversed() { return new Tuple7<>(_7, _6, _5, _4, _3, _2, _1); } /** * * @return */ @Override public Object[] toArray() { return new Object[] { _1, _2, _3, _4, _5, _6, _7 }; } /** * * @param * @param a * @return */ @Override public A[] toArray(A[] a) { if (a.length < 7) { a = N.copyOf(a, 7); } a[0] = (A) _1; a[1] = (A) _2; a[2] = (A) _3; a[3] = (A) _4; a[4] = (A) _5; a[5] = (A) _6; a[6] = (A) _7; return a; } /** * * @param * @param consumer * @throws E the e */ @Override public void forEach(Throwables.Consumer consumer) throws E { final Throwables.Consumer objConsumer = (Throwables.Consumer) consumer; objConsumer.accept(_1); objConsumer.accept(_2); objConsumer.accept(_3); objConsumer.accept(_4); objConsumer.accept(_5); objConsumer.accept(_6); objConsumer.accept(_7); } /** * * @param * @param action * @throws E the e */ public void accept(final Throwables.Consumer, E> action) throws E { action.accept(this); } /** * * @param * @param * @param mapper * @return * @throws E the e */ public U map(final Throwables.Function, U, E> mapper) throws E { return mapper.apply(this); } /** * * @param * @param predicate * @return * @throws E the e */ public Optional> filter( final Throwables.Predicate, E> predicate) throws E { return predicate.test(this) ? Optional.of(this) : Optional.> empty(); } /** * * @return */ @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + N.hashCode(_1); result = prime * result + N.hashCode(_2); result = prime * result + N.hashCode(_3); result = prime * result + N.hashCode(_4); result = prime * result + N.hashCode(_5); result = prime * result + N.hashCode(_6); result = prime * result + N.hashCode(_7); return result; } /** * * @param obj * @return true, if successful */ @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj != null && obj.getClass().equals(Tuple7.class)) { final Tuple7 other = (Tuple7) obj; return N.equals(this._1, other._1) && N.equals(this._2, other._2) && N.equals(this._3, other._3) && N.equals(this._4, other._4) && N.equals(this._5, other._5) && N.equals(this._6, other._6) && N.equals(this._7, other._7); } return false; } /** * * @return */ @Override public String toString() { return "[" + N.toString(_1) + ", " + N.toString(_2) + ", " + N.toString(_3) + ", " + N.toString(_4) + ", " + N.toString(_5) + ", " + N.toString(_6) + ", " + N.toString(_7) + "]"; } } /** * The Class Tuple8. * * @param * @param * @param * @param * @param * @param * @param * @param */ public static final class Tuple8 extends Tuple { /** The 1. */ public final T1 _1; /** The 2. */ public final T2 _2; /** The 3. */ public final T3 _3; /** The 4. */ public final T4 _4; /** The 5. */ public final T5 _5; /** The 6. */ public final T6 _6; /** The 7. */ public final T7 _7; /** The 8. */ public final T8 _8; /** * Instantiates a new tuple 8. */ // For Kryo Tuple8() { this(null, null, null, null, null, null, null, null); } /** * Instantiates a new tuple 8. * _1 the 1 _2 the 2 _3 the 3 _4 the 4 _5 the 5 _6 the 6 _7 the 7 _8 the 8 */ Tuple8(T1 _1, T2 _2, T3 _3, T4 _4, T5 _5, T6 _6, T7 _7, T8 _8) { this._1 = _1; this._2 = _2; this._3 = _3; this._4 = _4; this._5 = _5; this._6 = _6; this._7 = _7; this._8 = _8; } /** * * @return */ @Override public int arity() { return 8; } /** * * @return true, if successful */ @Override public boolean anyNull() { return _1 == null || _2 == null || _3 == null || _4 == null || _5 == null || _6 == null || _7 == null || _8 == null; } /** * * @return true, if successful */ @Override public boolean allNull() { return _1 == null && _2 == null && _3 == null && _4 == null && _5 == null && _6 == null && _7 == null && _8 == null; } /** * * @return */ public Tuple8 reversed() { return new Tuple8<>(_8, _7, _6, _5, _4, _3, _2, _1); } /** * * @return */ @Override public Object[] toArray() { return new Object[] { _1, _2, _3, _4, _5, _6, _7, _8 }; } /** * * @param * @param a * @return */ @Override public A[] toArray(A[] a) { if (a.length < 8) { a = N.copyOf(a, 8); } a[0] = (A) _1; a[1] = (A) _2; a[2] = (A) _3; a[3] = (A) _4; a[4] = (A) _5; a[5] = (A) _6; a[6] = (A) _7; a[7] = (A) _8; return a; } /** * * @param * @param consumer * @throws E the e */ @Override public void forEach(Throwables.Consumer consumer) throws E { final Throwables.Consumer objConsumer = (Throwables.Consumer) consumer; objConsumer.accept(_1); objConsumer.accept(_2); objConsumer.accept(_3); objConsumer.accept(_4); objConsumer.accept(_5); objConsumer.accept(_6); objConsumer.accept(_7); objConsumer.accept(_8); } /** * * @param * @param action * @throws E the e */ public void accept(final Throwables.Consumer, E> action) throws E { action.accept(this); } /** * * @param * @param * @param mapper * @return * @throws E the e */ public U map(final Throwables.Function, U, E> mapper) throws E { return mapper.apply(this); } /** * * @param * @param predicate * @return * @throws E the e */ public Optional> filter( final Throwables.Predicate, E> predicate) throws E { return predicate.test(this) ? Optional.of(this) : Optional.> empty(); } /** * * @return */ @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + N.hashCode(_1); result = prime * result + N.hashCode(_2); result = prime * result + N.hashCode(_3); result = prime * result + N.hashCode(_4); result = prime * result + N.hashCode(_5); result = prime * result + N.hashCode(_6); result = prime * result + N.hashCode(_7); result = prime * result + N.hashCode(_8); return result; } /** * * @param obj * @return true, if successful */ @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj != null && obj.getClass().equals(Tuple8.class)) { final Tuple8 other = (Tuple8) obj; return N.equals(this._1, other._1) && N.equals(this._2, other._2) && N.equals(this._3, other._3) && N.equals(this._4, other._4) && N.equals(this._5, other._5) && N.equals(this._6, other._6) && N.equals(this._7, other._7) && N.equals(this._8, other._8); } return false; } /** * * @return */ @Override public String toString() { return "[" + N.toString(_1) + ", " + N.toString(_2) + ", " + N.toString(_3) + ", " + N.toString(_4) + ", " + N.toString(_5) + ", " + N.toString(_6) + ", " + N.toString(_7) + ", " + N.toString(_8) + "]"; } } /** * The Class Tuple9. * * @param * @param * @param * @param * @param * @param * @param * @param * @param */ public static final class Tuple9 extends Tuple { /** The 1. */ public final T1 _1; /** The 2. */ public final T2 _2; /** The 3. */ public final T3 _3; /** The 4. */ public final T4 _4; /** The 5. */ public final T5 _5; /** The 6. */ public final T6 _6; /** The 7. */ public final T7 _7; /** The 8. */ public final T8 _8; /** The 9. */ public final T9 _9; /** * Instantiates a new tuple 9. */ // For Kryo Tuple9() { this(null, null, null, null, null, null, null, null, null); } /** * Instantiates a new tuple 9. * _1 the 1 _2 the 2 _3 the 3 _4 the 4 _5 the 5 _6 the 6 _7 the 7 _8 the 8 _9 the 9 */ Tuple9(T1 _1, T2 _2, T3 _3, T4 _4, T5 _5, T6 _6, T7 _7, T8 _8, T9 _9) { this._1 = _1; this._2 = _2; this._3 = _3; this._4 = _4; this._5 = _5; this._6 = _6; this._7 = _7; this._8 = _8; this._9 = _9; } /** * * @return */ @Override public int arity() { return 9; } /** * * @return true, if successful */ @Override public boolean anyNull() { return _1 == null || _2 == null || _3 == null || _4 == null || _5 == null || _6 == null || _7 == null || _8 == null || _9 == null; } /** * * @return true, if successful */ @Override public boolean allNull() { return _1 == null && _2 == null && _3 == null && _4 == null && _5 == null && _6 == null && _7 == null && _8 == null && _9 == null; } /** * * @return */ public Tuple9 reversed() { return new Tuple9<>(_9, _8, _7, _6, _5, _4, _3, _2, _1); } /** * * @return */ @Override public Object[] toArray() { return new Object[] { _1, _2, _3, _4, _5, _6, _7, _8, _9 }; } /** * * @param * @param a * @return */ @Override public A[] toArray(A[] a) { if (a.length < 9) { a = N.copyOf(a, 9); } a[0] = (A) _1; a[1] = (A) _2; a[2] = (A) _3; a[3] = (A) _4; a[4] = (A) _5; a[5] = (A) _6; a[6] = (A) _7; a[7] = (A) _8; a[8] = (A) _9; return a; } /** * * @param * @param consumer * @throws E the e */ @Override public void forEach(Throwables.Consumer consumer) throws E { final Throwables.Consumer objConsumer = (Throwables.Consumer) consumer; objConsumer.accept(_1); objConsumer.accept(_2); objConsumer.accept(_3); objConsumer.accept(_4); objConsumer.accept(_5); objConsumer.accept(_6); objConsumer.accept(_7); objConsumer.accept(_8); objConsumer.accept(_9); } /** * * @param * @param action * @throws E the e */ public void accept(final Throwables.Consumer, E> action) throws E { action.accept(this); } /** * * @param * @param * @param mapper * @return * @throws E the e */ public U map(final Throwables.Function, U, E> mapper) throws E { return mapper.apply(this); } /** * * @param * @param predicate * @return * @throws E the e */ public Optional> filter( final Throwables.Predicate, E> predicate) throws E { return predicate.test(this) ? Optional.of(this) : Optional.> empty(); } /** * * @return */ @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + N.hashCode(_1); result = prime * result + N.hashCode(_2); result = prime * result + N.hashCode(_3); result = prime * result + N.hashCode(_4); result = prime * result + N.hashCode(_5); result = prime * result + N.hashCode(_6); result = prime * result + N.hashCode(_7); result = prime * result + N.hashCode(_8); result = prime * result + N.hashCode(_9); return result; } /** * * @param obj * @return true, if successful */ @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj != null && obj.getClass().equals(Tuple9.class)) { final Tuple9 other = (Tuple9) obj; return N.equals(this._1, other._1) && N.equals(this._2, other._2) && N.equals(this._3, other._3) && N.equals(this._4, other._4) && N.equals(this._5, other._5) && N.equals(this._6, other._6) && N.equals(this._7, other._7) && N.equals(this._8, other._8) && N.equals(this._9, other._9); } return false; } /** * * @return */ @Override public String toString() { return "[" + N.toString(_1) + ", " + N.toString(_2) + ", " + N.toString(_3) + ", " + N.toString(_4) + ", " + N.toString(_5) + ", " + N.toString(_6) + ", " + N.toString(_7) + ", " + N.toString(_8) + ", " + N.toString(_9) + "]"; } } }