class io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor extends io.smallrye.mutiny.operators.multi.MultiOperatorProcessor
{
private final java.util.concurrent.ScheduledExecutorService executor;
private final io.smallrye.mutiny.subscription.DemandPacer pacer;
private final java.util.concurrent.atomic.AtomicLong itemsCounter;
private java.util.concurrent.ScheduledFuture scheduledFuture;
private io.smallrye.mutiny.subscription.DemandPacer$Request currentRequest;
void <init>(io.smallrye.mutiny.subscription.MultiSubscriber, java.util.concurrent.ScheduledExecutorService, io.smallrye.mutiny.subscription.DemandPacer)
{
java.util.concurrent.atomic.AtomicLong v;
io.smallrye.mutiny.subscription.DemandPacer v;
java.util.concurrent.ScheduledExecutorService v;
io.smallrye.mutiny.subscription.MultiSubscriber v;
io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor v;
v := @this: io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor;
v := @parameter: io.smallrye.mutiny.subscription.MultiSubscriber;
v := @parameter: java.util.concurrent.ScheduledExecutorService;
v := @parameter: io.smallrye.mutiny.subscription.DemandPacer;
specialinvoke v.<io.smallrye.mutiny.operators.multi.MultiOperatorProcessor: void <init>(io.smallrye.mutiny.subscription.MultiSubscriber)>(v);
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.atomic.AtomicLong itemsCounter> = v;
v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.ScheduledExecutorService executor> = v;
v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.DemandPacer pacer> = v;
return;
}
public io.smallrye.mutiny.Context context()
{
io.smallrye.mutiny.Context v, v;
io.smallrye.mutiny.subscription.MultiSubscriber v, v;
boolean v;
io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor v;
v := @this: io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
v = v instanceof io.smallrye.mutiny.subscription.ContextSupport;
if v == 0 goto label;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
v = interfaceinvoke v.<io.smallrye.mutiny.subscription.ContextSupport: io.smallrye.mutiny.Context context()>();
return v;
label:
v = staticinvoke <io.smallrye.mutiny.Context: io.smallrye.mutiny.Context empty()>();
return v;
}
private void demandAndSchedule(java.util.concurrent.ScheduledExecutorService)
{
java.util.concurrent.ScheduledFuture v;
long v, v;
io.smallrye.mutiny.helpers.Subscriptions$EmptySubscription v;
java.lang.Runnable v;
java.util.concurrent.TimeUnit v;
java.time.Duration v;
java.util.concurrent.ScheduledExecutorService v;
io.smallrye.mutiny.subscription.DemandPacer$Request v, v;
io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor v;
java.util.concurrent.Flow$Subscription v, v;
v := @this: io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor;
v := @parameter: java.util.concurrent.ScheduledExecutorService;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.Flow$Subscription upstream>;
v = <io.smallrye.mutiny.helpers.Subscriptions: io.smallrye.mutiny.helpers.Subscriptions$EmptySubscription CANCELLED>;
if v != v goto label;
return;
label:
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.DemandPacer$Request currentRequest>;
v = virtualinvoke v.<io.smallrye.mutiny.subscription.DemandPacer$Request: long demand()>();
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.DemandPacer$Request currentRequest>;
v = virtualinvoke v.<io.smallrye.mutiny.subscription.DemandPacer$Request: java.time.Duration delay()>();
v = virtualinvoke v.<java.time.Duration: long toNanos()>();
v = staticinvoke <io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor$tick__3207: java.lang.Runnable bootstrap$(io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor)>(v);
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit NANOSECONDS>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.ScheduledFuture schedule(java.lang.Runnable,long,java.util.concurrent.TimeUnit)>(v, v, v);
v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.ScheduledFuture scheduledFuture> = v;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.Flow$Subscription upstream>;
interfaceinvoke v.<java.util.concurrent.Flow$Subscription: void request(long)>(v);
return;
}
public void tick()
{
java.lang.Throwable v;
io.smallrye.mutiny.subscription.DemandPacer v;
long v;
io.smallrye.mutiny.helpers.Subscriptions$EmptySubscription v;
java.lang.NullPointerException v;
java.util.concurrent.atomic.AtomicLong v;
java.util.concurrent.ScheduledExecutorService v;
io.smallrye.mutiny.subscription.DemandPacer$Request v, v, v;
io.smallrye.mutiny.subscription.MultiSubscriber v, v;
io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor v;
java.util.concurrent.Flow$Subscription v;
v := @this: io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.Flow$Subscription upstream>;
v = <io.smallrye.mutiny.helpers.Subscriptions: io.smallrye.mutiny.helpers.Subscriptions$EmptySubscription CANCELLED>;
if v != v goto label;
return;
label:
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.atomic.AtomicLong itemsCounter>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long getAndSet(long)>(0L);
label:
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.DemandPacer pacer>;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.DemandPacer$Request currentRequest>;
v = interfaceinvoke v.<io.smallrye.mutiny.subscription.DemandPacer: io.smallrye.mutiny.subscription.DemandPacer$Request apply(io.smallrye.mutiny.subscription.DemandPacer$Request,long)>(v, v);
v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.DemandPacer$Request currentRequest> = v;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.DemandPacer$Request currentRequest>;
if v != null goto label;
virtualinvoke v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: void cancel()>();
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
v = new java.lang.NullPointerException;
specialinvoke v.<java.lang.NullPointerException: void <init>(java.lang.String)>("The pacer provided a null request");
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onFailure(java.lang.Throwable)>(v);
label:
return;
label:
v := @caughtexception;
virtualinvoke v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: void cancel()>();
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onFailure(java.lang.Throwable)>(v);
return;
label:
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.ScheduledExecutorService executor>;
specialinvoke v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: void demandAndSchedule(java.util.concurrent.ScheduledExecutorService)>(v);
return;
catch java.lang.Throwable from label to label with label;
}
public void onSubscribe(java.util.concurrent.Flow$Subscription)
{
java.lang.Throwable v;
io.smallrye.mutiny.subscription.DemandPacer v;
java.lang.NullPointerException v;
java.util.concurrent.ScheduledExecutorService v;
io.smallrye.mutiny.subscription.DemandPacer$Request v, v;
io.smallrye.mutiny.subscription.MultiSubscriber v, v, v;
boolean v;
io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor v;
java.util.concurrent.Flow$Subscription v;
v := @this: io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor;
v := @parameter: java.util.concurrent.Flow$Subscription;
v = virtualinvoke v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: boolean compareAndSetUpstreamSubscription(java.util.concurrent.Flow$Subscription,java.util.concurrent.Flow$Subscription)>(null, v);
if v == 0 goto label;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onSubscribe(java.util.concurrent.Flow$Subscription)>(v);
label:
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.DemandPacer pacer>;
v = interfaceinvoke v.<io.smallrye.mutiny.subscription.DemandPacer: io.smallrye.mutiny.subscription.DemandPacer$Request initial()>();
v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.DemandPacer$Request currentRequest> = v;
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: void cancel()>();
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onFailure(java.lang.Throwable)>(v);
return;
label:
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.DemandPacer$Request currentRequest>;
if v != null goto label;
virtualinvoke v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: void cancel()>();
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
v = new java.lang.NullPointerException;
specialinvoke v.<java.lang.NullPointerException: void <init>(java.lang.String)>("The pacer provided a null initial request");
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onFailure(java.lang.Throwable)>(v);
goto label;
label:
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.ScheduledExecutorService executor>;
specialinvoke v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: void demandAndSchedule(java.util.concurrent.ScheduledExecutorService)>(v);
goto label;
label:
interfaceinvoke v.<java.util.concurrent.Flow$Subscription: void cancel()>();
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void onItem(java.lang.Object)
{
java.util.concurrent.atomic.AtomicLong v;
java.lang.Object v;
io.smallrye.mutiny.helpers.Subscriptions$EmptySubscription v;
io.smallrye.mutiny.subscription.MultiSubscriber v;
io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor v;
java.util.concurrent.Flow$Subscription v;
v := @this: io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor;
v := @parameter: java.lang.Object;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.Flow$Subscription upstream>;
v = <io.smallrye.mutiny.helpers.Subscriptions: io.smallrye.mutiny.helpers.Subscriptions$EmptySubscription CANCELLED>;
if v != v goto label;
return;
label:
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.atomic.AtomicLong itemsCounter>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long incrementAndGet()>();
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onItem(java.lang.Object)>(v);
return;
}
public void onFailure(java.lang.Throwable)
{
java.lang.Throwable v;
io.smallrye.mutiny.helpers.Subscriptions$EmptySubscription v;
io.smallrye.mutiny.subscription.MultiSubscriber v;
io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor v;
java.util.concurrent.Flow$Subscription v;
v := @this: io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor;
v := @parameter: java.lang.Throwable;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.Flow$Subscription upstream>;
v = <io.smallrye.mutiny.helpers.Subscriptions: io.smallrye.mutiny.helpers.Subscriptions$EmptySubscription CANCELLED>;
if v != v goto label;
return;
label:
virtualinvoke v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: void cancel()>();
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onFailure(java.lang.Throwable)>(v);
return;
}
public void onCompletion()
{
io.smallrye.mutiny.helpers.Subscriptions$EmptySubscription v;
io.smallrye.mutiny.subscription.MultiSubscriber v;
io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor v;
java.util.concurrent.Flow$Subscription v;
v := @this: io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.Flow$Subscription upstream>;
v = <io.smallrye.mutiny.helpers.Subscriptions: io.smallrye.mutiny.helpers.Subscriptions$EmptySubscription CANCELLED>;
if v != v goto label;
return;
label:
virtualinvoke v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: void cancel()>();
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onCompletion()>();
return;
}
public void cancel()
{
java.util.concurrent.ScheduledFuture v, v;
io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor v;
v := @this: io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.ScheduledFuture scheduledFuture>;
if v == null goto label;
v = v.<io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor: java.util.concurrent.ScheduledFuture scheduledFuture>;
interfaceinvoke v.<java.util.concurrent.ScheduledFuture: boolean cancel(boolean)>(1);
label:
specialinvoke v.<io.smallrye.mutiny.operators.multi.MultiOperatorProcessor: void cancel()>();
return;
}
public void request(long)
{
long v;
io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor v;
v := @this: io.smallrye.mutiny.operators.multi.MultiDemandPacer$MultiSubscriptionPacerProcessor;
v := @parameter: long;
return;
}
}