public abstract class org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader extends java.lang.Object implements java.util.Iterator
{
private static final long FIVE_MINUTES;
private static int threadId;
private java.util.concurrent.BlockingQueue queue;
private java.util.concurrent.atomic.AtomicReference readException;
private java.util.concurrent.atomic.AtomicBoolean readingComplete;
private org.finos.legend.engine.shared.core.url.StreamProvider streamProvider;
public void <init>()
{
java.util.concurrent.ArrayBlockingQueue v;
java.util.concurrent.atomic.AtomicBoolean v;
org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader v;
java.util.concurrent.atomic.AtomicReference v;
v := @this: org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.ArrayBlockingQueue;
specialinvoke v.<java.util.concurrent.ArrayBlockingQueue: void <init>(int,boolean)>(256, 1);
v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.BlockingQueue queue> = v;
v = new java.util.concurrent.atomic.AtomicReference;
specialinvoke v.<java.util.concurrent.atomic.AtomicReference: void <init>()>();
v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.atomic.AtomicReference readException> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>(boolean)>(0);
v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.atomic.AtomicBoolean readingComplete> = v;
return;
}
public boolean hasNext()
{
java.lang.IllegalStateException v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.concurrent.BlockingQueue v, v;
long v, v, v;
org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader v;
byte v;
boolean v, v, v, v;
v := @this: org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader;
specialinvoke v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: void checkReader()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
label:
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.BlockingQueue queue>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: boolean isEmpty()>();
if v == 0 goto label;
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.atomic.AtomicBoolean readingComplete>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v != 0 goto label;
specialinvoke v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: void checkReader()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
v = v cmp 300000L;
if v <= 0 goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Data unavailable for more than 5 minutes");
throw v;
label:
specialinvoke v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: void sleep()>();
goto label;
label:
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.BlockingQueue queue>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public org.finos.legend.engine.plan.dependencies.domain.dataQuality.IChecked next()
{
java.lang.IllegalStateException v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.concurrent.BlockingQueue v, v;
long v, v, v;
org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader v;
byte v;
java.lang.Object v;
org.finos.legend.engine.plan.dependencies.domain.dataQuality.IChecked v;
java.util.NoSuchElementException v;
boolean v, v;
v := @this: org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader;
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.BlockingQueue queue>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.BlockingQueue queue>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: java.lang.Object remove()>();
return v;
label:
specialinvoke v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: void checkReader()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = specialinvoke v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: org.finos.legend.engine.plan.dependencies.domain.dataQuality.IChecked poll(int)>(100);
label:
if v != null goto label;
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.atomic.AtomicBoolean readingComplete>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v != 0 goto label;
specialinvoke v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: void checkReader()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
v = v cmp 300000L;
if v <= 0 goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Data unavailable for more than 5 minutes");
throw v;
label:
v = specialinvoke v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: org.finos.legend.engine.plan.dependencies.domain.dataQuality.IChecked poll(int)>(100);
goto label;
label:
if v != null goto label;
v = new java.util.NoSuchElementException;
specialinvoke v.<java.util.NoSuchElementException: void <init>()>();
throw v;
label:
return v;
}
public java.util.stream.Stream startStream()
{
java.lang.ThreadLocal v;
org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader v;
java.lang.Runnable v;
java.util.stream.Stream v;
java.lang.Thread v;
int v, v;
java.lang.Object v;
java.lang.String v;
java.util.Spliterator v;
v := @this: org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader;
v = <org.finos.legend.engine.shared.core.url.StreamProviderHolder: java.lang.ThreadLocal streamProviderThreadLocal>;
v = virtualinvoke v.<java.lang.ThreadLocal: java.lang.Object get()>();
v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: org.finos.legend.engine.shared.core.url.StreamProvider streamProvider> = v;
v = new java.lang.Thread;
v = staticinvoke <org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader$readData__6: java.lang.Runnable bootstrap$(org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader)>(v);
v = <org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: int threadId>;
v = v + 1;
<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: int threadId> = v;
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[])>("ExternalFormatDeserializer-\u0001");
specialinvoke v.<java.lang.Thread: void <init>(java.lang.Runnable,java.lang.String)>(v, v);
virtualinvoke v.<java.lang.Thread: void start()>();
v = staticinvoke <java.util.Spliterators: java.util.Spliterator spliteratorUnknownSize(java.util.Iterator,int)>(v, 1296);
v = staticinvoke <java.util.stream.StreamSupport: java.util.stream.Stream stream(java.util.Spliterator,boolean)>(v, 0);
return v;
}
private void checkReader()
{
org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader v;
java.util.concurrent.atomic.AtomicReference v, v, v, v;
java.lang.Object v, v, v, v;
boolean v;
v := @this: org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader;
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.atomic.AtomicReference readException>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
if v == null goto label;
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.atomic.AtomicReference readException>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
v = v instanceof java.lang.RuntimeException;
if v == 0 goto label;
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.atomic.AtomicReference readException>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
goto label;
label:
v = new java.lang.RuntimeException;
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.atomic.AtomicReference readException>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
label:
throw v;
label:
return;
}
private org.finos.legend.engine.plan.dependencies.domain.dataQuality.IChecked poll(int)
{
java.util.concurrent.TimeUnit v;
java.lang.InterruptedException v;
int v;
java.lang.Object v;
java.util.concurrent.BlockingQueue v;
org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader v;
v := @this: org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader;
v := @parameter: int;
label:
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.BlockingQueue queue>;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: java.lang.Object poll(long,java.util.concurrent.TimeUnit)>(v, v);
label:
return v;
label:
v := @caughtexception;
return null;
catch java.lang.InterruptedException from label to label with label;
}
private void sleep()
{
org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader v;
java.lang.InterruptedException v;
v := @this: org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader;
label:
staticinvoke <java.lang.Thread: void sleep(long,int)>(0L, 5);
label:
goto label;
label:
v := @caughtexception;
label:
return;
catch java.lang.InterruptedException from label to label with label;
}
public void enqueue(org.finos.legend.engine.plan.dependencies.domain.dataQuality.IChecked)
{
java.lang.InterruptedException v;
java.util.concurrent.BlockingQueue v;
java.lang.RuntimeException v;
org.finos.legend.engine.plan.dependencies.domain.dataQuality.IChecked v;
org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader v;
v := @this: org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader;
v := @parameter: org.finos.legend.engine.plan.dependencies.domain.dataQuality.IChecked;
label:
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.BlockingQueue queue>;
interfaceinvoke v.<java.util.concurrent.BlockingQueue: void put(java.lang.Object)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
return;
catch java.lang.InterruptedException from label to label with label;
}
public void readData()
{
java.lang.ThreadLocal v;
java.util.concurrent.atomic.AtomicBoolean v;
org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader v;
org.finos.legend.engine.shared.core.url.StreamProvider v, v;
java.util.concurrent.atomic.AtomicReference v;
java.lang.Exception v;
java.util.function.Consumer v;
v := @this: org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader;
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: org.finos.legend.engine.shared.core.url.StreamProvider streamProvider>;
if v == null goto label;
v = <org.finos.legend.engine.shared.core.url.StreamProviderHolder: java.lang.ThreadLocal streamProviderThreadLocal>;
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: org.finos.legend.engine.shared.core.url.StreamProvider streamProvider>;
virtualinvoke v.<java.lang.ThreadLocal: void set(java.lang.Object)>(v);
label:
v = staticinvoke <org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader$enqueue__7: java.util.function.Consumer bootstrap$(org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader)>(v);
virtualinvoke v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: void readData(java.util.function.Consumer)>(v);
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.atomic.AtomicBoolean readingComplete>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void set(boolean)>(1);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: java.util.concurrent.atomic.AtomicReference readException>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
label:
return;
catch java.lang.Exception from label to label with label;
}
protected abstract void readData(java.util.function.Consumer);
static void <clinit>()
{
<org.finos.legend.engine.external.shared.runtime.read.ExternalFormatReader: int threadId> = 0;
return;
}
}