public final class io.helidon.config.SimpleRetryPolicy extends java.lang.Object implements io.helidon.config.spi.RetryPolicy
{
private static final java.util.logging.Logger LOGGER;
private final int retries;
private final java.time.Duration delay;
private final double delayFactor;
private final java.time.Duration callTimeout;
private final java.time.Duration overallTimeout;
private final java.util.concurrent.ScheduledExecutorService executorService;
private volatile java.util.concurrent.ScheduledFuture future;
private void <init>(io.helidon.config.SimpleRetryPolicy$Builder)
{
io.helidon.config.SimpleRetryPolicy v;
io.helidon.config.SimpleRetryPolicy$Builder v;
java.time.Duration v, v, v;
int v;
java.util.concurrent.ScheduledExecutorService v;
double v;
v := @this: io.helidon.config.SimpleRetryPolicy;
v := @parameter: io.helidon.config.SimpleRetryPolicy$Builder;
specialinvoke v.<java.lang.Object: void <init>()>();
v = v.<io.helidon.config.SimpleRetryPolicy$Builder: int retries>;
v.<io.helidon.config.SimpleRetryPolicy: int retries> = v;
v = v.<io.helidon.config.SimpleRetryPolicy$Builder: java.time.Duration delay>;
v.<io.helidon.config.SimpleRetryPolicy: java.time.Duration delay> = v;
v = v.<io.helidon.config.SimpleRetryPolicy$Builder: double delayFactor>;
v.<io.helidon.config.SimpleRetryPolicy: double delayFactor> = v;
v = v.<io.helidon.config.SimpleRetryPolicy$Builder: java.time.Duration callTimeout>;
v.<io.helidon.config.SimpleRetryPolicy: java.time.Duration callTimeout> = v;
v = v.<io.helidon.config.SimpleRetryPolicy$Builder: java.time.Duration overallTimeout>;
v.<io.helidon.config.SimpleRetryPolicy: java.time.Duration overallTimeout> = v;
v = v.<io.helidon.config.SimpleRetryPolicy$Builder: java.util.concurrent.ScheduledExecutorService executorService>;
v.<io.helidon.config.SimpleRetryPolicy: java.util.concurrent.ScheduledExecutorService executorService> = v;
return;
}
public static io.helidon.config.SimpleRetryPolicy$Builder builder()
{
io.helidon.config.SimpleRetryPolicy$Builder v;
v = new io.helidon.config.SimpleRetryPolicy$Builder;
specialinvoke v.<io.helidon.config.SimpleRetryPolicy$Builder: void <init>()>();
return v;
}
public static io.helidon.config.SimpleRetryPolicy create(io.helidon.config.Config)
{
io.helidon.config.Config v;
io.helidon.config.SimpleRetryPolicy v;
io.helidon.config.SimpleRetryPolicy$Builder v, v;
v := @parameter: io.helidon.config.Config;
v = staticinvoke <io.helidon.config.SimpleRetryPolicy: io.helidon.config.SimpleRetryPolicy$Builder builder()>();
v = virtualinvoke v.<io.helidon.config.SimpleRetryPolicy$Builder: io.helidon.config.SimpleRetryPolicy$Builder config(io.helidon.config.Config)>(v);
v = virtualinvoke v.<io.helidon.config.SimpleRetryPolicy$Builder: io.helidon.config.SimpleRetryPolicy build()>();
return v;
}
public java.lang.Object execute(java.util.function.Supplier) throws io.helidon.config.ConfigException
{
java.util.concurrent.ScheduledFuture v;
java.util.concurrent.TimeoutException v;
io.helidon.config.SimpleRetryPolicy v;
io.helidon.config.ConfigException v, v, v, v, v, v;
byte v;
java.time.Duration v, v, v, v;
java.util.concurrent.CancellationException v;
java.util.logging.Logger v, v;
java.lang.Throwable v, v;
java.util.concurrent.Callable v;
long v, v, v, v, v;
java.util.function.Supplier v;
int v, v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v, v;
java.util.concurrent.TimeUnit v, v;
java.lang.InterruptedException v;
java.lang.Object v;
v := @this: io.helidon.config.SimpleRetryPolicy;
v := @parameter: java.util.function.Supplier;
v = <java.time.Duration: java.time.Duration ZERO>;
v = v.<io.helidon.config.SimpleRetryPolicy: java.time.Duration overallTimeout>;
v = virtualinvoke v.<java.time.Duration: long toMillis()>();
v = null;
v = 0;
label:
v = v.<io.helidon.config.SimpleRetryPolicy: int retries>;
if v > v goto label;
label:
v = <io.helidon.config.SimpleRetryPolicy: java.util.logging.Logger LOGGER>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.time.Duration)>(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[])>("next delay: \u0001");
virtualinvoke v.<java.util.logging.Logger: void finest(java.lang.String)>(v);
v = virtualinvoke v.<java.time.Duration: long toMillis()>();
v = v - v;
v = v cmp 0L;
if v >= 0 goto label;
v = <io.helidon.config.SimpleRetryPolicy: java.util.logging.Logger LOGGER>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long)>(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[])>("overall timeout left [ms]: \u0001");
virtualinvoke v.<java.util.logging.Logger: void finest(java.lang.String)>(v);
v = new io.helidon.config.ConfigException;
specialinvoke v.<io.helidon.config.ConfigException: void <init>(java.lang.String)>("Cannot schedule the next call, the current delay would exceed the overall timeout.");
throw v;
label:
v = v.<io.helidon.config.SimpleRetryPolicy: java.util.concurrent.ScheduledExecutorService executorService>;
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <io.helidon.config.SimpleRetryPolicy$get__396: java.util.concurrent.Callable bootstrap$(java.util.function.Supplier)>(v);
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 schedule(java.util.concurrent.Callable,long,java.util.concurrent.TimeUnit)>(v, v, v);
v.<io.helidon.config.SimpleRetryPolicy: java.util.concurrent.ScheduledFuture future> = v;
v = v.<io.helidon.config.SimpleRetryPolicy: java.time.Duration callTimeout>;
v = virtualinvoke v.<java.time.Duration: java.time.Duration plus(java.time.Duration)>(v);
v = virtualinvoke v.<java.time.Duration: long toMillis()>();
v = staticinvoke <java.lang.Math: long min(long,long)>(v, v);
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledFuture: java.lang.Object get(long,java.util.concurrent.TimeUnit)>(v, v);
label:
return v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = new io.helidon.config.ConfigException;
specialinvoke v.<io.helidon.config.ConfigException: void <init>(java.lang.String,java.lang.Throwable)>("An invocation has been canceled.", v);
throw v;
label:
v := @caughtexception;
v = new io.helidon.config.ConfigException;
specialinvoke v.<io.helidon.config.ConfigException: void <init>(java.lang.String,java.lang.Throwable)>("An invocation has been interrupted.", v);
throw v;
label:
v := @caughtexception;
v = new io.helidon.config.ConfigException;
specialinvoke v.<io.helidon.config.ConfigException: void <init>(java.lang.String,java.lang.Throwable)>("A timeout has been reached.", v);
throw v;
label:
v := @caughtexception;
v = v;
v = virtualinvoke v.<io.helidon.config.SimpleRetryPolicy: java.time.Duration nextDelay(int,java.time.Duration)>(v, v);
v = v + 1;
goto label;
label:
v = new io.helidon.config.ConfigException;
specialinvoke v.<io.helidon.config.ConfigException: void <init>(java.lang.String,java.lang.Throwable)>("All repeated calls failed.", v);
throw v;
catch io.helidon.config.ConfigException from label to label with label;
catch java.util.concurrent.CancellationException from label to label with label;
catch java.lang.InterruptedException from label to label with label;
catch java.util.concurrent.TimeoutException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
java.time.Duration nextDelay(int, java.time.Duration)
{
io.helidon.config.SimpleRetryPolicy v;
long v;
java.time.Duration v, v, v;
int v;
double v, v;
v := @this: io.helidon.config.SimpleRetryPolicy;
v := @parameter: int;
v := @parameter: java.time.Duration;
if v != 0 goto label;
v = v.<io.helidon.config.SimpleRetryPolicy: java.time.Duration delay>;
return v;
label:
v = virtualinvoke v.<java.time.Duration: long toMillis()>();
v = v.<io.helidon.config.SimpleRetryPolicy: double delayFactor>;
v = v * v;
v = staticinvoke <java.time.Duration: java.time.Duration ofMillis(long)>(v);
return v;
}
public boolean cancel(boolean)
{
java.util.concurrent.ScheduledFuture v, v, v, v;
io.helidon.config.SimpleRetryPolicy v;
boolean v, v, v, v;
v := @this: io.helidon.config.SimpleRetryPolicy;
v := @parameter: boolean;
v = v.<io.helidon.config.SimpleRetryPolicy: java.util.concurrent.ScheduledFuture future>;
if v == null goto label;
v = v.<io.helidon.config.SimpleRetryPolicy: java.util.concurrent.ScheduledFuture future>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledFuture: boolean isDone()>();
if v != 0 goto label;
v = v.<io.helidon.config.SimpleRetryPolicy: java.util.concurrent.ScheduledFuture future>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledFuture: boolean isCancelled()>();
if v != 0 goto label;
v = v.<io.helidon.config.SimpleRetryPolicy: java.util.concurrent.ScheduledFuture future>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledFuture: boolean cancel(boolean)>(v);
return v;
label:
return 0;
}
public int retries()
{
int v;
io.helidon.config.SimpleRetryPolicy v;
v := @this: io.helidon.config.SimpleRetryPolicy;
v = v.<io.helidon.config.SimpleRetryPolicy: int retries>;
return v;
}
public java.time.Duration delay()
{
io.helidon.config.SimpleRetryPolicy v;
java.time.Duration v;
v := @this: io.helidon.config.SimpleRetryPolicy;
v = v.<io.helidon.config.SimpleRetryPolicy: java.time.Duration delay>;
return v;
}
public double delayFactor()
{
io.helidon.config.SimpleRetryPolicy v;
double v;
v := @this: io.helidon.config.SimpleRetryPolicy;
v = v.<io.helidon.config.SimpleRetryPolicy: double delayFactor>;
return v;
}
public java.time.Duration callTimeout()
{
io.helidon.config.SimpleRetryPolicy v;
java.time.Duration v;
v := @this: io.helidon.config.SimpleRetryPolicy;
v = v.<io.helidon.config.SimpleRetryPolicy: java.time.Duration callTimeout>;
return v;
}
public java.time.Duration overallTimeout()
{
io.helidon.config.SimpleRetryPolicy v;
java.time.Duration v;
v := @this: io.helidon.config.SimpleRetryPolicy;
v = v.<io.helidon.config.SimpleRetryPolicy: java.time.Duration overallTimeout>;
return v;
}
static void <clinit>()
{
java.lang.Class v;
java.lang.String v;
java.util.logging.Logger v;
v = class "Lio/helidon/config/SimpleRetryPolicy;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <java.util.logging.Logger: java.util.logging.Logger getLogger(java.lang.String)>(v);
<io.helidon.config.SimpleRetryPolicy: java.util.logging.Logger LOGGER> = v;
return;
}
}