com.landawn.abacus.util.If Maven / Gradle / Ivy
/*
* 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 super T, E> action) throws E {
// if (b) {
// action.accept(seed);
// }
// }
//
// public Nullable thenCall(final Try.Callable extends T, E> callable) throws E {
// return b ? Nullable.of(callable.call()) : Nullable. empty();
// }
//
// public Nullable thenCall(final T seed, final Try.Function super T, R, E> 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 super U, E> action) throws E {
N.requireNonNull(action);
if (b) {
action.accept(seed);
}
return Or.of(b);
}
public Or thenThrow(final Supplier extends E> 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 super T, R, E> 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 super U, E> action) throws E {
N.requireNonNull(action);
if (!b) {
action.accept(seed);
}
}
public void orElseThrow(final Supplier extends E> 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
@Deprecated
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 super U, T, E> 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<>(callable.call()) : FALSE_OR;
}
public Or then(final U seed, final Try.Function super U, T, E> func) throws E {
N.requireNonNull(func);
return b ? new TrueOr<>(func.apply(seed)) : FALSE_OR;
}
public static abstract class Or {
Or() {
}
public abstract T orElse(final Try.Callable callable) throws E;
public abstract T orElse(final U seed, final Try.Function super U, T, E> func) throws E;
public abstract T orElseThrow(final Supplier extends E> exceptionSupplier) throws E;
}
static final class TrueOr extends Or {
private final T result;
TrueOr(final T result) {
this.result = result;
}
@Override
public T orElse(final Try.Callable callable) throws E {
N.requireNonNull(callable);
return result;
}
@Override
public T orElse(final U seed, final Try.Function super U, T, E> func) throws E {
N.requireNonNull(func);
return result;
}
@Override
public T orElseThrow(final Supplier extends E> exceptionSupplier) throws E {
N.requireNonNull(exceptionSupplier);
return result;
}
}
static final class FalseOr extends Or {
FalseOr() {
}
@Override
public T orElse(final Try.Callable callable) throws E {
return callable.call();
}
@Override
public T orElse(final U seed, final Try.Function super U, T, E> func) throws E {
return func.apply(seed);
}
@Override
public T orElseThrow(final Supplier extends E> exceptionSupplier) throws E {
throw exceptionSupplier.get();
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy