public class oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry extends java.lang.Object implements oadd.org.apache.hadoop.io.retry.RetryPolicy
{
private final java.util.List pairs;
private java.lang.String myString;
public void <init>(java.util.List)
{
java.util.List v, v;
oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry v;
java.lang.IllegalArgumentException v;
boolean v;
v := @this: oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry;
v := @parameter: java.util.List;
specialinvoke v.<java.lang.Object: void <init>()>();
if v == null goto label;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
label:
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("pairs must be neither null nor empty.");
throw v;
label:
v = staticinvoke <java.util.Collections: java.util.List unmodifiableList(java.util.List)>(v);
v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.util.List pairs> = v;
return;
}
public oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction shouldRetry(java.lang.Exception, int, int, boolean) throws java.lang.Exception
{
long v;
java.util.concurrent.ThreadLocalRandom v;
oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry v;
int v, v, v;
oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction v, v;
java.lang.String v;
oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction$RetryDecision v, v;
boolean v;
double v, v, v;
oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry$Pair v;
java.lang.Exception v;
java.util.List v;
v := @this: oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry;
v := @parameter: java.lang.Exception;
v := @parameter: int;
v := @parameter: int;
v := @parameter: boolean;
v = specialinvoke v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry$Pair searchPair(int)>(v);
if v != null goto label;
v = new oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction;
v = <oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction$RetryDecision: oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction$RetryDecision FAIL>;
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.util.List pairs>;
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[])>("Retry all pairs in MultipleLinearRandomRetry: \u0001");
specialinvoke v.<oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction: void <init>(oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction$RetryDecision,long,java.lang.String)>(v, 0L, v);
return v;
label:
v = staticinvoke <java.util.concurrent.ThreadLocalRandom: java.util.concurrent.ThreadLocalRandom current()>();
v = virtualinvoke v.<java.util.concurrent.ThreadLocalRandom: double nextDouble()>();
v = v + 0.5;
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry$Pair: int sleepMillis>;
v = v * v;
v = staticinvoke <java.lang.Math: long round(double)>(v);
v = new oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction;
v = <oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction$RetryDecision: oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction$RetryDecision RETRY>;
specialinvoke v.<oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction: void <init>(oadd.org.apache.hadoop.io.retry.RetryPolicy$RetryAction$RetryDecision,long)>(v, v);
return v;
}
private oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry$Pair searchPair(int)
{
java.util.List v, v, v, v, v;
oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry v;
int v, v, v, v, v, v;
java.lang.Object v, v, v;
v := @this: oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry;
v := @parameter: int;
v = 0;
label:
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.util.List pairs>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.util.List pairs>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry$Pair: int numRetries>;
if v <= v goto label;
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.util.List pairs>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry$Pair: int numRetries>;
v = v - v;
v = v + 1;
goto label;
label:
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.util.List pairs>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v == v goto label;
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.util.List pairs>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
label:
return v;
}
public int hashCode()
{
int v;
java.lang.String v;
oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry v;
v := @this: oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry;
v = virtualinvoke v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: int hashCode()>();
return v;
}
public boolean equals(java.lang.Object)
{
oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry v;
java.lang.Class v, v;
java.lang.Object v;
java.lang.String v, v;
boolean v;
v := @this: oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry;
v := @parameter: java.lang.Object;
if v != v goto label;
return 1;
label:
if v == null goto label;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
if v == v goto label;
label:
return 0;
label:
v = virtualinvoke v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.Object: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
return v;
}
public java.lang.String toString()
{
java.util.List v;
oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry v;
java.lang.Class v;
java.lang.String v, v, v, v;
v := @this: oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry;
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.lang.String myString>;
if v != null goto label;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.util.List pairs>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.util.List)>(v, 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[])>("\u0001\u0001");
v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.lang.String myString> = v;
label:
v = v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: java.lang.String myString>;
return v;
}
public static oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry parseCommaSeparatedString(java.lang.String)
{
java.lang.String[] v;
java.util.ArrayList v;
oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry v;
int v, v, v, v, v, v, v, v, v, v, v;
java.lang.String v, v, v;
org.slf4j.Logger v, v;
oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry$Pair v;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>(",");
v = lengthof v;
if v != 0 goto label;
v = <oadd.org.apache.hadoop.io.retry.RetryPolicies: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>("Illegal value: there is no element in \"\u0001\".");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
return null;
label:
v = lengthof v;
v = v % 2;
if v == 0 goto label;
v = <oadd.org.apache.hadoop.io.retry.RetryPolicies: org.slf4j.Logger LOG>;
v = lengthof v;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(v, 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[])>("Illegal value: the number of elements in \"\u0001\" is \u but an even number of elements is expected.");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
return null;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = 0;
label:
v = lengthof v;
if v >= v goto label;
v = v + 1;
v = staticinvoke <oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: int parsePositiveInt(java.lang.String[],int,java.lang.String)>(v, v, v);
v = (int) -1;
if v != v goto label;
return null;
label:
v = v + 1;
v = staticinvoke <oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: int parsePositiveInt(java.lang.String[],int,java.lang.String)>(v, v, v);
v = (int) -1;
if v != v goto label;
return null;
label:
v = new oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry$Pair;
specialinvoke v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry$Pair: void <init>(int,int)>(v, v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = new oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry;
specialinvoke v.<oadd.org.apache.hadoop.io.retry.RetryPolicies$MultipleLinearRandomRetry: void <init>(java.util.List)>(v);
return v;
}
private static int parsePositiveInt(java.lang.String[], int, java.lang.String)
{
org.slf4j.Logger v, v;
java.lang.NumberFormatException v;
java.lang.String[] v;
int v, v, v, v;
java.lang.String v, v, v, v, v;
v := @parameter: java.lang.String[];
v := @parameter: int;
v := @parameter: java.lang.String;
v = v[v];
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
label:
v = staticinvoke <java.lang.Integer: int parseInt(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <oadd.org.apache.hadoop.io.retry.RetryPolicies: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int,java.lang.String)>(v, v, 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[])>("Failed to parse \"\u0001\", which is the index \u element in \"\u0001\"");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
v = (int) -1;
return v;
label:
if v > 0 goto label;
v = <oadd.org.apache.hadoop.io.retry.RetryPolicies: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int,java.lang.String,int,java.lang.String)>(v, v, v, 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[])>("The value \u <= 0: it is parsed from the string \"\u0001\" which is the index \u element in \"\u0001\"");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>(v);
v = (int) -1;
return v;
label:
return v;
catch java.lang.NumberFormatException from label to label with label;
}
}