public class org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler extends org.springframework.scheduling.concurrent.ExecutorConfigurationSupport implements org.springframework.core.task.AsyncListenableTaskExecutor, org.springframework.scheduling.SchedulingTaskExecutor, org.springframework.scheduling.TaskScheduler
{
private static final boolean setRemoveOnCancelPolicyAvailable;
private volatile int poolSize;
private volatile boolean removeOnCancelPolicy;
private volatile org.springframework.util.ErrorHandler errorHandler;
private volatile java.util.concurrent.ScheduledExecutorService scheduledExecutor;
public void <init>()
{
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
specialinvoke v.<org.springframework.scheduling.concurrent.ExecutorConfigurationSupport: void <init>()>();
v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: int poolSize> = 1;
v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: boolean removeOnCancelPolicy> = 0;
return;
}
public void setPoolSize(int)
{
int v;
java.util.concurrent.ScheduledExecutorService v, v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
boolean v, v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: int;
if v <= 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
staticinvoke <org.springframework.util.Assert: void isTrue(boolean,java.lang.String)>(v, "\'poolSize\' must be 1 or higher");
v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: int poolSize> = v;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
v = v instanceof java.util.concurrent.ScheduledThreadPoolExecutor;
if v == 0 goto label;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
virtualinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: void setCorePoolSize(int)>(v);
label:
return;
}
public void setRemoveOnCancelPolicy(boolean)
{
java.util.concurrent.ScheduledExecutorService v, v, v;
org.apache.commons.logging.Log v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
boolean v, v, v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: boolean;
v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: boolean removeOnCancelPolicy> = v;
v = <org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: boolean setRemoveOnCancelPolicyAvailable>;
if v == 0 goto label;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
v = v instanceof java.util.concurrent.ScheduledThreadPoolExecutor;
if v == 0 goto label;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
virtualinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: void setRemoveOnCancelPolicy(boolean)>(v);
goto label;
label:
if v == 0 goto label;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
if v == null goto label;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: org.apache.commons.logging.Log logger>;
interfaceinvoke v.<org.apache.commons.logging.Log: void info(java.lang.Object)>("Could not apply remove-on-cancel policy - not a Java 7+ ScheduledThreadPoolExecutor");
label:
return;
}
public void setErrorHandler(org.springframework.util.ErrorHandler)
{
org.springframework.util.ErrorHandler v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: org.springframework.util.ErrorHandler;
v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: org.springframework.util.ErrorHandler errorHandler> = v;
return;
}
protected java.util.concurrent.ExecutorService initializeExecutor(java.util.concurrent.ThreadFactory, java.util.concurrent.RejectedExecutionHandler)
{
java.util.concurrent.RejectedExecutionHandler v;
int v;
java.util.concurrent.ScheduledExecutorService v, v, v, v;
org.apache.commons.logging.Log v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
java.util.concurrent.ThreadFactory v;
boolean v, v, v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.util.concurrent.ThreadFactory;
v := @parameter: java.util.concurrent.RejectedExecutionHandler;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: int poolSize>;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService createExecutor(int,java.util.concurrent.ThreadFactory,java.util.concurrent.RejectedExecutionHandler)>(v, v, v);
v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor> = v;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: boolean removeOnCancelPolicy>;
if v == 0 goto label;
v = <org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: boolean setRemoveOnCancelPolicyAvailable>;
if v == 0 goto label;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
v = v instanceof java.util.concurrent.ScheduledThreadPoolExecutor;
if v == 0 goto label;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
virtualinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: void setRemoveOnCancelPolicy(boolean)>(1);
goto label;
label:
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: org.apache.commons.logging.Log logger>;
interfaceinvoke v.<org.apache.commons.logging.Log: void info(java.lang.Object)>("Could not apply remove-on-cancel policy - not a Java 7+ ScheduledThreadPoolExecutor");
label:
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
return v;
}
protected java.util.concurrent.ScheduledExecutorService createExecutor(int, java.util.concurrent.ThreadFactory, java.util.concurrent.RejectedExecutionHandler)
{
java.util.concurrent.RejectedExecutionHandler v;
int v;
java.util.concurrent.ScheduledThreadPoolExecutor v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
java.util.concurrent.ThreadFactory v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: int;
v := @parameter: java.util.concurrent.ThreadFactory;
v := @parameter: java.util.concurrent.RejectedExecutionHandler;
v = new java.util.concurrent.ScheduledThreadPoolExecutor;
specialinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: void <init>(int,java.util.concurrent.ThreadFactory,java.util.concurrent.RejectedExecutionHandler)>(v, v, v);
return v;
}
public java.util.concurrent.ScheduledExecutorService getScheduledExecutor() throws java.lang.IllegalStateException
{
java.util.concurrent.ScheduledExecutorService v, v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
boolean v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
staticinvoke <org.springframework.util.Assert: void state(boolean,java.lang.String)>(v, "ThreadPoolTaskScheduler not initialized");
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
return v;
}
public java.util.concurrent.ScheduledThreadPoolExecutor getScheduledThreadPoolExecutor() throws java.lang.IllegalStateException
{
java.util.concurrent.ScheduledExecutorService v, v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
boolean v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
v = v instanceof java.util.concurrent.ScheduledThreadPoolExecutor;
staticinvoke <org.springframework.util.Assert: void state(boolean,java.lang.String)>(v, "No ScheduledThreadPoolExecutor available");
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
return v;
}
public int getPoolSize()
{
int v, v;
java.util.concurrent.ScheduledExecutorService v;
java.util.concurrent.ScheduledThreadPoolExecutor v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
if v != null goto label;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: int poolSize>;
return v;
label:
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledThreadPoolExecutor getScheduledThreadPoolExecutor()>();
v = virtualinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: int getPoolSize()>();
return v;
}
public boolean isRemoveOnCancelPolicy()
{
java.util.concurrent.ScheduledExecutorService v;
java.util.concurrent.ScheduledThreadPoolExecutor v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
boolean v, v, v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v = <org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: boolean setRemoveOnCancelPolicyAvailable>;
if v != 0 goto label;
return 0;
label:
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
if v != null goto label;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: boolean removeOnCancelPolicy>;
return v;
label:
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledThreadPoolExecutor getScheduledThreadPoolExecutor()>();
v = virtualinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: boolean getRemoveOnCancelPolicy()>();
return v;
}
public int getActiveCount()
{
int v;
java.util.concurrent.ScheduledExecutorService v;
java.util.concurrent.ScheduledThreadPoolExecutor v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService scheduledExecutor>;
if v != null goto label;
return 0;
label:
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledThreadPoolExecutor getScheduledThreadPoolExecutor()>();
v = virtualinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: int getActiveCount()>();
return v;
}
public void execute(java.lang.Runnable)
{
java.util.concurrent.RejectedExecutionException v;
java.util.concurrent.ScheduledExecutorService v;
org.springframework.core.task.TaskRejectedException v;
java.lang.String v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
java.lang.Runnable v, v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.lang.Runnable;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService getScheduledExecutor()>();
label:
v = specialinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.lang.Runnable errorHandlingTask(java.lang.Runnable,boolean)>(v, 0);
interfaceinvoke v.<java.util.concurrent.Executor: void execute(java.lang.Runnable)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new org.springframework.core.task.TaskRejectedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.ScheduledExecutorService,java.lang.Runnable)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor [\u] did not accept task: \u0001");
specialinvoke v.<org.springframework.core.task.TaskRejectedException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
public void execute(java.lang.Runnable, long)
{
long v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
java.lang.Runnable v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.lang.Runnable;
v := @parameter: long;
virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: void execute(java.lang.Runnable)>(v);
return;
}
public java.util.concurrent.Future submit(java.lang.Runnable)
{
org.springframework.core.task.TaskRejectedException v;
java.lang.Runnable v, v;
java.util.concurrent.Future v;
java.util.concurrent.RejectedExecutionException v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.lang.Runnable;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService getScheduledExecutor()>();
label:
v = specialinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.lang.Runnable errorHandlingTask(java.lang.Runnable,boolean)>(v, 0);
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: java.util.concurrent.Future submit(java.lang.Runnable)>(v);
label:
return v;
label:
v := @caughtexception;
v = new org.springframework.core.task.TaskRejectedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.ScheduledExecutorService,java.lang.Runnable)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor [\u] did not accept task: \u0001");
specialinvoke v.<org.springframework.core.task.TaskRejectedException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
public java.util.concurrent.Future submit(java.util.concurrent.Callable)
{
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler$DelegatingErrorHandlingCallable v;
java.util.concurrent.Callable v, v;
org.springframework.core.task.TaskRejectedException v;
org.springframework.util.ErrorHandler v, v;
java.util.concurrent.Future v;
java.util.concurrent.RejectedExecutionException v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.util.concurrent.Callable;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService getScheduledExecutor()>();
label:
v = v;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: org.springframework.util.ErrorHandler errorHandler>;
if v == null goto label;
v = new org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler$DelegatingErrorHandlingCallable;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: org.springframework.util.ErrorHandler errorHandler>;
specialinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler$DelegatingErrorHandlingCallable: void <init>(java.util.concurrent.Callable,org.springframework.util.ErrorHandler)>(v, v);
v = v;
label:
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: java.util.concurrent.Future submit(java.util.concurrent.Callable)>(v);
label:
return v;
label:
v := @caughtexception;
v = new org.springframework.core.task.TaskRejectedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.ScheduledExecutorService,java.util.concurrent.Callable)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor [\u] did not accept task: \u0001");
specialinvoke v.<org.springframework.core.task.TaskRejectedException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
public org.springframework.util.concurrent.ListenableFuture submitListenable(java.lang.Runnable)
{
org.springframework.core.task.TaskRejectedException v;
java.lang.Runnable v, v;
java.util.concurrent.RejectedExecutionException v;
org.springframework.util.concurrent.ListenableFutureTask v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.lang.Runnable;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService getScheduledExecutor()>();
label:
v = new org.springframework.util.concurrent.ListenableFutureTask;
specialinvoke v.<org.springframework.util.concurrent.ListenableFutureTask: void <init>(java.lang.Runnable,java.lang.Object)>(v, null);
v = specialinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.lang.Runnable errorHandlingTask(java.lang.Runnable,boolean)>(v, 0);
interfaceinvoke v.<java.util.concurrent.ExecutorService: void execute(java.lang.Runnable)>(v);
label:
return v;
label:
v := @caughtexception;
v = new org.springframework.core.task.TaskRejectedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.ScheduledExecutorService,java.lang.Runnable)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor [\u] did not accept task: \u0001");
specialinvoke v.<org.springframework.core.task.TaskRejectedException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
public org.springframework.util.concurrent.ListenableFuture submitListenable(java.util.concurrent.Callable)
{
java.util.concurrent.Callable v;
org.springframework.core.task.TaskRejectedException v;
java.lang.Runnable v;
java.util.concurrent.RejectedExecutionException v;
org.springframework.util.concurrent.ListenableFutureTask v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.util.concurrent.Callable;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService getScheduledExecutor()>();
label:
v = new org.springframework.util.concurrent.ListenableFutureTask;
specialinvoke v.<org.springframework.util.concurrent.ListenableFutureTask: void <init>(java.util.concurrent.Callable)>(v);
v = specialinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.lang.Runnable errorHandlingTask(java.lang.Runnable,boolean)>(v, 0);
interfaceinvoke v.<java.util.concurrent.ExecutorService: void execute(java.lang.Runnable)>(v);
label:
return v;
label:
v := @caughtexception;
v = new org.springframework.core.task.TaskRejectedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.ScheduledExecutorService,java.util.concurrent.Callable)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor [\u] did not accept task: \u0001");
specialinvoke v.<org.springframework.core.task.TaskRejectedException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
public boolean prefersShortLivedTasks()
{
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
return 1;
}
public java.util.concurrent.ScheduledFuture schedule(java.lang.Runnable, org.springframework.scheduling.Trigger)
{
java.util.concurrent.ScheduledFuture v;
org.springframework.scheduling.Trigger v;
org.springframework.core.task.TaskRejectedException v;
java.lang.Runnable v;
org.springframework.util.ErrorHandler v, v;
java.util.concurrent.RejectedExecutionException v;
org.springframework.scheduling.concurrent.ReschedulingRunnable v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.lang.Runnable;
v := @parameter: org.springframework.scheduling.Trigger;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService getScheduledExecutor()>();
label:
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: org.springframework.util.ErrorHandler errorHandler>;
if v == null goto label;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: org.springframework.util.ErrorHandler errorHandler>;
goto label;
label:
v = staticinvoke <org.springframework.scheduling.support.TaskUtils: org.springframework.util.ErrorHandler getDefaultErrorHandler(boolean)>(1);
label:
v = new org.springframework.scheduling.concurrent.ReschedulingRunnable;
specialinvoke v.<org.springframework.scheduling.concurrent.ReschedulingRunnable: void <init>(java.lang.Runnable,org.springframework.scheduling.Trigger,java.util.concurrent.ScheduledExecutorService,org.springframework.util.ErrorHandler)>(v, v, v, v);
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ReschedulingRunnable: java.util.concurrent.ScheduledFuture schedule()>();
label:
return v;
label:
v := @caughtexception;
v = new org.springframework.core.task.TaskRejectedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.ScheduledExecutorService,java.lang.Runnable)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor [\u] did not accept task: \u0001");
specialinvoke v.<org.springframework.core.task.TaskRejectedException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
public java.util.concurrent.ScheduledFuture schedule(java.lang.Runnable, java.util.Date)
{
java.util.concurrent.ScheduledFuture v;
java.util.Date v;
long v, v, v;
org.springframework.core.task.TaskRejectedException v;
java.lang.Runnable v, v;
java.util.concurrent.TimeUnit v;
java.util.concurrent.RejectedExecutionException v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.lang.Runnable;
v := @parameter: java.util.Date;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService getScheduledExecutor()>();
v = virtualinvoke v.<java.util.Date: long getTime()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
label:
v = specialinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.lang.Runnable errorHandlingTask(java.lang.Runnable,boolean)>(v, 0);
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.ScheduledFuture schedule(java.lang.Runnable,long,java.util.concurrent.TimeUnit)>(v, v, v);
label:
return v;
label:
v := @caughtexception;
v = new org.springframework.core.task.TaskRejectedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.ScheduledExecutorService,java.lang.Runnable)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor [\u] did not accept task: \u0001");
specialinvoke v.<org.springframework.core.task.TaskRejectedException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
public java.util.concurrent.ScheduledFuture scheduleAtFixedRate(java.lang.Runnable, java.util.Date, long)
{
java.util.concurrent.ScheduledFuture v;
java.util.Date v;
long v, v, v, v;
org.springframework.core.task.TaskRejectedException v;
java.lang.Runnable v, v;
java.util.concurrent.TimeUnit v;
java.util.concurrent.RejectedExecutionException v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.lang.Runnable;
v := @parameter: java.util.Date;
v := @parameter: long;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService getScheduledExecutor()>();
v = virtualinvoke v.<java.util.Date: long getTime()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
label:
v = specialinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.lang.Runnable errorHandlingTask(java.lang.Runnable,boolean)>(v, 1);
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.ScheduledFuture scheduleAtFixedRate(java.lang.Runnable,long,long,java.util.concurrent.TimeUnit)>(v, v, v, v);
label:
return v;
label:
v := @caughtexception;
v = new org.springframework.core.task.TaskRejectedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.ScheduledExecutorService,java.lang.Runnable)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor [\u] did not accept task: \u0001");
specialinvoke v.<org.springframework.core.task.TaskRejectedException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
public java.util.concurrent.ScheduledFuture scheduleAtFixedRate(java.lang.Runnable, long)
{
java.util.concurrent.ScheduledFuture v;
long v;
org.springframework.core.task.TaskRejectedException v;
java.lang.Runnable v, v;
java.util.concurrent.TimeUnit v;
java.util.concurrent.RejectedExecutionException v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.lang.Runnable;
v := @parameter: long;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService getScheduledExecutor()>();
label:
v = specialinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.lang.Runnable errorHandlingTask(java.lang.Runnable,boolean)>(v, 1);
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.ScheduledFuture scheduleAtFixedRate(java.lang.Runnable,long,long,java.util.concurrent.TimeUnit)>(v, 0L, v, v);
label:
return v;
label:
v := @caughtexception;
v = new org.springframework.core.task.TaskRejectedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.ScheduledExecutorService,java.lang.Runnable)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor [\u] did not accept task: \u0001");
specialinvoke v.<org.springframework.core.task.TaskRejectedException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
public java.util.concurrent.ScheduledFuture scheduleWithFixedDelay(java.lang.Runnable, java.util.Date, long)
{
java.util.concurrent.ScheduledFuture v;
java.util.Date v;
long v, v, v, v;
org.springframework.core.task.TaskRejectedException v;
java.lang.Runnable v, v;
java.util.concurrent.TimeUnit v;
java.util.concurrent.RejectedExecutionException v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.lang.Runnable;
v := @parameter: java.util.Date;
v := @parameter: long;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService getScheduledExecutor()>();
v = virtualinvoke v.<java.util.Date: long getTime()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
label:
v = specialinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.lang.Runnable errorHandlingTask(java.lang.Runnable,boolean)>(v, 1);
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.ScheduledFuture scheduleWithFixedDelay(java.lang.Runnable,long,long,java.util.concurrent.TimeUnit)>(v, v, v, v);
label:
return v;
label:
v := @caughtexception;
v = new org.springframework.core.task.TaskRejectedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.ScheduledExecutorService,java.lang.Runnable)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor [\u] did not accept task: \u0001");
specialinvoke v.<org.springframework.core.task.TaskRejectedException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
public java.util.concurrent.ScheduledFuture scheduleWithFixedDelay(java.lang.Runnable, long)
{
java.util.concurrent.ScheduledFuture v;
long v;
org.springframework.core.task.TaskRejectedException v;
java.lang.Runnable v, v;
java.util.concurrent.TimeUnit v;
java.util.concurrent.RejectedExecutionException v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.lang.Runnable;
v := @parameter: long;
v = virtualinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.util.concurrent.ScheduledExecutorService getScheduledExecutor()>();
label:
v = specialinvoke v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: java.lang.Runnable errorHandlingTask(java.lang.Runnable,boolean)>(v, 1);
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.ScheduledFuture scheduleWithFixedDelay(java.lang.Runnable,long,long,java.util.concurrent.TimeUnit)>(v, 0L, v, v);
label:
return v;
label:
v := @caughtexception;
v = new org.springframework.core.task.TaskRejectedException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.ScheduledExecutorService,java.lang.Runnable)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor [\u] did not accept task: \u0001");
specialinvoke v.<org.springframework.core.task.TaskRejectedException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
private java.lang.Runnable errorHandlingTask(java.lang.Runnable, boolean)
{
org.springframework.util.ErrorHandler v;
org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler v;
java.lang.Runnable v;
boolean v;
org.springframework.scheduling.support.DelegatingErrorHandlingRunnable v;
v := @this: org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
v := @parameter: java.lang.Runnable;
v := @parameter: boolean;
v = v.<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: org.springframework.util.ErrorHandler errorHandler>;
v = staticinvoke <org.springframework.scheduling.support.TaskUtils: org.springframework.scheduling.support.DelegatingErrorHandlingRunnable decorateTaskWithErrorHandler(java.lang.Runnable,org.springframework.util.ErrorHandler,boolean)>(v, v, v);
return v;
}
static void <clinit>()
{
java.lang.Class[] v;
java.lang.Class v;
boolean v;
v = newarray (java.lang.Class)[1];
v = <java.lang.Boolean: java.lang.Class TYPE>;
v[0] = v;
v = staticinvoke <org.springframework.util.ClassUtils: boolean hasMethod(java.lang.Class,java.lang.String,java.lang.Class[])>(class "Ljava/util/concurrent/ScheduledThreadPoolExecutor;", "setRemoveOnCancelPolicy", v);
<org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler: boolean setRemoveOnCancelPolicyAvailable> = v;
return;
}
}