
org.jdeferred.impl.AbstractDeferredManager Maven / Gradle / Ivy
Show all versions of jdeferred-core Show documentation
/*
* Copyright 2013 Ray Tsang
*
* 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 org.jdeferred.impl;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
import org.jdeferred.DeferredCallable;
import org.jdeferred.DeferredFutureTask;
import org.jdeferred.DeferredManager;
import org.jdeferred.DeferredRunnable;
import org.jdeferred.Promise;
import org.jdeferred.multiple.MasterProgress;
import org.jdeferred.multiple.MasterDeferredObject;
import org.jdeferred.multiple.MultipleResults;
import org.jdeferred.multiple.OneReject;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@SuppressWarnings({ "rawtypes", "unchecked" })
public abstract class AbstractDeferredManager implements DeferredManager {
final protected Logger log = LoggerFactory.getLogger(AbstractDeferredManager.class);
protected abstract void submit(Runnable runnable);
protected abstract void submit(Callable callable);
/**
* Should {@link Runnable} or {@link Callable} be submitted for execution automatically
* when any of the following are called
*
* - {@link #when(Runnable...)}
* - {@link #when(Callable...)}
* - {@link #when(DeferredFutureTask...))}
* - {@link #when(DeferredCallable)}
* - {@link #when(DeferredRunnable)}
* - {@link #when(DeferredFutureTask))}
*
* @return
*/
public abstract boolean isAutoSubmit();
@Override
public Promise when(Runnable... runnables) {
assertNotEmpty(runnables);
Promise[] promises = new Promise[runnables.length];
for (int i = 0; i < runnables.length; i++) {
if (runnables[i] instanceof DeferredRunnable)
promises[i] = when((DeferredRunnable) runnables[i]);
else
promises[i] = when(runnables[i]);
}
return when(promises);
}
@Override
public Promise when(Callable>... callables) {
assertNotEmpty(callables);
Promise[] promises = new Promise[callables.length];
for (int i = 0; i < callables.length; i++) {
if (callables[i] instanceof DeferredCallable)
promises[i] = when((DeferredCallable) callables[i]);
else
promises[i] = when(callables[i]);
}
return when(promises);
}
@Override
public Promise when(DeferredRunnable>... runnables) {
assertNotEmpty(runnables);
Promise[] promises = new Promise[runnables.length];
for (int i = 0; i < runnables.length; i++) {
promises[i] = when(runnables[i]);
}
return when(promises);
}
@Override
public Promise when(DeferredCallable, ?>... callables) {
assertNotEmpty(callables);
Promise[] promises = new Promise[callables.length];
for (int i = 0; i < callables.length; i++) {
promises[i] = when(callables[i]);
}
return when(promises);
}
@Override
public Promise when(DeferredFutureTask, ?>... tasks) {
assertNotEmpty(tasks);
Promise[] promises = new Promise[tasks.length];
for (int i = 0; i < tasks.length; i++) {
promises[i] = when(tasks[i]);
}
return when(promises);
}
@Override
public Promise when(Future> ... futures) {
assertNotEmpty(futures);
Promise[] promises = new Promise[futures.length];
for (int i = 0; i < futures.length; i++) {
promises[i] = when(futures[i]);
}
return when(promises);
}
@Override
public Promise when(Promise... promises) {
assertNotEmpty(promises);
return new MasterDeferredObject(promises).promise();
}
@Override
public Promise when(Promise promise) {
return promise;
}
@Override
public Promise when(DeferredRunnable runnable) {
return when(new DeferredFutureTask(runnable));
}
@Override
public Promise when(DeferredCallable runnable) {
return when(new DeferredFutureTask(runnable));
}
@Override
public Promise when(Runnable runnable) {
return when(new DeferredFutureTask(runnable));
}
@Override
public Promise when(Callable callable) {
return when(new DeferredFutureTask(callable));
}
/**
* This method is delegated by at least the following methods
*
* - {@link #when(Callable)}
* - {@link #when(Callable...)}
* - {@link #when(Runnable)}
* - {@link #when(Runnable..)}
* - {@link #when(java.util.concurrent.Future)}
* - {@link #when(java.util.concurrent.Future...)}
* - {@link #when(org.jdeferred.DeferredRunnable...)}
* - {@link #when(org.jdeferred.DeferredRunnable)}
* - {@link #when(org.jdeferred.DeferredCallable...)}
* - {@link #when(org.jdeferred.DeferredCallable)}
* - {@link #when(DeferredFutureTask...)}
*
*/
@Override
public Promise when(
DeferredFutureTask task) {
if (task.getStartPolicy() == StartPolicy.AUTO
|| (task.getStartPolicy() == StartPolicy.DEFAULT && isAutoSubmit()))
submit(task);
return task.promise();
}
@Override
public Promise when(final Future future) {
// make sure the task is automatically started
return when(new DeferredCallable(StartPolicy.AUTO) {
@Override
public D call() throws Exception {
try {
return future.get();
} catch (InterruptedException e) {
throw e;
} catch (ExecutionException e) {
if (e.getCause() instanceof Exception)
throw (Exception) e.getCause();
else throw e;
}
}
});
}
protected void assertNotEmpty(Object[] objects) {
if (objects == null || objects.length == 0)
throw new IllegalArgumentException(
"Arguments is null or its length is empty");
}
}