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

com.minlia.cloud.config.async.CompletableExecutors Maven / Gradle / Ivy

/*
 * Copyright © 2016 Minlia (http://oss.minlia.com/license/framework/2016)
 *
 * 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.minlia.cloud.config.async;

import java.util.Collection;
import java.util.List;
import java.util.concurrent.*;

import static java.util.concurrent.Executors.callable;

/**
 * Inspired by:
 * http://binkley.blogspot.fr/2014/12/completablefuture-and-executorservice.html
 */
public final class CompletableExecutors {

    public static CompletableExecutorService completable(ExecutorService delegate) {
        return new DelegatingCompletableExecutorService(delegate);
    }

    /**
     * DelegatingCompletableExecutorService {@code ExecutorService} to covariantly return {@code
     * CompletableFuture} in place of {@code Future}.
     */
    public interface CompletableExecutorService extends ExecutorService {
        /**
         * @return a completable future representing pending completion of the
         * task, never missing
         */
        @Override
         CompletableFuture submit(Callable task);

        /**
         * @return a completable future representing pending completion of the
         * task, never missing
         */
        @Override
         CompletableFuture submit(Runnable task, T result);

        /**
         * @return a completable future representing pending completion of the
         * task, never missing
         */
        @Override
        CompletableFuture submit(Runnable task);
    }

    static class DelegatingCompletableExecutorService extends DelegatingExecutorService implements CompletableExecutorService {

        DelegatingCompletableExecutorService(ExecutorService threads) {
            super(threads);
        }

        @Override public  CompletableFuture submit(Callable task) {
            final CompletableFuture cf = new CompletableFuture<>();
            delegate.submit(() -> {
                try {
                    cf.complete(task.call());
                } catch (CancellationException e) {
                    cf.cancel(true);
                } catch (Exception e) {
                    cf.completeExceptionally(e);
                }
            });
            return cf;
        }

        @Override
        public  CompletableFuture submit(Runnable task, T result) {
            return submit(callable(task, result));
        }

        @Override
        public CompletableFuture submit(Runnable task) {
            return submit(callable(task));
        }
    }

    /**
     * Executor service that delegates everything to another one
     */
    static class DelegatingExecutorService implements ExecutorService {
        protected ExecutorService delegate;

        public DelegatingExecutorService(ExecutorService executorService) {
            this.delegate = executorService;
        }

        @Override
        public  Future submit(Callable task) {
            return delegate.submit(task);
        }

        @Override
        public  Future submit(Runnable task, T result) {
            return delegate.submit(task, result);
        }

        @Override
        public Future submit(Runnable task) {
            return delegate.submit(task);
        }

        @Override
        public void shutdown() {
            delegate.shutdown();
        }

        @Override
        public List shutdownNow() {
            return delegate.shutdownNow();
        }

        @Override
        public boolean isShutdown() {
            return delegate.isShutdown();
        }

        @Override
        public boolean isTerminated() {
            return delegate.isTerminated();
        }

        @Override
        public boolean awaitTermination(long timeout, TimeUnit unit) throws InterruptedException {
            return delegate.awaitTermination(timeout, unit);
        }

        @Override
        public  List> invokeAll(Collection> tasks) throws InterruptedException {
            return delegate.invokeAll(tasks);
        }

        @Override
        public  List> invokeAll(Collection> tasks, long timeout, TimeUnit unit) throws InterruptedException {
            return delegate.invokeAll(tasks, timeout, unit);
        }

        @Override
        public  T invokeAny(Collection> tasks) throws InterruptedException, ExecutionException {
            return delegate.invokeAny(tasks);
        }

        @Override
        public  T invokeAny(Collection> tasks, long timeout, TimeUnit unit) throws InterruptedException, ExecutionException, TimeoutException {
            return delegate.invokeAny(tasks, timeout, unit);
        }

        @Override
        public void execute(Runnable command) {
            delegate.execute(command);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy