public class org.apache.camel.processor.loadbalancer.FailOverLoadBalancer extends org.apache.camel.processor.loadbalancer.LoadBalancerSupport implements org.apache.camel.Traceable, org.apache.camel.CamelContextAware
{
private final java.util.List exceptions;
private org.apache.camel.CamelContext camelContext;
private boolean roundRobin;
private boolean sticky;
private int maximumFailoverAttempts;
private final java.util.concurrent.atomic.AtomicInteger counter;
private final java.util.concurrent.atomic.AtomicInteger lastGoodIndex;
private final org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics;
public void <init>()
{
java.util.concurrent.atomic.AtomicInteger v, v;
int v, v, v;
org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
specialinvoke v.<org.apache.camel.processor.loadbalancer.LoadBalancerSupport: void <init>()>();
v = (int) -1;
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: int maximumFailoverAttempts> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
v = (int) -1;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(v);
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger counter> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
v = (int) -1;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(v);
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger lastGoodIndex> = v;
v = new org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics;
specialinvoke v.<org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics: void <init>()>();
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics> = v;
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.List exceptions> = null;
return;
}
public void <init>(java.util.List)
{
java.util.Iterator v;
java.lang.IllegalArgumentException v;
org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics v, v;
java.util.List v;
java.util.concurrent.atomic.AtomicInteger v, v;
int v, v, v;
java.lang.Object v;
java.lang.String v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
boolean v, v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v := @parameter: java.util.List;
specialinvoke v.<org.apache.camel.processor.loadbalancer.LoadBalancerSupport: void <init>()>();
v = (int) -1;
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: int maximumFailoverAttempts> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
v = (int) -1;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(v);
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger counter> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
v = (int) -1;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(v);
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger lastGoodIndex> = v;
v = new org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics;
specialinvoke v.<org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics: void <init>()>();
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics> = v;
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.List exceptions> = v;
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 = staticinvoke <org.apache.camel.util.ObjectHelper: boolean isAssignableFrom(java.lang.Class,java.lang.Class)>(class "Ljava/lang/Throwable;", v);
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Class)>(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[])>("Class is not an instance of Throwable: \u0001");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics>;
virtualinvoke v.<org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics: void init(java.util.List)>(v);
return;
}
public org.apache.camel.CamelContext getCamelContext()
{
org.apache.camel.CamelContext v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.apache.camel.CamelContext camelContext>;
return v;
}
public void setCamelContext(org.apache.camel.CamelContext)
{
org.apache.camel.CamelContext v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v := @parameter: org.apache.camel.CamelContext;
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.apache.camel.CamelContext camelContext> = v;
return;
}
public int getLastGoodIndex()
{
int v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
java.util.concurrent.atomic.AtomicInteger v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger lastGoodIndex>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
return v;
}
public java.util.List getExceptions()
{
java.util.List v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.List exceptions>;
return v;
}
public boolean isRoundRobin()
{
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
boolean v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: boolean roundRobin>;
return v;
}
public void setRoundRobin(boolean)
{
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
boolean v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v := @parameter: boolean;
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: boolean roundRobin> = v;
return;
}
public boolean isSticky()
{
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
boolean v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: boolean sticky>;
return v;
}
public void setSticky(boolean)
{
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
boolean v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v := @parameter: boolean;
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: boolean sticky> = v;
return;
}
public int getMaximumFailoverAttempts()
{
int v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: int maximumFailoverAttempts>;
return v;
}
public void setMaximumFailoverAttempts(int)
{
int v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v := @parameter: int;
v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: int maximumFailoverAttempts> = v;
return;
}
protected boolean shouldFailOver(org.apache.camel.Exchange)
{
org.apache.camel.Exchange v;
java.lang.Boolean v;
java.lang.String v;
boolean v, v, v;
org.slf4j.Logger v;
java.util.Iterator v;
org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics v;
java.lang.Exception v, v;
java.util.List v, v, v;
java.lang.Object v, v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v := @parameter: org.apache.camel.Exchange;
if v != null goto label;
return 0;
label:
v = 0;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.Exception getException()>();
if v == null goto label;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.List exceptions>;
if v == null goto label;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.List exceptions>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.List exceptions>;
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 = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.Object getException(java.lang.Class)>(v);
if v == null goto label;
v = 1;
label:
if v == 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.Exception getException()>();
virtualinvoke v.<org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics: void onHandledFailure(java.lang.Exception)>(v);
label:
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.slf4j.Logger log>;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Should failover: {} for exchangeId: {}", v, v);
return v;
}
public boolean isRunAllowed()
{
org.apache.camel.CamelContext v;
org.apache.camel.spi.ShutdownStrategy v;
org.slf4j.Logger v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
boolean v, v, v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.apache.camel.CamelContext camelContext>;
v = interfaceinvoke v.<org.apache.camel.CamelContext: org.apache.camel.spi.ShutdownStrategy getShutdownStrategy()>();
v = interfaceinvoke v.<org.apache.camel.spi.ShutdownStrategy: boolean forceShutdown(org.apache.camel.Service)>(v);
if v == 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>("Run not allowed as ShutdownStrategy is forcing shutting down");
label:
if v != 0 goto label;
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.LoadBalancerSupport: boolean isRunAllowed()>();
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public boolean process(org.apache.camel.Exchange, org.apache.camel.AsyncCallback)
{
java.util.concurrent.atomic.AtomicInteger v, v, v, v, v, v, v, v, v;
boolean v, v, v, v, v, v, v;
java.lang.Exception v;
java.util.List v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
org.apache.camel.Exchange v, v;
java.util.concurrent.RejectedExecutionException v;
int v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.String v, v, v;
org.slf4j.Logger v, v, v, v, v, v, v, v;
org.apache.camel.AsyncCallback v;
java.lang.Object v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.AsyncCallback;
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.List getProcessors()>();
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v = 1;
v = null;
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: boolean isSticky()>();
if v == 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger lastGoodIndex>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = (int) -1;
if v != v goto label;
v = 0;
label:
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(v);
goto label;
label:
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: boolean isRoundRobin()>();
if v == 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger counter>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = interfaceinvoke v.<java.util.List: int size()>();
if v < v goto label;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger counter>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
label:
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger counter>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(v);
label:
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Failover starting with endpoint index {}", v);
label:
if v != 0 goto label;
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: boolean shouldFailOver(org.apache.camel.Exchange)>(v);
if v == 0 goto label;
label:
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: boolean isRunAllowed()>();
if v != 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Run not allowed, will reject executing exchange: {}", v);
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.Exception getException()>();
if v != null goto label;
v = new java.util.concurrent.RejectedExecutionException;
specialinvoke v.<java.util.concurrent.RejectedExecutionException: void <init>()>();
interfaceinvoke v.<org.apache.camel.Exchange: void setException(java.lang.Throwable)>(v);
label:
interfaceinvoke v.<org.apache.camel.AsyncCallback: void done(boolean)>(1);
return 1;
label:
if v != 0 goto label;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: int maximumFailoverAttempts>;
v = (int) -1;
if v <= v goto label;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: int maximumFailoverAttempts>;
if v <= v goto label;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Breaking out of failover after {} failover attempts", v);
goto label;
label:
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger counter>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
goto label;
label:
v = 0;
label:
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = interfaceinvoke v.<java.util.List: int size()>();
if v < v goto label;
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: boolean isRoundRobin()>();
if v == 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>("Failover is round robin enabled and therefore starting from the first endpoint");
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger counter>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
goto label;
label:
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>("Breaking out of failover as we reached the end of endpoints to use for failover");
goto label;
label:
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.apache.camel.Exchange prepareExchangeForFailover(org.apache.camel.Exchange)>(v);
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v = specialinvoke v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: boolean processExchange(org.apache.camel.Processor,org.apache.camel.Exchange,org.apache.camel.Exchange,java.util.concurrent.atomic.AtomicInteger,java.util.concurrent.atomic.AtomicInteger,org.apache.camel.AsyncCallback,java.util.List)>(v, v, v, v, v, v, v);
if v != 0 goto label;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Processing exchangeId: {} is continued being processed asynchronously", v);
return 0;
label:
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Processing exchangeId: {} is continued being processed synchronously", v);
goto label;
label:
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger lastGoodIndex>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(v);
if v == null goto label;
staticinvoke <org.apache.camel.util.ExchangeHelper: void copyResults(org.apache.camel.Exchange,org.apache.camel.Exchange)>(v, v);
label:
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.apache.camel.Exchange: java.lang.String getExchangeId()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Failover complete for exchangeId: {} >>> {}", v, v);
interfaceinvoke v.<org.apache.camel.AsyncCallback: void done(boolean)>(1);
return 1;
}
protected org.apache.camel.Exchange prepareExchangeForFailover(org.apache.camel.Exchange)
{
org.apache.camel.Exchange v, v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v := @parameter: org.apache.camel.Exchange;
v = staticinvoke <org.apache.camel.util.ExchangeHelper: org.apache.camel.Exchange createCopy(org.apache.camel.Exchange,boolean)>(v, 1);
return v;
}
private boolean processExchange(org.apache.camel.Processor, org.apache.camel.Exchange, org.apache.camel.Exchange, java.util.concurrent.atomic.AtomicInteger, java.util.concurrent.atomic.AtomicInteger, org.apache.camel.AsyncCallback, java.util.List)
{
java.lang.IllegalStateException v;
org.slf4j.Logger v;
org.apache.camel.AsyncCallback v;
org.apache.camel.Exchange v, v;
org.apache.camel.Processor v;
java.util.List v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer$FailOverAsyncCallback v;
java.util.concurrent.atomic.AtomicInteger v, v;
org.apache.camel.AsyncProcessor v;
java.lang.String v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
boolean v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v := @parameter: org.apache.camel.Processor;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: org.apache.camel.Exchange;
v := @parameter: java.util.concurrent.atomic.AtomicInteger;
v := @parameter: java.util.concurrent.atomic.AtomicInteger;
v := @parameter: org.apache.camel.AsyncCallback;
v := @parameter: java.util.List;
if v != null goto label;
v = new java.lang.IllegalStateException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.camel.Exchange)>(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[])>("No processors could be chosen to process \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Processing failover at attempt {} for {}", v, v);
v = staticinvoke <org.apache.camel.util.AsyncProcessorConverterHelper: org.apache.camel.AsyncProcessor convert(org.apache.camel.Processor)>(v);
v = new org.apache.camel.processor.loadbalancer.FailOverLoadBalancer$FailOverAsyncCallback;
specialinvoke v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer$FailOverAsyncCallback: void <init>(org.apache.camel.processor.loadbalancer.FailOverLoadBalancer,org.apache.camel.Exchange,org.apache.camel.Exchange,java.util.concurrent.atomic.AtomicInteger,java.util.concurrent.atomic.AtomicInteger,org.apache.camel.AsyncCallback,java.util.List)>(v, v, v, v, v, v, v);
v = interfaceinvoke v.<org.apache.camel.AsyncProcessor: boolean process(org.apache.camel.Exchange,org.apache.camel.AsyncCallback)>(v, v);
return v;
}
public java.lang.String toString()
{
java.util.List v;
java.lang.String v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v = virtualinvoke v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.List getProcessors()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.List)>(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[])>("FailoverLoadBalancer[\u]");
return v;
}
public java.lang.String getTraceLabel()
{
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
return "failover";
}
public org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics getExceptionFailureStatistics()
{
org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics>;
return v;
}
public void reset()
{
java.util.concurrent.atomic.AtomicInteger v, v;
int v, v;
org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics v;
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger lastGoodIndex>;
v = (int) -1;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(v);
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: java.util.concurrent.atomic.AtomicInteger counter>;
v = (int) -1;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(v);
v = v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics statistics>;
virtualinvoke v.<org.apache.camel.processor.loadbalancer.ExceptionFailureStatistics: void reset()>();
return;
}
protected void doStart() throws java.lang.Exception
{
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
specialinvoke v.<org.apache.camel.processor.loadbalancer.LoadBalancerSupport: void doStart()>();
virtualinvoke v.<org.apache.camel.processor.loadbalancer.FailOverLoadBalancer: void reset()>();
return;
}
protected void doStop() throws java.lang.Exception
{
org.apache.camel.processor.loadbalancer.FailOverLoadBalancer v;
v := @this: org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
specialinvoke v.<org.apache.camel.processor.loadbalancer.LoadBalancerSupport: void doStop()>();
return;
}
}