final class io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber extends io.smallrye.mutiny.subscription.SwitchableSubscriptionSubscriber
{
final java.util.concurrent.Flow$Publisher[] upstreams;
int index;
long produced;
private final java.util.concurrent.atomic.AtomicInteger wip;
private final java.util.concurrent.atomic.AtomicReference failure;
void <init>(io.smallrye.mutiny.subscription.MultiSubscriber, java.util.concurrent.Flow$Publisher[])
{
java.util.concurrent.atomic.AtomicInteger v;
java.util.concurrent.Flow$Publisher[] v;
java.util.concurrent.atomic.AtomicReference v;
io.smallrye.mutiny.subscription.MultiSubscriber v;
io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber v;
v := @this: io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber;
v := @parameter: io.smallrye.mutiny.subscription.MultiSubscriber;
v := @parameter: java.util.concurrent.Flow$Publisher[];
specialinvoke v.<io.smallrye.mutiny.subscription.SwitchableSubscriptionSubscriber: void <init>(io.smallrye.mutiny.subscription.MultiSubscriber)>(v);
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: java.util.concurrent.atomic.AtomicInteger wip> = v;
v = new java.util.concurrent.atomic.AtomicReference;
specialinvoke v.<java.util.concurrent.atomic.AtomicReference: void <init>()>();
v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: java.util.concurrent.atomic.AtomicReference failure> = v;
v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: java.util.concurrent.Flow$Publisher[] upstreams> = v;
return;
}
public void onItem(java.lang.Object)
{
java.lang.Object v;
long v, v;
io.smallrye.mutiny.subscription.MultiSubscriber v;
io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber v;
v := @this: io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber;
v := @parameter: java.lang.Object;
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: long produced>;
v = v + 1L;
v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: long produced> = v;
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: 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;
java.util.concurrent.atomic.AtomicReference v;
boolean v;
io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber v;
v := @this: io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber;
v := @parameter: java.lang.Throwable;
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: java.util.concurrent.atomic.AtomicReference failure>;
v = staticinvoke <io.smallrye.mutiny.helpers.Subscriptions: boolean addFailure(java.util.concurrent.atomic.AtomicReference,java.lang.Throwable)>(v, v);
if v == 0 goto label;
virtualinvoke v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: void onCompletion()>();
label:
return;
}
public void onCompletion()
{
java.lang.Throwable v;
java.util.concurrent.Flow$Publisher[] v;
long v;
java.util.concurrent.atomic.AtomicReference v;
java.lang.NullPointerException v;
byte v;
java.util.concurrent.atomic.AtomicInteger v, v;
int v, v, v, v, v;
java.lang.String v;
io.smallrye.mutiny.subscription.MultiSubscriber v, v, v;
boolean v, v;
io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber v;
java.util.concurrent.Flow$Subscriber v;
java.util.concurrent.Flow$Publisher v;
v := @this: io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber;
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: java.util.concurrent.atomic.AtomicInteger wip>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int getAndIncrement()>();
if v != 0 goto label;
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: java.util.concurrent.Flow$Publisher[] upstreams>;
label:
v = virtualinvoke v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: boolean isCancelled()>();
if v == 0 goto label;
return;
label:
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: int index>;
v = lengthof v;
if v != v goto label;
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: java.util.concurrent.atomic.AtomicReference failure>;
v = staticinvoke <io.smallrye.mutiny.helpers.Subscriptions: java.lang.Throwable markFailureAsTerminated(java.util.concurrent.atomic.AtomicReference)>(v);
if v == null goto label;
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onFailure(java.lang.Throwable)>(v);
goto label;
label:
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onCompletion()>();
label:
return;
label:
v = v[v];
if v != null goto label;
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: io.smallrye.mutiny.subscription.MultiSubscriber downstream>;
v = new java.lang.NullPointerException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("Source Publisher at currentIndex \u is null");
specialinvoke v.<java.lang.NullPointerException: void <init>(java.lang.String)>(v);
interfaceinvoke v.<io.smallrye.mutiny.subscription.MultiSubscriber: void onFailure(java.lang.Throwable)>(v);
return;
label:
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: long produced>;
v = v cmp 0L;
if v == 0 goto label;
v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: long produced> = 0L;
virtualinvoke v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: void emitted(long)>(v);
label:
v = staticinvoke <io.smallrye.mutiny.infrastructure.Infrastructure: java.util.concurrent.Flow$Subscriber onMultiSubscription(java.util.concurrent.Flow$Publisher,java.util.concurrent.Flow$Subscriber)>(v, v);
interfaceinvoke v.<java.util.concurrent.Flow$Publisher: void subscribe(java.util.concurrent.Flow$Subscriber)>(v);
v = virtualinvoke v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: boolean isCancelled()>();
if v == 0 goto label;
return;
label:
v = v + 1;
v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: int index> = v;
v = v.<io.smallrye.mutiny.operators.multi.MultiConcatOp$ConcatArrayAndPostponeFailureSubscriber: java.util.concurrent.atomic.AtomicInteger wip>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int decrementAndGet()>();
if v != 0 goto label;
label:
return;
}
}