class org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy extends java.lang.Object implements com.lmax.disruptor.WaitStrategy
{
private final java.lang.Object mutex;
private final long timeoutInNanos;
private static final int ONE_MILLISECOND_IN_NANOSECONDS;
public void <init>(long, java.util.concurrent.TimeUnit)
{
java.util.concurrent.TimeUnit v;
org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy v;
java.lang.Object v;
long v, v;
v := @this: org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy;
v := @parameter: long;
v := @parameter: java.util.concurrent.TimeUnit;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.lang.Object;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy: java.lang.Object mutex> = v;
v = virtualinvoke v.<java.util.concurrent.TimeUnit: long toNanos(long)>(v);
v.<org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy: long timeoutInNanos> = v;
return;
}
public long waitFor(long, com.lmax.disruptor.Sequence, com.lmax.disruptor.Sequence, com.lmax.disruptor.SequenceBarrier) throws com.lmax.disruptor.AlertException, java.lang.InterruptedException, com.lmax.disruptor.TimeoutException
{
java.lang.Throwable v;
long v, v, v, v, v;
byte v, v, v, v;
org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy v;
com.lmax.disruptor.Sequence v, v;
com.lmax.disruptor.TimeoutException v;
java.lang.Object v, v;
com.lmax.disruptor.SequenceBarrier v;
v := @this: org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy;
v := @parameter: long;
v := @parameter: com.lmax.disruptor.Sequence;
v := @parameter: com.lmax.disruptor.Sequence;
v := @parameter: com.lmax.disruptor.SequenceBarrier;
v = v.<org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy: long timeoutInNanos>;
v = virtualinvoke v.<com.lmax.disruptor.Sequence: long get()>();
v = v cmp v;
if v >= 0 goto label;
v = v.<org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy: java.lang.Object mutex>;
entermonitor v;
label:
v = virtualinvoke v.<com.lmax.disruptor.Sequence: long get()>();
v = v cmp v;
if v >= 0 goto label;
interfaceinvoke v.<com.lmax.disruptor.SequenceBarrier: void checkAlert()>();
v = v.<org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy: java.lang.Object mutex>;
v = staticinvoke <org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy: long awaitNanos(java.lang.Object,long)>(v, v);
v = v cmp 0L;
if v > 0 goto label;
v = <com.lmax.disruptor.TimeoutException: com.lmax.disruptor.TimeoutException INSTANCE>;
throw v;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = virtualinvoke v.<com.lmax.disruptor.Sequence: long get()>();
v = v cmp v;
if v >= 0 goto label;
interfaceinvoke v.<com.lmax.disruptor.SequenceBarrier: void checkAlert()>();
goto label;
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public void signalAllWhenBlocking()
{
java.lang.Throwable v;
org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy v;
java.lang.Object v, v;
v := @this: org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy;
v = v.<org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy: java.lang.Object mutex>;
entermonitor v;
label:
v = v.<org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy: java.lang.Object mutex>;
virtualinvoke v.<java.lang.Object: void notifyAll()>();
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public java.lang.String toString()
{
org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy v;
java.lang.Object v;
long v;
java.lang.String v;
v := @this: org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy;
v = v.<org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy: java.lang.Object mutex>;
v = v.<org.apache.logging.log4j.core.async.TimeoutBlockingWaitStrategy: long timeoutInNanos>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Object,long)>(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[])>("TimeoutBlockingWaitStrategy{mutex=\u, timeoutInNanos=\u0001}");
return v;
}
private static long awaitNanos(java.lang.Object, long) throws java.lang.InterruptedException
{
long v, v, v, v, v, v, v;
java.lang.Object v;
v := @parameter: java.lang.Object;
v := @parameter: long;
v = v / 1000000L;
v = v % 1000000L;
v = staticinvoke <java.lang.System: long nanoTime()>();
virtualinvoke v.<java.lang.Object: void wait(long,int)>(v, v);
v = staticinvoke <java.lang.System: long nanoTime()>();
v = v - v;
v = v - v;
return v;
}
}