CPD: Re-implement deprecated code to use new code

This commit is contained in:
Gary Gregory 2022-08-26 16:29:57 -04:00
parent 318b2cb7e2
commit 8b75877f59
1 changed files with 6 additions and 34 deletions

View File

@ -32,6 +32,7 @@ import java.util.function.Supplier;
import java.util.stream.Stream; import java.util.stream.Stream;
import org.apache.commons.lang3.Streams.FailableStream; import org.apache.commons.lang3.Streams.FailableStream;
import org.apache.commons.lang3.function.Failable;
import org.apache.commons.lang3.function.FailableBooleanSupplier; import org.apache.commons.lang3.function.FailableBooleanSupplier;
/** /**
@ -629,41 +630,12 @@ public class Functions {
public static void tryWithResources(final FailableRunnable<? extends Throwable> action, public static void tryWithResources(final FailableRunnable<? extends Throwable> action,
final FailableConsumer<Throwable, ? extends Throwable> errorHandler, final FailableConsumer<Throwable, ? extends Throwable> errorHandler,
final FailableRunnable<? extends Throwable>... resources) { final FailableRunnable<? extends Throwable>... resources) {
final FailableConsumer<Throwable, ? extends Throwable> actualErrorHandler; org.apache.commons.lang3.function.FailableRunnable<?>[] fr = new org.apache.commons.lang3.function.FailableRunnable[resources.length];
if (errorHandler == null) { for (int i = 0; i < resources.length; i++) {
actualErrorHandler = Functions::rethrow; final int fi = i;
} else { fr[i] = () -> resources[fi].run();
actualErrorHandler = errorHandler;
}
if (resources != null) {
for (final FailableRunnable<? extends Throwable> failableRunnable : resources) {
Objects.requireNonNull(failableRunnable, "runnable");
}
}
Throwable th = null;
try {
action.run();
} catch (final Throwable t) {
th = t;
}
if (resources != null) {
for (final FailableRunnable<?> runnable : resources) {
try {
runnable.run();
} catch (final Throwable t) {
if (th == null) {
th = t;
}
}
}
}
if (th != null) {
try {
actualErrorHandler.accept(th);
} catch (final Throwable t) {
throw rethrow(t);
}
} }
Failable.tryWithResources(action::run, errorHandler != null ? errorHandler::accept : null, fr);
} }
/** /**