public class org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore extends org.apache.activemq.util.ServiceSupport implements org.apache.activemq.broker.scheduler.JobSchedulerStore
{
private static final org.slf4j.Logger LOG;
private final java.util.concurrent.locks.ReentrantLock lock;
private final java.util.Map schedulers;
public void <init>()
{
org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore v;
java.util.HashMap v;
java.util.concurrent.locks.ReentrantLock v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore;
specialinvoke v.<org.apache.activemq.util.ServiceSupport: void <init>()>();
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.concurrent.locks.ReentrantLock lock> = v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.Map schedulers> = v;
return;
}
protected void doStop(org.apache.activemq.util.ServiceStopper) throws java.lang.Exception
{
org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore v;
org.slf4j.Logger v;
java.util.Iterator v;
java.util.Collection v;
java.lang.Exception v;
org.apache.activemq.util.ServiceStopper v;
java.util.Map v;
java.lang.Object v;
java.lang.String v;
boolean v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore;
v := @parameter: org.apache.activemq.util.ServiceStopper;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.Map schedulers>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: 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()>();
label:
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void stop()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.lang.String getName()>();
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("Failed to stop scheduler: {}", v, v);
goto label;
label:
return;
catch java.lang.Exception from label to label with label;
}
protected void doStart() throws java.lang.Exception
{
org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore v;
org.slf4j.Logger v;
java.util.Iterator v;
java.util.Collection v;
java.lang.Exception v;
java.util.Map v;
java.lang.Object v;
java.lang.String v;
boolean v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.Map schedulers>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: 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()>();
label:
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void start()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: java.lang.String getName()>();
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("Failed to start scheduler: {}", v, v);
goto label;
label:
return;
catch java.lang.Exception from label to label with label;
}
public org.apache.activemq.broker.scheduler.JobScheduler getJobScheduler(java.lang.String) throws java.lang.Exception
{
java.lang.Throwable v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore v;
org.slf4j.Logger v;
java.util.concurrent.locks.ReentrantLock v, v, v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler v;
java.util.Map v, v;
java.lang.Object v;
java.lang.String v;
boolean v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore;
v := @parameter: java.lang.String;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.concurrent.locks.ReentrantLock lock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.Map schedulers>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = <org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Creating new in-memory scheduler: {}", v);
v = new org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler;
specialinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void <init>(java.lang.String)>(v);
v = v;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.Map schedulers>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: boolean isStarted()>();
if v == 0 goto label;
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void start()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.concurrent.locks.ReentrantLock lock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.concurrent.locks.ReentrantLock lock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
public boolean removeJobScheduler(java.lang.String) throws java.lang.Exception
{
java.lang.Throwable v;
org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore v;
org.slf4j.Logger v;
java.util.concurrent.locks.ReentrantLock v, v, v;
java.util.Map v, v;
java.lang.Object v;
java.lang.String v;
boolean v, v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore;
v := @parameter: java.lang.String;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.concurrent.locks.ReentrantLock lock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void lock()>();
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.Map schedulers>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
if v == 0 goto label;
v = <org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Removing in-memory Job Scheduler: {}", v);
virtualinvoke v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobScheduler: void stop()>();
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.Map schedulers>;
interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
label:
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.concurrent.locks.ReentrantLock lock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: java.util.concurrent.locks.ReentrantLock lock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public long size()
{
org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore;
return 0L;
}
public java.io.File getDirectory()
{
org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore;
return null;
}
public void setDirectory(java.io.File)
{
org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore v;
java.io.File v;
v := @this: org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore;
v := @parameter: java.io.File;
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/activemq/broker/scheduler/memory/InMemoryJobSchedulerStore;");
<org.apache.activemq.broker.scheduler.memory.InMemoryJobSchedulerStore: org.slf4j.Logger LOG> = v;
return;
}
}