public class oadd.org.apache.curator.retry.ExponentialBackoffRetry extends oadd.org.apache.curator.retry.SleepingRetry
{
private static final org.slf4j.Logger log;
private static final int MAX_RETRIES_LIMIT;
private static final int DEFAULT_MAX_SLEEP_MS;
private final java.util.Random random;
private final int baseSleepTimeMs;
private final int maxSleepMs;
public void <init>(int, int)
{
int v, v;
oadd.org.apache.curator.retry.ExponentialBackoffRetry v;
v := @this: oadd.org.apache.curator.retry.ExponentialBackoffRetry;
v := @parameter: int;
v := @parameter: int;
specialinvoke v.<oadd.org.apache.curator.retry.ExponentialBackoffRetry: void <init>(int,int,int)>(v, v, 2147483647);
return;
}
public void <init>(int, int, int)
{
int v, v, v, v;
java.util.Random v;
oadd.org.apache.curator.retry.ExponentialBackoffRetry v;
v := @this: oadd.org.apache.curator.retry.ExponentialBackoffRetry;
v := @parameter: int;
v := @parameter: int;
v := @parameter: int;
v = staticinvoke <oadd.org.apache.curator.retry.ExponentialBackoffRetry: int validateMaxRetries(int)>(v);
specialinvoke v.<oadd.org.apache.curator.retry.SleepingRetry: void <init>(int)>(v);
v = new java.util.Random;
specialinvoke v.<java.util.Random: void <init>()>();
v.<oadd.org.apache.curator.retry.ExponentialBackoffRetry: java.util.Random random> = v;
v.<oadd.org.apache.curator.retry.ExponentialBackoffRetry: int baseSleepTimeMs> = v;
v.<oadd.org.apache.curator.retry.ExponentialBackoffRetry: int maxSleepMs> = v;
return;
}
public int getBaseSleepTimeMs()
{
int v;
oadd.org.apache.curator.retry.ExponentialBackoffRetry v;
v := @this: oadd.org.apache.curator.retry.ExponentialBackoffRetry;
v = v.<oadd.org.apache.curator.retry.ExponentialBackoffRetry: int baseSleepTimeMs>;
return v;
}
protected long getSleepTimeMs(int, long)
{
java.lang.Object[] v;
java.util.Random v;
long v;
java.lang.Integer v;
oadd.org.apache.curator.retry.ExponentialBackoffRetry v;
byte v;
java.lang.Long v;
int v, v, v, v, v, v, v, v, v;
java.lang.String v;
org.slf4j.Logger v;
v := @this: oadd.org.apache.curator.retry.ExponentialBackoffRetry;
v := @parameter: int;
v := @parameter: long;
v = v.<oadd.org.apache.curator.retry.ExponentialBackoffRetry: int baseSleepTimeMs>;
v = v.<oadd.org.apache.curator.retry.ExponentialBackoffRetry: java.util.Random random>;
v = v + 1;
v = 1 << v;
v = virtualinvoke v.<java.util.Random: int nextInt(int)>(v);
v = staticinvoke <java.lang.Math: int max(int,int)>(1, v);
v = v * v;
v = v.<oadd.org.apache.curator.retry.ExponentialBackoffRetry: int maxSleepMs>;
v = v cmp v;
if v <= 0 goto label;
v = <oadd.org.apache.curator.retry.ExponentialBackoffRetry: org.slf4j.Logger log>;
v = newarray (java.lang.Object)[2];
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[0] = v;
v = v.<oadd.org.apache.curator.retry.ExponentialBackoffRetry: int maxSleepMs>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Sleep extension too large (%d). Pinning to %d", v);
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
label:
return v;
}
private static int validateMaxRetries(int)
{
java.lang.Object[] v;
org.slf4j.Logger v;
int v;
java.lang.String v;
java.lang.Integer v, v;
v := @parameter: int;
if v <= 29 goto label;
v = <oadd.org.apache.curator.retry.ExponentialBackoffRetry: org.slf4j.Logger log>;
v = newarray (java.lang.Object)[2];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(29);
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("maxRetries too large (%d). Pinning to %d", v);
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
v = 29;
label:
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Loadd/org/apache/curator/retry/ExponentialBackoffRetry;");
<oadd.org.apache.curator.retry.ExponentialBackoffRetry: org.slf4j.Logger log> = v;
return;
}
}