Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
 package org.infinispan.commons.util.concurrent;
 
 import java.util.List;
For use with > 1 underlying network future

Author(s):
Manik Surtani
Since:
4.0
public class AggregatingNotifyingFutureImpl<T> extends NotifyingFutureImpl<T> {
   final List<Future<T>> futures;
   public AggregatingNotifyingFutureImpl(T actualReturnValueint maxFutures) {
      super(actualReturnValue);
       = new ArrayList<Future<T>>(maxFutures);
      .set(maxFutures);
   }
   @Override
   public void setNetworkFuture(Future<T> future) {
      .add(future);
   }
   @Override
   public boolean cancel(boolean mayInterruptIfRunning) {
      boolean aggregateValue = false;
      for (Future<T> f : aggregateValue = f.cancel(mayInterruptIfRunning) && aggregateValue;
      return aggregateValue;
   }
   @Override
   public boolean isCancelled() {
      for (Future<T> f : if (f.isCancelled()) return true;
      return false;
   }
   @Override
   public boolean isDone() {
      for (Future<T> f : if (!f.isDone()) return false;
      return true;
   }
   @Override
   public T get() throws InterruptedExceptionExecutionException {
      for (Future<T> f : f.get();
      return ;
   }
   @Override
   public T get(long timeoutTimeUnit unitthrows InterruptedExceptionExecutionExceptionjava.util.concurrent.TimeoutException {
      for (Future<T> f : f.get(timeoutunit);
      return ;
   }
   @Override
   public void notifyDone() {
      if (.decrementAndGet() == 0) super.notifyDone();
   }
New to GrepCode? Check out our FAQ X