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

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

There is a newer version: 1.2.9
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.Map;

import com.landawn.abacus.annotation.Beta;
import com.landawn.abacus.util.function.Supplier;

/**
 * This class is mainly designed for functional programming. 
 * Generally the traditional "{@code if-else}" or ternary operator: "{@code ? : }" is preferred over this class.
 * 
 * @author HaiYang Li
 *
 */
@Beta
public final class If {
    private static final If TRUE = new If(true);
    private static final If FALSE = new If(false);

    private final boolean b;

    If(boolean b) {
        this.b = b;
    }

    public static If is(final boolean b) {
        return b ? TRUE : FALSE;
    }

    public static If not(final boolean b) {
        return b ? FALSE : TRUE;
    }

    /**
     * {@code true} for {@code index >= 0}, {@code false} for {@code index < 0}.
     * 
     * @param index
     * @return
     */
    public static If exists(final int index) {
        return index >= 0 ? TRUE : FALSE;
    }

    public static If isNullOrEmpty(final CharSequence s) {
        return is(N.isNullOrEmpty(s));
    }

    public static If isNullOrEmpty(final boolean[] a) {
        return is(N.isNullOrEmpty(a));
    }

    public static If isNullOrEmpty(final char[] a) {
        return is(N.isNullOrEmpty(a));
    }

    public static If isNullOrEmpty(final byte[] a) {
        return is(N.isNullOrEmpty(a));
    }

    public static If isNullOrEmpty(final short[] a) {
        return is(N.isNullOrEmpty(a));
    }

    public static If isNullOrEmpty(final int[] a) {
        return is(N.isNullOrEmpty(a));
    }

    public static If isNullOrEmpty(final long[] a) {
        return is(N.isNullOrEmpty(a));
    }

    public static If isNullOrEmpty(final float[] a) {
        return is(N.isNullOrEmpty(a));
    }

    public static If isNullOrEmpty(final double[] a) {
        return is(N.isNullOrEmpty(a));
    }

    public static If isNullOrEmpty(final Object[] a) {
        return is(N.isNullOrEmpty(a));
    }

    public static If isNullOrEmpty(final Collection c) {
        return is(N.isNullOrEmpty(c));
    }

    public static If isNullOrEmpty(final Map m) {
        return is(N.isNullOrEmpty(m));
    }

    @SuppressWarnings("rawtypes")
    public static If isNullOrEmpty(final PrimitiveList list) {
        return is(N.isNullOrEmpty(list));
    }

    public static If isNullOrEmpty(final Multiset s) {
        return is(N.isNullOrEmpty(s));
    }

    public static If isNullOrEmpty(final LongMultiset s) {
        return is(N.isNullOrEmpty(s));
    }

    public static If isNullOrEmpty(final Multimap m) {
        return is(N.isNullOrEmpty(m));
    }

    // DON'T change 'OrEmptyOrBlank' to 'OrBlank' because of the occurring order in the auto-completed context menu. 
    public static If isNullOrEmptyOrBlank(final CharSequence s) {
        return is(N.isNullOrEmptyOrBlank(s));
    }

    public static If notNullOrEmpty(final CharSequence s) {
        return is(N.notNullOrEmpty(s));
    }

    public static If notNullOrEmpty(final boolean[] a) {
        return is(N.notNullOrEmpty(a));
    }

    public static If notNullOrEmpty(final char[] a) {
        return is(N.notNullOrEmpty(a));
    }

    public static If notNullOrEmpty(final byte[] a) {
        return is(N.notNullOrEmpty(a));
    }

    public static If notNullOrEmpty(final short[] a) {
        return is(N.notNullOrEmpty(a));
    }

    public static If notNullOrEmpty(final int[] a) {
        return is(N.notNullOrEmpty(a));
    }

    public static If notNullOrEmpty(final long[] a) {
        return is(N.notNullOrEmpty(a));
    }

    public static If notNullOrEmpty(final float[] a) {
        return is(N.notNullOrEmpty(a));
    }

    public static If notNullOrEmpty(final double[] a) {
        return is(N.notNullOrEmpty(a));
    }

    public static If notNullOrEmpty(final Object[] a) {
        return is(N.notNullOrEmpty(a));
    }

    public static If notNullOrEmpty(final Collection c) {
        return is(N.notNullOrEmpty(c));
    }

    public static If notNullOrEmpty(final Map m) {
        return is(N.notNullOrEmpty(m));
    }

    @SuppressWarnings("rawtypes")
    public static If notNullOrEmpty(final PrimitiveList list) {
        return is(N.notNullOrEmpty(list));
    }

    public static If notNullOrEmpty(final Multiset s) {
        return is(N.notNullOrEmpty(s));
    }

    public static If notNullOrEmpty(final LongMultiset s) {
        return is(N.notNullOrEmpty(s));
    }

    public static If notNullOrEmpty(final Multimap m) {
        return is(N.notNullOrEmpty(m));
    }

    // DON'T change 'OrEmptyOrBlank' to 'OrBlank' because of the occurring order in the auto-completed context menu. 
    public static If notNullOrEmptyOrBlank(final CharSequence s) {
        return is(N.notNullOrEmptyOrBlank(s));
    }

    //    public  void thenRun(final Try.Runnable cmd) throws E {
    //        if (b) {
    //            cmd.run();
    //        }
    //    }
    //
    //    public  void thenRun(final T seed, final Try.Consumer action) throws E {
    //        if (b) {
    //            action.accept(seed);
    //        }
    //    }
    //
    //    public  Nullable thenCall(final Try.Callable callable) throws E {
    //        return b ? Nullable.of(callable.call()) : Nullable. empty();
    //    }
    //
    //    public  Nullable thenCall(final T seed, final Try.Function func) throws E {
    //        return b ? Nullable.of(func.apply(seed)) : Nullable. empty();
    //    }

    public Or thenDoNothing() {
        return Or.of(b);
    }

    public  Or then(final Try.Runnable cmd) throws E {
        N.requireNonNull(cmd);

        if (b) {
            cmd.run();
        }

        return Or.of(b);
    }

    public  Or then(final U seed, final Try.Consumer action) throws E {
        N.requireNonNull(action);

        if (b) {
            action.accept(seed);
        }

        return Or.of(b);
    }

    public  Or thenThrow(final Supplier exceptionSupplier) throws E {
        N.requireNonNull(exceptionSupplier);

        if (b) {
            throw exceptionSupplier.get();
        }

        return Or.of(b);
    }

    //    public  Nullable then(final Try.Callable callable) throws E {
    //        return b ? Nullable.of(callable.call()) : Nullable. empty();
    //    }
    //
    //    public  Nullable then(final T seed, final Try.Function func) throws E {
    //        return b ? Nullable.of(func.apply(seed)) : Nullable. empty();
    //    }

    public static final class Or {
        private static final Or TRUE = new Or(true);
        private static final Or FALSE = new Or(false);

        private final boolean b;

        Or(final boolean b) {
            this.b = b;
        }

        static Or of(boolean b) {
            return b ? TRUE : FALSE;
        }

        void orElseDoNothing() {
            // Do nothing.
        }

        public  void orElse(final Try.Runnable cmd) throws E {
            N.requireNonNull(cmd);

            if (!b) {
                cmd.run();
            }
        }

        public  void orElse(final U seed, final Try.Consumer action) throws E {
            N.requireNonNull(action);

            if (!b) {
                action.accept(seed);
            }
        }

        public  void orElseThrow(final Supplier exceptionSupplier) throws E {
            N.requireNonNull(exceptionSupplier);

            if (!b) {
                throw exceptionSupplier.get();
            }
        }
    }

    /**
     * This class is mainly designed for functional programming. 
     * Generally the traditional "{@code if-else}" or ternary operator: "{@code ? : }" is preferred over this class.
     * 
     * @author HaiYang Li
     *
     */
    @Beta
    public static final class IF {
        private static final IF TRUE = new IF(true);
        private static final IF FALSE = new IF(false);

        @SuppressWarnings("rawtypes")
        private static final Or FALSE_OR = new FalseOr();

        private final boolean b;

        IF(boolean b) {
            this.b = b;
        }

        public static IF is(final boolean b) {
            return b ? TRUE : FALSE;
        }

        public static IF not(final boolean b) {
            return b ? FALSE : TRUE;
        }

        /**
         * {@code true} for {@code index >= 0}, {@code false} for {@code index < 0}.
         * 
         * @param index
         * @return
         */
        public static IF exists(final int index) {
            return index >= 0 ? TRUE : FALSE;
        }

        public static IF isNullOrEmpty(final CharSequence s) {
            return is(N.isNullOrEmpty(s));
        }

        public static IF isNullOrEmpty(final boolean[] a) {
            return is(N.isNullOrEmpty(a));
        }

        public static IF isNullOrEmpty(final char[] a) {
            return is(N.isNullOrEmpty(a));
        }

        public static IF isNullOrEmpty(final byte[] a) {
            return is(N.isNullOrEmpty(a));
        }

        public static IF isNullOrEmpty(final short[] a) {
            return is(N.isNullOrEmpty(a));
        }

        public static IF isNullOrEmpty(final int[] a) {
            return is(N.isNullOrEmpty(a));
        }

        public static IF isNullOrEmpty(final long[] a) {
            return is(N.isNullOrEmpty(a));
        }

        public static IF isNullOrEmpty(final float[] a) {
            return is(N.isNullOrEmpty(a));
        }

        public static IF isNullOrEmpty(final double[] a) {
            return is(N.isNullOrEmpty(a));
        }

        public static IF isNullOrEmpty(final Object[] a) {
            return is(N.isNullOrEmpty(a));
        }

        public static IF isNullOrEmpty(final Collection c) {
            return is(N.isNullOrEmpty(c));
        }

        public static IF isNullOrEmpty(final Map m) {
            return is(N.isNullOrEmpty(m));
        }

        @SuppressWarnings("rawtypes")
        public static IF isNullOrEmpty(final PrimitiveList list) {
            return is(N.isNullOrEmpty(list));
        }

        public static IF isNullOrEmpty(final Multiset s) {
            return is(N.isNullOrEmpty(s));
        }

        public static IF isNullOrEmpty(final LongMultiset s) {
            return is(N.isNullOrEmpty(s));
        }

        public static IF isNullOrEmpty(final Multimap m) {
            return is(N.isNullOrEmpty(m));
        }

        // DON'T change 'OrEmptyOrBlank' to 'OrBlank' because of the occurring order in the auto-completed context menu. 
        public static IF isNullOrEmptyOrBlank(final CharSequence s) {
            return is(N.isNullOrEmptyOrBlank(s));
        }

        public static IF notNullOrEmpty(final CharSequence s) {
            return is(N.notNullOrEmpty(s));
        }

        public static IF notNullOrEmpty(final boolean[] a) {
            return is(N.notNullOrEmpty(a));
        }

        public static IF notNullOrEmpty(final char[] a) {
            return is(N.notNullOrEmpty(a));
        }

        public static IF notNullOrEmpty(final byte[] a) {
            return is(N.notNullOrEmpty(a));
        }

        public static IF notNullOrEmpty(final short[] a) {
            return is(N.notNullOrEmpty(a));
        }

        public static IF notNullOrEmpty(final int[] a) {
            return is(N.notNullOrEmpty(a));
        }

        public static IF notNullOrEmpty(final long[] a) {
            return is(N.notNullOrEmpty(a));
        }

        public static IF notNullOrEmpty(final float[] a) {
            return is(N.notNullOrEmpty(a));
        }

        public static IF notNullOrEmpty(final double[] a) {
            return is(N.notNullOrEmpty(a));
        }

        public static IF notNullOrEmpty(final Object[] a) {
            return is(N.notNullOrEmpty(a));
        }

        public static IF notNullOrEmpty(final Collection c) {
            return is(N.notNullOrEmpty(c));
        }

        public static IF notNullOrEmpty(final Map m) {
            return is(N.notNullOrEmpty(m));
        }

        @SuppressWarnings("rawtypes")
        public static IF notNullOrEmpty(final PrimitiveList list) {
            return is(N.notNullOrEmpty(list));
        }

        public static IF notNullOrEmpty(final Multiset s) {
            return is(N.notNullOrEmpty(s));
        }

        public static IF notNullOrEmpty(final LongMultiset s) {
            return is(N.notNullOrEmpty(s));
        }

        public static IF notNullOrEmpty(final Multimap m) {
            return is(N.notNullOrEmpty(m));
        }

        // DON'T change 'OrEmptyOrBlank' to 'OrBlank' because of the occurring order in the auto-completed context menu. 
        public static IF notNullOrEmptyOrBlank(final CharSequence s) {
            return is(N.notNullOrEmptyOrBlank(s));
        }

        public  Nullable thenGet(Try.Supplier supplier) throws E {
            return b ? Nullable.of(supplier.get()) : Nullable. empty();
        }

        public  Nullable thenApply(final U seed, final Try.Function func) throws E {
            return b ? Nullable.of(func.apply(seed)) : Nullable. empty();
        }

        public  Or then(final Try.Callable callable) throws E {
            N.requireNonNull(callable);

            return b ? new TrueOr<>(Nullable.of(callable.call())) : FALSE_OR;
        }

        public  Or then(final U seed, final Try.Function func) throws E {
            N.requireNonNull(func);

            return b ? new TrueOr<>(Nullable.of(func.apply(seed))) : FALSE_OR;
        }

        public static abstract class Or {
            Or() {
            }

            public abstract  Nullable orElse(final Try.Callable callable) throws E;

            public abstract  Nullable orElse(final U seed, final Try.Function func) throws E;

            public abstract  Nullable orElseThrow(final Supplier exceptionSupplier) throws E;
        }

        static final class TrueOr extends Or {
            private final Nullable result;

            TrueOr(final Nullable result) {
                this.result = result;
            }

            @Override
            public  Nullable orElse(final Try.Callable callable) throws E {
                N.requireNonNull(callable);

                return result;
            }

            @Override
            public  Nullable orElse(final U seed, final Try.Function func) throws E {
                N.requireNonNull(func);

                return result;
            }

            @Override
            public  Nullable orElseThrow(final Supplier exceptionSupplier) throws E {
                N.requireNonNull(exceptionSupplier);

                return result;
            }
        }

        static final class FalseOr extends Or {
            FalseOr() {
            }

            @Override
            public  Nullable orElse(final Try.Callable callable) throws E {
                return Nullable.of(callable.call());
            }

            @Override
            public  Nullable orElse(final U seed, final Try.Function func) throws E {
                return Nullable.of(func.apply(seed));
            }

            @Override
            public  Nullable orElseThrow(final Supplier exceptionSupplier) throws E {
                throw exceptionSupplier.get();
            }
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy