public class org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler extends java.lang.Object implements org.apache.activemq.broker.scheduler.JobScheduler
{
private static final org.slf4j.Logger LOG;
private static final org.apache.activemq.util.IdGenerator ID_GENERATOR;
private final java.util.concurrent.locks.ReentrantReadWriteLock lock;
private final java.lang.String name;
private final java.util.TreeMap jobs;
private final java.util.concurrent.atomic.AtomicBoolean started;
private final java.util.concurrent.atomic.AtomicBoolean dispatchEnabled;
private final java.util.List jobListeners;
private final java.util.Timer timer;
public void <init>(java.lang.String)
{
java.util.concurrent.atomic.AtomicBoolean v, v;
java.util.Timer v;
java.util.concurrent.locks.ReentrantReadWriteLock v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
java.util.TreeMap v;
java.lang.String v;
java.util.concurrent.CopyOnWriteArrayList v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: java.lang.String;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.locks.ReentrantReadWriteLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: void <init>()>();
v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock> = v;
v = new java.util.TreeMap;
specialinvoke v.<java.util.TreeMap: void <init>()>();
v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>(boolean)>(0);
v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.atomic.AtomicBoolean started> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>(boolean)>(0);
v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.atomic.AtomicBoolean dispatchEnabled> = v;
v = new java.util.concurrent.CopyOnWriteArrayList;
specialinvoke v.<java.util.concurrent.CopyOnWriteArrayList: void <init>()>();
v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.List jobListeners> = v;
v = new java.util.Timer;
specialinvoke v.<java.util.Timer: void <init>()>();
v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.Timer timer> = v;
v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.lang.String name> = v;
return;
}
public java.lang.String getName() throws java.lang.Exception
{
java.lang.String v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.lang.String name>;
return v;
}
public void start() throws java.lang.Exception
{
org.slf4j.Logger v;
java.util.concurrent.atomic.AtomicBoolean v;
java.lang.String v;
boolean v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(0, 1);
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void startDispatching()>();
v = <org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.lang.String name>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("JobScheduler[{}] started", v);
label:
return;
}
public void stop() throws java.lang.Exception
{
org.slf4j.Logger v;
java.util.TreeMap v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.Timer v;
java.lang.String v;
boolean v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(1, 0);
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void stopDispatching()>();
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.Timer timer>;
virtualinvoke v.<java.util.Timer: void cancel()>();
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
virtualinvoke v.<java.util.TreeMap: void clear()>();
v = <org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: org.slf4j.Logger LOG>;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.lang.String name>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("JobScheduler[{}] stopped", v);
label:
return;
}
public boolean isStarted()
{
java.util.concurrent.atomic.AtomicBoolean v;
boolean v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
return v;
}
public boolean isDispatchEnabled()
{
java.util.concurrent.atomic.AtomicBoolean v;
boolean v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.atomic.AtomicBoolean dispatchEnabled>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
return v;
}
public void startDispatching() throws java.lang.Exception
{
java.util.concurrent.atomic.AtomicBoolean v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.atomic.AtomicBoolean dispatchEnabled>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void set(boolean)>(1);
return;
}
public void stopDispatching() throws java.lang.Exception
{
java.util.concurrent.atomic.AtomicBoolean v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.atomic.AtomicBoolean dispatchEnabled>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void set(boolean)>(0);
return;
}
public void addListener(org.apache.activemq.broker.scheduler.JobListener) throws java.lang.Exception
{
java.util.List v;
org.apache.activemq.broker.scheduler.JobListener v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: org.apache.activemq.broker.scheduler.JobListener;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.List jobListeners>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
return;
}
public void removeListener(org.apache.activemq.broker.scheduler.JobListener) throws java.lang.Exception
{
java.util.List v;
org.apache.activemq.broker.scheduler.JobListener v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: org.apache.activemq.broker.scheduler.JobListener;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.List jobListeners>;
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
return;
}
public void schedule(java.lang.String, org.apache.activemq.util.ByteSequence, long) throws java.lang.Exception
{
long v;
java.lang.String v;
org.apache.activemq.util.ByteSequence v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: java.lang.String;
v := @parameter: org.apache.activemq.util.ByteSequence;
v := @parameter: long;
specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void doSchedule(java.lang.String,org.apache.activemq.util.ByteSequence,java.lang.String,long,long,int)>(v, v, "", 0L, v, 0);
return;
}
public void schedule(java.lang.String, org.apache.activemq.util.ByteSequence, java.lang.String) throws java.lang.Exception
{
java.lang.String v, v;
org.apache.activemq.util.ByteSequence v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: java.lang.String;
v := @parameter: org.apache.activemq.util.ByteSequence;
v := @parameter: java.lang.String;
specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void doSchedule(java.lang.String,org.apache.activemq.util.ByteSequence,java.lang.String,long,long,int)>(v, v, v, 0L, 0L, 0);
return;
}
public void schedule(java.lang.String, org.apache.activemq.util.ByteSequence, java.lang.String, long, long, int) throws java.lang.Exception
{
int v;
long v, v;
java.lang.String v, v;
org.apache.activemq.util.ByteSequence v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: java.lang.String;
v := @parameter: org.apache.activemq.util.ByteSequence;
v := @parameter: java.lang.String;
v := @parameter: long;
v := @parameter: long;
v := @parameter: int;
specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void doSchedule(java.lang.String,org.apache.activemq.util.ByteSequence,java.lang.String,long,long,int)>(v, v, v, v, v, v);
return;
}
public void remove(long) throws java.lang.Exception
{
long v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: long;
specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void doRemoveRange(long,long)>(v, v);
return;
}
public void remove(java.lang.String) throws java.lang.Exception
{
java.lang.String v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: java.lang.String;
specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void doRemoveJob(java.lang.String)>(v);
return;
}
public void removeAllJobs() throws java.lang.Exception
{
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void doRemoveRange(long,long)>(0L, 9223372036854775807L);
return;
}
public void removeAllJobs(long, long) throws java.lang.Exception
{
long v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: long;
v := @parameter: long;
specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void doRemoveRange(long,long)>(v, v);
return;
}
public long getNextScheduleTime() throws java.lang.Exception
{
java.lang.Throwable v;
long v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
boolean v;
java.util.Iterator v;
java.util.Set v;
java.util.TreeMap v, v;
java.lang.Object v, v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = -1L;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = virtualinvoke v.<java.util.TreeMap: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = virtualinvoke v.<java.util.TreeMap: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = virtualinvoke v.<java.lang.Long: long longValue()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public java.util.List getNextScheduleJobs() throws java.lang.Exception
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.ArrayList v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
boolean v;
java.util.Iterator v;
java.util.Collection v;
java.util.Set v;
java.util.TreeMap v, v;
java.lang.Object v, v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = virtualinvoke v.<java.util.TreeMap: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = virtualinvoke v.<java.util.TreeMap: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: java.util.Collection getAllJobs()>();
interfaceinvoke v.<java.util.List: boolean addAll(java.util.Collection)>(v);
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public java.util.List getAllJobs() throws java.lang.Exception
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.ArrayList v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
boolean v;
java.util.Iterator v;
java.util.Collection v;
java.util.Set v;
java.util.TreeMap v;
java.lang.Object v, v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = virtualinvoke v.<java.util.TreeMap: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: java.util.Collection getAllJobs()>();
interfaceinvoke v.<java.util.List: boolean addAll(java.util.Collection)>(v);
goto label;
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public java.util.List getAllJobs(long, long) throws java.lang.Exception
{
java.lang.Throwable v;
long v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.ArrayList v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
byte v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock v, v, v;
boolean v;
java.util.Iterator v;
java.util.Collection v;
java.util.Set v;
java.util.TreeMap v;
java.lang.Object v, v, v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: long;
v := @parameter: long;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = virtualinvoke v.<java.util.TreeMap: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = virtualinvoke v.<java.lang.Long: long longValue()>();
v = v cmp v;
if v > 0 goto label;
v = v cmp v;
if v > 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: java.util.Collection getAllJobs()>();
interfaceinvoke v.<java.util.List: boolean addAll(java.util.Collection)>(v);
goto label;
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock readLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock: void unlock()>();
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public int hashCode()
{
int v;
java.lang.String v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.lang.String name>;
v = virtualinvoke v.<java.lang.String: int hashCode()>();
return v;
}
public java.lang.String toString()
{
java.lang.String v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.lang.String name>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>("JobScheduler: \u0001");
return v;
}
private void doSchedule(java.lang.String, org.apache.activemq.util.ByteSequence, java.lang.String, long, long, int) throws java.io.IOException
{
byte[] v;
java.util.Date v;
java.util.Timer v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
byte v, v;
java.lang.Long v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask v;
org.apache.activemq.util.ByteSequence v;
org.apache.activemq.broker.scheduler.memory.InMemoryJob v;
java.lang.Throwable v, v;
long v, v, v, v, v, v, v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
int v, v;
java.lang.String v, v, v, v;
org.slf4j.Logger v;
java.io.IOException v;
java.util.TreeMap v, v;
java.lang.Object v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: java.lang.String;
v := @parameter: org.apache.activemq.util.ByteSequence;
v := @parameter: java.lang.String;
v := @parameter: long;
v := @parameter: long;
v := @parameter: int;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = 0L;
v = v + 500L;
v = v / 500L;
v = v * 500L;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
label:
v = staticinvoke <org.apache.activemq.broker.scheduler.CronParser: long getNextScheduledTime(java.lang.String,long)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = new java.io.IOException;
v = virtualinvoke v.<javax.jms.MessageFormatException: java.lang.String getMessage()>();
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v cmp 0L;
if v != 0 goto label;
v = v;
label:
v = v cmp 0L;
if v <= 0 goto label;
v = v + v;
goto label;
label:
v = v + v;
label:
v = new org.apache.activemq.broker.scheduler.memory.InMemoryJob;
specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: void <init>(java.lang.String)>(v);
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: void setStart(long)>(v);
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: void setCronEntry(java.lang.String)>(v);
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: void setDelay(long)>(v);
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: void setPeriod(long)>(v);
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: void setRepeat(int)>(v);
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: void setNextTime(long)>(v);
v = virtualinvoke v.<org.apache.activemq.util.ByteSequence: byte[] getData()>();
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: void setPayload(byte[])>(v);
v = <org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: org.slf4j.Logger LOG>;
v = staticinvoke <org.apache.activemq.broker.scheduler.JobSupport: java.lang.String getDateTime(long)>(v);
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("JobScheduler adding job[{}] to fire at: {}", v, v);
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = virtualinvoke v.<java.util.TreeMap: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = new org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask;
specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: void <init>(org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler,long)>(v, v);
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: void add(org.apache.activemq.broker.scheduler.memory.InMemoryJob)>(v);
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: long getExecutionTime()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
virtualinvoke v.<java.util.TreeMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.Timer timer>;
v = new java.util.Date;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: long getNextTime()>();
specialinvoke v.<java.util.Date: void <init>(long)>(v);
virtualinvoke v.<java.util.Timer: void schedule(java.util.TimerTask,java.util.Date)>(v, v);
goto label;
label:
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: void add(org.apache.activemq.broker.scheduler.memory.InMemoryJob)>(v);
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return;
catch javax.jms.MessageFormatException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void doReschedule(org.apache.activemq.broker.scheduler.memory.InMemoryJob, long)
{
java.lang.Throwable v;
java.util.Date v;
java.util.Timer v;
long v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
java.lang.Long v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask v;
java.lang.String v, v;
boolean v;
org.slf4j.Logger v;
org.apache.activemq.broker.scheduler.memory.InMemoryJob v;
java.util.TreeMap v, v;
java.lang.Object v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: org.apache.activemq.broker.scheduler.memory.InMemoryJob;
v := @parameter: long;
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: void setNextTime(long)>(v);
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: void incrementExecutionCount()>();
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: boolean isCron()>();
if v != 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: void decrementRepeatCount()>();
label:
v = <org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: java.lang.String getJobId()>();
v = staticinvoke <org.apache.activemq.broker.scheduler.JobSupport: java.lang.String getDateTime(long)>(v);
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("JobScheduler rescheduling job[{}] to fire at: {}", v, v);
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = virtualinvoke v.<java.util.TreeMap: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = new org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask;
specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: void <init>(org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler,long)>(v, v);
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: void add(org.apache.activemq.broker.scheduler.memory.InMemoryJob)>(v);
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: long getExecutionTime()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
virtualinvoke v.<java.util.TreeMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.Timer timer>;
v = new java.util.Date;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: long getExecutionTime()>();
specialinvoke v.<java.util.Date: void <init>(long)>(v);
virtualinvoke v.<java.util.Timer: void schedule(java.util.TimerTask,java.util.Date)>(v, v);
goto label;
label:
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: void add(org.apache.activemq.broker.scheduler.memory.InMemoryJob)>(v);
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void doRemoveJob(java.lang.String) throws java.io.IOException
{
java.lang.Throwable v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
java.lang.String v;
boolean v, v, v;
org.slf4j.Logger v;
java.util.Iterator v;
java.util.Set v;
java.util.TreeMap v;
java.lang.Object v, v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: java.lang.String;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = virtualinvoke v.<java.util.TreeMap: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: boolean remove(java.lang.String)>(v);
if v == 0 goto label;
v = <org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("JobScheduler removing job[{}]", v);
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: boolean isEmpty()>();
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: boolean cancel()>();
interfaceinvoke v.<java.util.Iterator: void remove()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
return;
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void doRemoveRange(long, long) throws java.io.IOException
{
java.lang.Throwable v;
long v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock v, v, v;
java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock v, v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
byte v, v, v;
boolean v;
java.util.Iterator v;
java.util.Set v;
java.util.TreeMap v;
java.lang.Object v, v, v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: long;
v := @parameter: long;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.TreeMap jobs>;
v = virtualinvoke v.<java.util.TreeMap: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = virtualinvoke v.<java.lang.Long: long longValue()>();
v = v cmp v;
if v > 0 goto label;
v = v cmp v;
if v > 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler$ScheduledTask: boolean cancel()>();
interfaceinvoke v.<java.util.Iterator: void remove()>();
label:
v = v cmp v;
if v >= 0 goto label;
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.concurrent.locks.ReentrantReadWriteLock lock>;
v = virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock writeLock()>();
virtualinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock$WriteLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private boolean canDispatch()
{
boolean v, v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: boolean isStarted()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: boolean isDispatchEnabled()>();
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private long calculateNextExecutionTime(org.apache.activemq.broker.scheduler.memory.InMemoryJob, long, int) throws javax.jms.MessageFormatException
{
long v, v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJob v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
int v, v, v;
java.lang.String v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: org.apache.activemq.broker.scheduler.memory.InMemoryJob;
v := @parameter: long;
v := @parameter: int;
v = v;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: java.lang.String getCronEntry()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = staticinvoke <org.apache.activemq.broker.scheduler.CronParser: long getNextScheduledTime(java.lang.String,long)>(v, v);
goto label;
label:
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: int getRepeat()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: long getPeriod()>();
v = v + v;
label:
return v;
}
private void dispatch(org.apache.activemq.broker.scheduler.memory.InMemoryJob) throws java.lang.IllegalStateException, java.io.IOException
{
byte[] v;
org.slf4j.Logger v;
java.util.Iterator v;
org.apache.activemq.broker.scheduler.memory.InMemoryJob v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
java.util.List v;
java.lang.Object v;
java.lang.String v;
org.apache.activemq.util.ByteSequence v;
boolean v, v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
v := @parameter: org.apache.activemq.broker.scheduler.memory.InMemoryJob;
v = specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: boolean canDispatch()>();
if v == 0 goto label;
v = <org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Firing: {}", v);
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.util.List jobListeners>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: java.lang.String getJobId()>();
v = new org.apache.activemq.util.ByteSequence;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJob: byte[] getPayload()>();
specialinvoke v.<org.apache.activemq.util.ByteSequence: void <init>(byte[])>(v);
interfaceinvoke v.<org.apache.activemq.broker.scheduler.JobListener: void scheduledJob(java.lang.String,org.apache.activemq.util.ByteSequence)>(v, v);
goto label;
label:
return;
}
static void <clinit>()
{
org.apache.activemq.util.IdGenerator v;
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/broker/scheduler/memory/InMemoryJobScheduler;");
<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: org.slf4j.Logger LOG> = v;
v = new org.apache.activemq.util.IdGenerator;
specialinvoke v.<org.apache.activemq.util.IdGenerator: void <init>()>();
<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: org.apache.activemq.util.IdGenerator ID_GENERATOR> = v;
return;
}
}