final class io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable extends java.lang.Object implements java.lang.Runnable, java.util.concurrent.Flow$Subscription
{
private final io.smallrye.mutiny.subscription.MultiSubscriber actual;
private final java.util.concurrent.atomic.AtomicLong requested;
private final java.time.Duration period;
private final java.time.Duration initialDelay;
private final java.util.concurrent.ScheduledExecutorService executor;
private volatile boolean cancelled;
private volatile boolean once;
private final java.util.concurrent.atomic.AtomicLong count;
private java.util.concurrent.ScheduledFuture future;
void <init>(io.smallrye.mutiny.subscription.MultiSubscriber, java.time.Duration, java.time.Duration, java.util.concurrent.ScheduledExecutorService)
{
java.util.concurrent.atomic.AtomicLong v, v;
java.time.Duration v, v;
java.util.concurrent.ScheduledExecutorService v;
io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable v;
io.smallrye.mutiny.subscription.MultiSubscriber v;
v := @this: io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable;
v := @parameter: io.smallrye.mutiny.subscription.MultiSubscriber;
v := @parameter: java.time.Duration;
v := @parameter: java.time.Duration;
v := @parameter: java.util.concurrent.ScheduledExecutorService;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.atomic.AtomicLong requested> = v;
v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: boolean once> = 1;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.atomic.AtomicLong count> = v;
v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: io.smallrye.mutiny.subscription.MultiSubscriber actual> = v;
v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.time.Duration period> = v;
v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.time.Duration initialDelay> = v;
v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.ScheduledExecutorService executor> = v;
return;
}
public void start()
{
java.lang.Throwable v;
java.util.concurrent.ScheduledFuture v, v;
long v, v, v;
io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable v;
java.util.concurrent.RejectedExecutionException v, v;
java.time.Duration v, v, v, v;
java.util.concurrent.ScheduledExecutorService v, v;
io.smallrye.mutiny.subscription.MultiSubscriber v;
boolean v;
java.util.concurrent.TimeUnit v, v;
v := @this: io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable;
label:
entermonitor v;
label:
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.time.Duration initialDelay>;
if v == null goto label;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.ScheduledExecutorService executor>;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.time.Duration initialDelay>;
v = virtualinvoke v.<java.time.Duration: long toMillis()>();
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.time.Duration period>;
v = virtualinvoke v.<java.time.Duration: long toMillis()>();
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);
v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.ScheduledFuture future> = v;
goto label;
label:
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.ScheduledExecutorService executor>;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.time.Duration period>;
v = virtualinvoke v.<java.time.Duration: long toMillis()>();
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);
v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.ScheduledFuture future> = v;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v := @caughtexception;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: boolean cancelled>;
if v != 0 goto label;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: io.smallrye.mutiny.subscription.MultiSubscriber actual>;
v = new java.util.concurrent.RejectedExecutionException;
specialinvoke v.<java.util.concurrent.RejectedExecutionException: void <init>(java.lang.Throwable)>(v);
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onFailure(java.lang.Throwable)>(v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.util.concurrent.RejectedExecutionException from label to label with label;
}
public void run()
{
long v, v, v;
io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable v;
byte v, v;
io.smallrye.mutiny.subscription.BackPressureFailure v;
java.lang.Long v;
java.lang.String v;
io.smallrye.mutiny.subscription.MultiSubscriber v, v;
boolean v;
java.util.concurrent.atomic.AtomicLong v, v, v, v, v;
v := @this: io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: boolean cancelled>;
if v != 0 goto label;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.atomic.AtomicLong requested>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v cmp 0L;
if v == 0 goto label;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: io.smallrye.mutiny.subscription.MultiSubscriber actual>;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.atomic.AtomicLong count>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long getAndIncrement()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onItem(java.lang.Object)>(v);
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.atomic.AtomicLong requested>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v cmp 9223372036854775807L;
if v == 0 goto label;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.atomic.AtomicLong requested>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long decrementAndGet()>();
goto label;
label:
virtualinvoke v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: void cancel()>();
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: io.smallrye.mutiny.subscription.MultiSubscriber actual>;
v = new io.smallrye.mutiny.subscription.BackPressureFailure;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.atomic.AtomicLong count>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.concurrent.atomic.AtomicLong)>(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[])>("Could not emit tick \u due to lack of requests");
specialinvoke v.<io.smallrye.mutiny.subscription.BackPressureFailure: void <init>(java.lang.String)>(v);
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onFailure(java.lang.Throwable)>(v);
label:
return;
}
public void request(long)
{
java.util.concurrent.atomic.AtomicLong v;
byte v;
long v;
io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable v;
boolean v;
v := @this: io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable;
v := @parameter: long;
v = v cmp 0L;
if v <= 0 goto label;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.atomic.AtomicLong requested>;
staticinvoke <io.smallrye.mutiny.helpers.Subscriptions: long add(java.util.concurrent.atomic.AtomicLong,long)>(v, v);
label:
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: boolean once>;
if v == 0 goto label;
virtualinvoke v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: void start()>();
v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: boolean once> = 0;
label:
return;
}
public synchronized void cancel()
{
java.util.concurrent.ScheduledFuture v, v;
io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable v;
v := @this: io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable;
v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: boolean cancelled> = 1;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.ScheduledFuture future>;
if v == null goto label;
v = v.<io.smallrye.mutiny.operators.multi.builders.IntervalMulti$IntervalRunnable: java.util.concurrent.ScheduledFuture future>;
interfaceinvoke v.<java.util.concurrent.ScheduledFuture: boolean cancel(boolean)>(0);
label:
return;
}
}