public class org.apache.camel.util.concurrent.SubmitOrderedCompletionService extends java.lang.Object implements java.util.concurrent.CompletionService
{
private final java.util.concurrent.Executor executor;
private final java.util.concurrent.DelayQueue completionQueue;
private final java.util.concurrent.atomic.AtomicInteger id;
private final java.util.concurrent.atomic.AtomicInteger index;
public void <init>(java.util.concurrent.Executor)
{
java.util.concurrent.Executor v;
java.util.concurrent.atomic.AtomicInteger v, v;
java.util.concurrent.DelayQueue v;
org.apache.camel.util.concurrent.SubmitOrderedCompletionService v;
v := @this: org.apache.camel.util.concurrent.SubmitOrderedCompletionService;
v := @parameter: java.util.concurrent.Executor;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.DelayQueue;
specialinvoke v.<java.util.concurrent.DelayQueue: void <init>()>();
v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.DelayQueue completionQueue> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.atomic.AtomicInteger id> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.atomic.AtomicInteger index> = v;
v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.Executor executor> = v;
return;
}
public java.util.concurrent.Future submit(java.util.concurrent.Callable)
{
java.util.concurrent.Executor v;
java.util.concurrent.atomic.AtomicInteger v;
int v;
org.apache.camel.util.concurrent.SubmitOrderedCompletionService$SubmitOrderFutureTask v;
org.apache.camel.util.concurrent.SubmitOrderedCompletionService v;
java.util.concurrent.Callable v;
java.lang.IllegalArgumentException v;
v := @this: org.apache.camel.util.concurrent.SubmitOrderedCompletionService;
v := @parameter: java.util.concurrent.Callable;
if v != null goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Task must be provided");
throw v;
label:
v = new org.apache.camel.util.concurrent.SubmitOrderedCompletionService$SubmitOrderFutureTask;
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.atomic.AtomicInteger id>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
specialinvoke v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService$SubmitOrderFutureTask: void <init>(org.apache.camel.util.concurrent.SubmitOrderedCompletionService,long,java.util.concurrent.Callable)>(v, v, v);
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.Executor executor>;
interfaceinvoke v.<java.util.concurrent.Executor: void execute(java.lang.Runnable)>(v);
return v;
}
public java.util.concurrent.Future submit(java.lang.Runnable, java.lang.Object)
{
java.util.concurrent.Executor v;
org.apache.camel.util.concurrent.SubmitOrderedCompletionService v;
java.lang.IllegalArgumentException v;
java.lang.Runnable v;
java.util.concurrent.atomic.AtomicInteger v;
int v;
org.apache.camel.util.concurrent.SubmitOrderedCompletionService$SubmitOrderFutureTask v;
java.lang.Object v;
v := @this: org.apache.camel.util.concurrent.SubmitOrderedCompletionService;
v := @parameter: java.lang.Runnable;
v := @parameter: java.lang.Object;
if v != null goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Task must be provided");
throw v;
label:
v = new org.apache.camel.util.concurrent.SubmitOrderedCompletionService$SubmitOrderFutureTask;
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.atomic.AtomicInteger id>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
specialinvoke v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService$SubmitOrderFutureTask: void <init>(org.apache.camel.util.concurrent.SubmitOrderedCompletionService,long,java.lang.Runnable,java.lang.Object)>(v, v, v, null);
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.Executor executor>;
interfaceinvoke v.<java.util.concurrent.Executor: void execute(java.lang.Runnable)>(v);
return v;
}
public java.util.concurrent.Future take() throws java.lang.InterruptedException
{
java.util.concurrent.atomic.AtomicInteger v;
java.util.concurrent.DelayQueue v;
org.apache.camel.util.concurrent.SubmitOrderedCompletionService v;
java.util.concurrent.Delayed v;
v := @this: org.apache.camel.util.concurrent.SubmitOrderedCompletionService;
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.atomic.AtomicInteger index>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.DelayQueue completionQueue>;
v = virtualinvoke v.<java.util.concurrent.DelayQueue: java.util.concurrent.Delayed take()>();
return v;
}
public java.util.concurrent.Future poll()
{
java.util.concurrent.atomic.AtomicInteger v, v;
java.util.concurrent.DelayQueue v;
org.apache.camel.util.concurrent.SubmitOrderedCompletionService v;
java.util.concurrent.Delayed v;
v := @this: org.apache.camel.util.concurrent.SubmitOrderedCompletionService;
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.atomic.AtomicInteger index>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.DelayQueue completionQueue>;
v = virtualinvoke v.<java.util.concurrent.DelayQueue: java.util.concurrent.Delayed poll()>();
if v != null goto label;
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.atomic.AtomicInteger index>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int decrementAndGet()>();
label:
return v;
}
public java.util.concurrent.Future poll(long, java.util.concurrent.TimeUnit) throws java.lang.InterruptedException
{
java.util.concurrent.TimeUnit v;
java.util.concurrent.atomic.AtomicInteger v, v;
java.util.concurrent.DelayQueue v;
org.apache.camel.util.concurrent.SubmitOrderedCompletionService v;
long v;
java.util.concurrent.Delayed v;
v := @this: org.apache.camel.util.concurrent.SubmitOrderedCompletionService;
v := @parameter: long;
v := @parameter: java.util.concurrent.TimeUnit;
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.atomic.AtomicInteger index>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.DelayQueue completionQueue>;
v = virtualinvoke v.<java.util.concurrent.DelayQueue: java.util.concurrent.Delayed poll(long,java.util.concurrent.TimeUnit)>(v, v);
if v != null goto label;
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.atomic.AtomicInteger index>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int decrementAndGet()>();
label:
return v;
}
public void timeoutTask()
{
org.apache.camel.util.concurrent.SubmitOrderedCompletionService v;
java.util.concurrent.atomic.AtomicInteger v;
v := @this: org.apache.camel.util.concurrent.SubmitOrderedCompletionService;
v = v.<org.apache.camel.util.concurrent.SubmitOrderedCompletionService: java.util.concurrent.atomic.AtomicInteger index>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
return;
}
}