public class org.apache.camel.support.DefaultTimeoutMap extends org.apache.camel.support.ServiceSupport implements org.apache.camel.TimeoutMap, java.lang.Runnable
{
protected final org.slf4j.Logger log;
private final java.util.concurrent.ConcurrentMap map;
private final java.util.concurrent.ScheduledExecutorService executor;
private volatile java.util.concurrent.ScheduledFuture future;
private final long purgePollTime;
private final java.util.concurrent.locks.Lock lock;
private boolean useLock;
public void <init>(java.util.concurrent.ScheduledExecutorService)
{
java.util.concurrent.ScheduledExecutorService v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v := @parameter: java.util.concurrent.ScheduledExecutorService;
specialinvoke v.<org.apache.camel.support.DefaultTimeoutMap: void <init>(java.util.concurrent.ScheduledExecutorService,long)>(v, 1000L);
return;
}
public void <init>(java.util.concurrent.ScheduledExecutorService, long)
{
java.util.concurrent.ScheduledExecutorService v;
long v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v := @parameter: java.util.concurrent.ScheduledExecutorService;
v := @parameter: long;
specialinvoke v.<org.apache.camel.support.DefaultTimeoutMap: void <init>(java.util.concurrent.ScheduledExecutorService,long,boolean)>(v, v, 1);
return;
}
public void <init>(java.util.concurrent.ScheduledExecutorService, long, boolean)
{
org.slf4j.Logger v;
java.util.concurrent.locks.ReentrantLock v;
java.util.concurrent.ConcurrentHashMap v;
long v;
org.apache.camel.support.DefaultTimeoutMap v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.Class v;
boolean v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v := @parameter: java.util.concurrent.ScheduledExecutorService;
v := @parameter: long;
v := @parameter: boolean;
specialinvoke v.<org.apache.camel.support.ServiceSupport: void <init>()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(v);
v.<org.apache.camel.support.DefaultTimeoutMap: org.slf4j.Logger log> = v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map> = v;
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock> = v;
v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock> = 1;
staticinvoke <org.apache.camel.util.ObjectHelper: java.lang.Object notNull(java.lang.Object,java.lang.String)>(v, "ScheduledExecutorService");
v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ScheduledExecutorService executor> = v;
v.<org.apache.camel.support.DefaultTimeoutMap: long purgePollTime> = v;
v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock> = v;
return;
}
public java.lang.Object get(java.lang.Object)
{
java.lang.Throwable v;
java.util.concurrent.ConcurrentMap v;
org.apache.camel.support.DefaultTimeoutMap v;
java.util.concurrent.locks.Lock v, v, v, v;
java.lang.Object v, v, v;
boolean v, v, v, v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v := @parameter: java.lang.Object;
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
label:
return null;
label:
virtualinvoke v.<org.apache.camel.support.DefaultTimeoutMap: void updateExpireTime(org.apache.camel.support.TimeoutMapEntry)>(v);
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
label:
throw v;
label:
v = virtualinvoke v.<org.apache.camel.support.TimeoutMapEntry: java.lang.Object getValue()>();
return v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public java.lang.Object put(java.lang.Object, java.lang.Object, long)
{
java.lang.Throwable v;
long v;
java.util.concurrent.ConcurrentMap v;
org.apache.camel.support.DefaultTimeoutMap v;
boolean v, v, v;
java.util.concurrent.locks.Lock v, v, v;
java.lang.Object v, v, v, v, v;
org.apache.camel.support.TimeoutMapEntry v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Object;
v := @parameter: long;
v = new org.apache.camel.support.TimeoutMapEntry;
specialinvoke v.<org.apache.camel.support.TimeoutMapEntry: void <init>(java.lang.Object,java.lang.Object,long)>(v, v, v);
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
virtualinvoke v.<org.apache.camel.support.DefaultTimeoutMap: void updateExpireTime(org.apache.camel.support.TimeoutMapEntry)>(v);
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
if v == null goto label;
v = virtualinvoke v.<org.apache.camel.support.TimeoutMapEntry: java.lang.Object getValue()>();
goto label;
label:
v = null;
label:
v = v;
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
label:
return v;
label:
v := @caughtexception;
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
label:
throw v;
catch java.lang.Throwable from label to label with label;
}
public java.lang.Object putIfAbsent(java.lang.Object, java.lang.Object, long)
{
java.lang.Throwable v;
long v;
java.util.concurrent.ConcurrentMap v;
org.apache.camel.support.DefaultTimeoutMap v;
boolean v, v, v;
java.util.concurrent.locks.Lock v, v, v;
java.lang.Object v, v, v, v, v;
org.apache.camel.support.TimeoutMapEntry v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Object;
v := @parameter: long;
v = new org.apache.camel.support.TimeoutMapEntry;
specialinvoke v.<org.apache.camel.support.TimeoutMapEntry: void <init>(java.lang.Object,java.lang.Object,long)>(v, v, v);
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
virtualinvoke v.<org.apache.camel.support.DefaultTimeoutMap: void updateExpireTime(org.apache.camel.support.TimeoutMapEntry)>(v);
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object putIfAbsent(java.lang.Object,java.lang.Object)>(v, v);
if v == null goto label;
v = virtualinvoke v.<org.apache.camel.support.TimeoutMapEntry: java.lang.Object getValue()>();
goto label;
label:
v = null;
label:
v = v;
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
label:
return v;
label:
v := @caughtexception;
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
label:
throw v;
catch java.lang.Throwable from label to label with label;
}
public java.lang.Object remove(java.lang.Object)
{
java.lang.Throwable v;
java.util.concurrent.ConcurrentMap v;
org.apache.camel.support.DefaultTimeoutMap v;
java.util.concurrent.locks.Lock v, v, v;
java.lang.Object v, v, v;
boolean v, v, v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v := @parameter: java.lang.Object;
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
label:
throw v;
label:
if v == null goto label;
v = virtualinvoke v.<org.apache.camel.support.TimeoutMapEntry: java.lang.Object getValue()>();
goto label;
label:
v = null;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public java.lang.Object[] getKeys()
{
java.lang.Throwable v;
java.lang.Object[] v;
java.util.Set v;
java.util.concurrent.ConcurrentMap v;
org.apache.camel.support.DefaultTimeoutMap v;
java.util.concurrent.locks.Lock v, v, v;
int v;
boolean v, v, v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.util.Set keySet()>();
v = interfaceinvoke v.<java.util.Set: int size()>();
v = newarray (java.lang.Object)[v];
interfaceinvoke v.<java.util.Set: java.lang.Object[] toArray(java.lang.Object[])>(v);
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
label:
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public int size()
{
int v;
java.util.concurrent.ConcurrentMap v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: int size()>();
return v;
}
public void run()
{
java.lang.Throwable v;
org.slf4j.Logger v, v, v;
boolean v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v = virtualinvoke v.<org.apache.camel.support.DefaultTimeoutMap: boolean isRunAllowed()>();
if v != 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>("Purge task not allowed to run");
return;
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>("Running purge task to see if any entries has been timed out");
label:
virtualinvoke v.<org.apache.camel.support.DefaultTimeoutMap: void purge()>();
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.camel.support.DefaultTimeoutMap: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Exception occurred during purge task. This exception will be ignored.", v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void purge()
{
java.lang.Integer v;
org.apache.camel.support.DefaultTimeoutMap v;
byte v;
boolean v, v, v, v, v, v, v, v, v, v, v;
java.util.Set v;
java.lang.Throwable v, v, v;
long v, v;
java.util.ArrayList v, v;
java.util.concurrent.ConcurrentMap v, v, v, v, v;
org.apache.camel.support.DefaultTimeoutMap$1 v;
int v, v;
org.slf4j.Logger v, v, v;
java.util.Iterator v, v, v, v;
java.util.concurrent.locks.Lock v, v, v;
java.lang.Object v, v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v = v.<org.apache.camel.support.DefaultTimeoutMap: org.slf4j.Logger log>;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("There are {} in the timeout map", v);
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: boolean isEmpty()>();
if v == 0 goto label;
return;
label:
v = virtualinvoke v.<org.apache.camel.support.DefaultTimeoutMap: long currentTime()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: 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.camel.support.TimeoutMapEntry: long getExpireTime()>();
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.camel.support.DefaultTimeoutMap: boolean isValidForEviction(org.apache.camel.support.TimeoutMapEntry)>(v);
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: org.slf4j.Logger log>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Evicting inactive entry ID: {}", v);
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = new org.apache.camel.support.DefaultTimeoutMap$1;
specialinvoke v.<org.apache.camel.support.DefaultTimeoutMap$1: void <init>(org.apache.camel.support.DefaultTimeoutMap)>(v);
interfaceinvoke v.<java.util.List: void sort(java.util.Comparator)>(v);
v = new java.util.ArrayList;
v = interfaceinvoke v.<java.util.List: int size()>();
specialinvoke v.<java.util.ArrayList: void <init>(int)>(v);
label:
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 = 0;
label:
v = virtualinvoke v.<org.apache.camel.support.TimeoutMapEntry: java.lang.Object getKey()>();
v = virtualinvoke v.<org.apache.camel.support.TimeoutMapEntry: java.lang.Object getValue()>();
v = virtualinvoke v.<org.apache.camel.support.DefaultTimeoutMap: boolean onEviction(java.lang.Object,java.lang.Object)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.camel.support.DefaultTimeoutMap: org.slf4j.Logger log>;
v = virtualinvoke v.<org.apache.camel.support.TimeoutMapEntry: java.lang.Object getValue()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Exception happened during eviction of entry ID {}, won\'t evict and will continue trying: {}", v, v);
label:
if v == 0 goto label;
v = virtualinvoke v.<org.apache.camel.support.TimeoutMapEntry: java.lang.Object getKey()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
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 = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
goto label;
label:
v := @caughtexception;
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 = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
goto label;
label:
throw v;
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.camel.support.DefaultTimeoutMap: boolean useLock>;
if v == 0 goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
label:
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public long getPurgePollTime()
{
long v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v = v.<org.apache.camel.support.DefaultTimeoutMap: long purgePollTime>;
return v;
}
public java.util.concurrent.ScheduledExecutorService getExecutor()
{
java.util.concurrent.ScheduledExecutorService v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ScheduledExecutorService executor>;
return v;
}
protected void schedulePoll()
{
java.util.concurrent.TimeUnit v;
java.util.concurrent.ScheduledFuture v;
java.util.concurrent.ScheduledExecutorService v;
long v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ScheduledExecutorService executor>;
v = v.<org.apache.camel.support.DefaultTimeoutMap: long purgePollTime>;
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);
v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ScheduledFuture future> = v;
return;
}
protected boolean isValidForEviction(org.apache.camel.support.TimeoutMapEntry)
{
org.apache.camel.support.TimeoutMapEntry v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v := @parameter: org.apache.camel.support.TimeoutMapEntry;
return 1;
}
public boolean onEviction(java.lang.Object, java.lang.Object)
{
java.lang.Object v, v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Object;
return 1;
}
protected void updateExpireTime(org.apache.camel.support.TimeoutMapEntry)
{
long v, v, v;
org.apache.camel.support.TimeoutMapEntry v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v := @parameter: org.apache.camel.support.TimeoutMapEntry;
v = virtualinvoke v.<org.apache.camel.support.DefaultTimeoutMap: long currentTime()>();
v = virtualinvoke v.<org.apache.camel.support.TimeoutMapEntry: long getTimeout()>();
v = v + v;
virtualinvoke v.<org.apache.camel.support.TimeoutMapEntry: void setExpireTime(long)>(v);
return;
}
protected long currentTime()
{
long v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
return v;
}
protected void doStart() throws java.lang.Exception
{
java.lang.IllegalStateException v;
java.util.concurrent.ScheduledExecutorService v;
boolean v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ScheduledExecutorService executor>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: boolean isShutdown()>();
if v == 0 goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("The ScheduledExecutorService is shutdown");
throw v;
label:
virtualinvoke v.<org.apache.camel.support.DefaultTimeoutMap: void schedulePoll()>();
return;
}
protected void doStop() throws java.lang.Exception
{
java.util.concurrent.ScheduledFuture v, v;
java.util.concurrent.ConcurrentMap v;
org.apache.camel.support.DefaultTimeoutMap v;
v := @this: org.apache.camel.support.DefaultTimeoutMap;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ScheduledFuture future>;
if v == null goto label;
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ScheduledFuture future>;
interfaceinvoke v.<java.util.concurrent.ScheduledFuture: boolean cancel(boolean)>(0);
v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ScheduledFuture future> = null;
label:
v = v.<org.apache.camel.support.DefaultTimeoutMap: java.util.concurrent.ConcurrentMap map>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: void clear()>();
return;
}
}