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

net.calledtoconstruct.Tuple7 Maven / Gradle / Ivy

package net.calledtoconstruct;

import java.util.Optional;

public class Tuple7 implements Tuple {

    private final T1 firstValue;
    private final T2 secondValue;
    private final T3 thirdValue;
    private final T4 fourthValue;
    private final T5 fifthValue;
    private final T6 sixthValue;
    private final T7 seventhValue;

    public Tuple7(T1 firstValue, T2 secondValue, T3 thirdValue, T4 fourthValue, T5 fifthValue, T6 sixthValue, T7 seventhValue) {
        this.firstValue = firstValue;
        this.secondValue = secondValue;
        this.thirdValue = thirdValue;
        this.fourthValue = fourthValue;
        this.fifthValue = fifthValue;
        this.sixthValue = sixthValue;
        this.seventhValue = seventhValue;
    }

    /**
     * A function that returns a new {@link Tuple8} containing 
     * the values of this instance plus the supplied {@code value}.
     * 
     * @param  The type of {@code value} being added.
     * @param value A value to be added.
     * @return An instance of {@link Tuple8}
     */
    public  Tuple8 push(T8 value) {
        return new Tuple8<>(firstValue, secondValue, thirdValue, fourthValue, fifthValue, sixthValue, seventhValue, value);
    }

    /**
     * A function that returns a new instance of {@link Tuple6} containing the
     * first six values from this instance.
     * 
     * @return A {@link Tuple6} containing the first six values from this instance.
     */
    public Tuple6 pop() {
        return new Tuple6<>(firstValue, secondValue, thirdValue, fourthValue, fifthValue, sixthValue);
    }

    /**
     * A function that returns a new instance of {@link Tuple6} containing the
     * last six values from this instance.
     * 
     * @return A {@link Tuple6} containing the last six values from this instance.
     */
    public Tuple6 shift() {
        return new Tuple6<>(secondValue, thirdValue, fourthValue, fifthValue, sixthValue, seventhValue);
    }

    /**
     * A function that returns a new {@link Tuple8} containing 
     * the supplied {@code value} plus the values of this instance.
     * 
     * @param  The type of {@code value} being added.
     * @param value A value to be added.
     * @return An instance of {@link Tuple8}
     */
    public  Tuple8 unshift(T8 value) {
        return new Tuple8<>(value, firstValue, secondValue, thirdValue, fourthValue, fifthValue, sixthValue, seventhValue);
    }

    @Override
    public Optional tryPop() {
        return Optional.of(pop());
    }

    @Override
    public  Optional tryPush(T value) {
        return Optional.of(push(value));
    }

    @Override
    public Optional tryShift() {
        return Optional.of(shift());
    }

    @Override
    public  Optional tryUnshift(T value) {
        return Optional.of(unshift(value));
    }

    /**
     * A function that returns the first value from this instance.
     * 
     * @return A value of type {@code T1}
     */
    public T1 getFirst() {
        return firstValue;
    }

    /**
     * A function that returns the second value from this instance.
     * 
     * @return A value of type {@code T2}
     */
    public T2 getSecond() {
        return secondValue;
    }

    /**
     * A function that returns the third value from this instance.
     * 
     * @return A value of type {@code T3}
     */
    public T3 getThird() {
        return thirdValue;
    }

    /**
     * A function that returns the fourth value from this instance.
     * 
     * @return A value of type {@code T4}
     */
    public T4 getFourth() {
        return fourthValue;
    }

    /**
     * A function that returns the fifth value from this instance.
     * 
     * @return A value of type {@code T5}
     */
    public T5 getFifth() {
        return fifthValue;
    }

    /**
     * A function that returns the sixth value from this instance.
     * 
     * @return A value of type {@code T6}
     */
    public T6 getSixth() {
        return sixthValue;
    }

    /**
     * A function that returns the seventh value from this instance.
     * 
     * @return A value of type {@code T7}
     */
    public T7 getSeventh() {
        return seventhValue;
    }

    public  Tuple8 append(final Tuple1 other) {
        return new Tuple8<>(firstValue, secondValue, thirdValue, fourthValue, fifthValue, sixthValue, seventhValue, other.getFirst());
    }

    public  Tuple8 prepend(final Tuple1 other) {
        return new Tuple8<>(other.getFirst(), firstValue, secondValue, thirdValue, fourthValue, fifthValue, sixthValue, seventhValue);
    }

    @Override
    public  Optional tryGetFirst(Class clazz) {
        if (clazz.isAssignableFrom(firstValue.getClass())) {
            final var cast = clazz.cast(firstValue);
            return Optional.of(cast);
        }
        return Optional.empty();
    }

    @Override
    public  Optional tryGetLast(Class clazz) {
        if (clazz.isAssignableFrom(seventhValue.getClass())) {
            final var cast = clazz.cast(seventhValue);
            return Optional.of(cast);
        }
        return Optional.empty();
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy