com.landawn.abacus.util.Result Maven / Gradle / Ivy
/*
* Copyright (c) 2019, 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 com.landawn.abacus.util.Tuple.Tuple2;
import com.landawn.abacus.util.function.Function;
import com.landawn.abacus.util.function.Supplier;
/**
*
* @author Haiyang Li
* @param
* @param
*/
@com.landawn.abacus.annotation.Immutable
public final class Result implements Immutable {
private final T value;
private final E exception;
Result(T value, E exception) {
this.value = value;
this.exception = exception;
}
/**
*
* @param
* @param
* @param value
* @param exception
* @return
*/
public static Result of(final T value, final E exception) {
return new Result<>(value, exception);
}
/**
* Checks if is failure.
*
* @return true, if is failure
*/
public boolean isFailure() {
return exception != null;
}
/**
* Checks if is success.
*
* @return true, if is success
*/
public boolean isSuccess() {
return exception == null;
}
/**
*
* @param
* @param actionOnFailure
* @throws E2 the e2
*/
public void ifFailure(final Throwables.Consumer super E, E2> actionOnFailure) throws E2 {
ifFailureOrElse(actionOnFailure, Fn.doNothing());
}
/**
* If failure or else.
*
* @param
* @param
* @param actionOnFailure
* @param actionOnSuccess
* @throws E2 the e2
* @throws E3 the e3
*/
public void ifFailureOrElse(final Throwables.Consumer super E, E2> actionOnFailure,
final Throwables.Consumer super T, E3> actionOnSuccess) throws E2, E3 {
N.checkArgNotNull(actionOnFailure, "actionOnFailure");
N.checkArgNotNull(actionOnSuccess, "actionOnSuccess");
if (exception != null) {
actionOnFailure.accept(exception);
} else {
actionOnSuccess.accept(value);
}
}
/**
*
* @param
* @param actionOnSuccess
* @throws E2 the e2
*/
public void ifSuccess(final Throwables.Consumer super T, E2> actionOnSuccess) throws E2 {
ifSuccessOrElse(actionOnSuccess, Fn.doNothing());
}
/**
* If success or else.
*
* @param
* @param
* @param actionOnSuccess
* @param actionOnFailure
* @throws E2 the e2
* @throws E3 the e3
*/
public void ifSuccessOrElse(final Throwables.Consumer super T, E2> actionOnSuccess,
final Throwables.Consumer super E, E3> actionOnFailure) throws E2, E3 {
N.checkArgNotNull(actionOnSuccess, "actionOnSuccess");
N.checkArgNotNull(actionOnFailure, "actionOnFailure");
if (exception == null) {
actionOnSuccess.accept(value);
} else {
actionOnFailure.accept(exception);
}
}
/**
*
* @param defaultValueIfErrorOccurred
* @return
* @deprecated replaced with {@link #orElseIfFailure(Object)}
*/
@Deprecated
public T orElse(final T defaultValueIfErrorOccurred) {
return orElseIfFailure(defaultValueIfErrorOccurred);
}
/**
*
* @param
* @param otherIfErrorOccurred
* @return
* @throws E2
* @deprecated replaced with {@link #orElseGetIfFailure(com.landawn.abacus.util.Throwables.Supplier)}
*/
@Deprecated
public T orElseGet(final Throwables.Supplier extends T, E2> otherIfErrorOccurred) throws E2 {
return orElseGetIfFailure(otherIfErrorOccurred);
}
/**
*
* @param defaultValueIfErrorOccurred
* @return
*/
public T orElseIfFailure(final T defaultValueIfErrorOccurred) {
if (exception == null) {
return value;
} else {
return defaultValueIfErrorOccurred;
}
}
/**
*
* @param
* @param otherIfErrorOccurred
* @return
* @throws E2
*/
public T orElseGetIfFailure(final Throwables.Supplier extends T, E2> otherIfErrorOccurred) throws E2 {
N.checkArgNotNull(otherIfErrorOccurred, "otherIfErrorOccurred");
if (exception == null) {
return value;
} else {
return otherIfErrorOccurred.get();
}
}
/**
* Or else throw.
*
* @return
* @throws E the e
*/
public T orElseThrow() throws E {
if (exception == null) {
return value;
} else {
throw exception;
}
}
/**
* Or else throw.
*
* @param
* @param exceptionSupplierIfErrorOccurred
* @return
* @throws E2 the e2
*/
public T orElseThrow(final Function super E, E2> exceptionSupplierIfErrorOccurred) throws E2 {
N.checkArgNotNull(exceptionSupplierIfErrorOccurred, "exceptionSupplierIfErrorOccurred");
if (exception == null) {
return value;
} else {
throw exceptionSupplierIfErrorOccurred.apply(exception);
}
}
/**
*
* @param
* @param exception
* @return
* @throws E2
*/
public T orElseThrow(final E2 exception) throws E2 {
if (exception == null) {
return value;
} else {
throw exception;
}
}
/**
*
* @param
* @param exceptionSupplier
* @return
* @throws E2
*/
public T orElseThrow(final Supplier extends E2> exceptionSupplier) throws E2 {
if (exception == null) {
return value;
} else {
throw exceptionSupplier.get();
}
}
/**
* Returns the {@code Exception} if occurred, otherwise {@code null} is returned.
*
* @return
*/
public E getExceptionIfPresent() {
return exception;
}
// /**
// *
// * @return
// * @deprecated
// */
// @Deprecated
// public Nullable toNullable() {
// return exception == null ? Nullable.of(value) : Nullable. empty();
// }
public Pair toPair() {
return Pair.of(value, exception);
}
public Tuple2 toTuple() {
return Tuple.of(value, exception);
}
@Override
public int hashCode() {
return (exception == null) ? N.hashCode(value) : exception.hashCode();
}
/**
*
* @param obj
* @return
*/
@SuppressWarnings("rawtypes")
@Override
public boolean equals(final Object obj) {
if (this == obj) {
return true;
}
if (obj instanceof Result) {
final Result other = (Result) obj;
return N.equals(other.value, value) && N.equals(other.exception, exception);
}
return false;
}
@Override
public String toString() {
return "{value=" + N.toString(value) + ", exception=" + N.toString(exception) + "}";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy