public class org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer extends org.finos.legend.engine.plan.execution.result.serialization.Serializer
{
private static final byte[] b_comma;
private static final byte[] b_eol;
private final org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult relationalResult;
public void <init>(org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult)
{
org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult v;
org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult;
specialinvoke v.<org.finos.legend.engine.plan.execution.result.serialization.Serializer: void <init>()>();
v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult relationalResult> = v;
return;
}
public void stream(java.io.OutputStream) throws java.io.IOException
{
io.opentracing.Tracer$SpanBuilder v, v;
java.lang.Integer v, v;
org.eclipse.collections.api.list.MutableList v;
java.sql.ResultSet v, v;
java.util.stream.Collector v, v, v;
org.finos.legend.engine.plan.execution.result.builder.Builder v;
boolean v, v;
java.util.List v;
java.util.stream.Stream v, v, v, v;
io.opentracing.Span v, v, v;
io.opentracing.Scope v, v;
java.lang.Throwable v, v;
java.util.stream.IntStream v, v;
java.util.function.Function v;
java.sql.SQLException v;
org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult v, v, v, v, v, v, v, v;
int v, v, v, v;
java.util.function.IntFunction v, v;
java.io.OutputStream v;
io.opentracing.Tracer v, v;
org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer v;
java.lang.Object v, v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer;
v := @parameter: java.io.OutputStream;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult relationalResult>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult: org.finos.legend.engine.plan.execution.result.builder.Builder builder>;
v = v.<org.finos.legend.engine.plan.execution.result.builder.tds.TDSBuilder: java.util.List columns>;
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = staticinvoke <org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer$lambda_stream_0__26: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream map(java.util.function.Function)>(v);
v = staticinvoke <java.util.stream.Collectors: java.util.stream.Collector toList()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object collect(java.util.stream.Collector)>(v);
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: void streamCollection(java.io.OutputStream,java.util.List)>(v, v);
label:
v = v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult relationalResult>;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult: org.eclipse.collections.api.list.MutableList getTransformers()>();
v = staticinvoke <io.opentracing.util.GlobalTracer: io.opentracing.Tracer get()>();
v = interfaceinvoke v.<io.opentracing.Tracer: io.opentracing.Tracer$SpanBuilder buildSpan(java.lang.String)>("Relational Streaming: Fetch first row");
v = interfaceinvoke v.<io.opentracing.Tracer$SpanBuilder: io.opentracing.Scope startActive(boolean)>(1);
label:
v = v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult relationalResult>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult: java.sql.ResultSet resultSet>;
v = interfaceinvoke v.<java.sql.ResultSet: boolean next()>();
if v == 0 goto label;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult relationalResult>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult: int columnCount>;
v = v + 1;
v = staticinvoke <java.util.stream.IntStream: java.util.stream.IntStream range(int,int)>(1, v);
v = staticinvoke <org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer$lambda_stream_1__28: java.util.function.IntFunction bootstrap$(org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer,org.eclipse.collections.api.list.MutableList)>(v, v);
v = interfaceinvoke v.<java.util.stream.IntStream: java.util.stream.Stream mapToObj(java.util.function.IntFunction)>(v);
v = staticinvoke <java.util.stream.Collectors: java.util.stream.Collector toList()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object collect(java.util.stream.Collector)>(v);
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: void streamCollection(java.io.OutputStream,java.util.List)>(v, v);
label:
if v == null goto label;
interfaceinvoke v.<io.opentracing.Scope: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v = staticinvoke <io.opentracing.util.GlobalTracer: io.opentracing.Tracer get()>();
v = interfaceinvoke v.<io.opentracing.Tracer: io.opentracing.Tracer$SpanBuilder buildSpan(java.lang.String)>("Relational Streaming: remaining rows");
v = interfaceinvoke v.<io.opentracing.Tracer$SpanBuilder: io.opentracing.Scope startActive(boolean)>(1);
label:
v = v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult relationalResult>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult: java.sql.ResultSet resultSet>;
v = interfaceinvoke v.<java.sql.ResultSet: boolean next()>();
if v == 0 goto label;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult relationalResult>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult: int columnCount>;
v = v + 1;
v = staticinvoke <java.util.stream.IntStream: java.util.stream.IntStream range(int,int)>(1, v);
v = staticinvoke <org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer$lambda_stream_2__27: java.util.function.IntFunction bootstrap$(org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer,org.eclipse.collections.api.list.MutableList)>(v, v);
v = interfaceinvoke v.<java.util.stream.IntStream: java.util.stream.Stream mapToObj(java.util.function.IntFunction)>(v);
v = staticinvoke <java.util.stream.Collectors: java.util.stream.Collector toList()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object collect(java.util.stream.Collector)>(v);
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: void streamCollection(java.io.OutputStream,java.util.List)>(v, v);
goto label;
label:
v = interfaceinvoke v.<io.opentracing.Scope: io.opentracing.Span span()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(0);
interfaceinvoke v.<io.opentracing.Span: io.opentracing.Span setTag(java.lang.String,java.lang.Number)>("rowCount", v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult relationalResult>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult: io.opentracing.Span topSpan>;
if v == null goto label;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult relationalResult>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.result.RelationalResult: io.opentracing.Span topSpan>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(0);
interfaceinvoke v.<io.opentracing.Span: io.opentracing.Span setTag(java.lang.String,java.lang.Number)>("lastQueryRowCount", v);
label:
interfaceinvoke v.<io.opentracing.Scope: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.sql.SQLException from label to label with label;
}
private void streamCollection(java.io.OutputStream, java.util.List) throws java.io.IOException
{
java.io.OutputStream v;
byte[] v, v;
java.util.List v;
org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer v;
int v, v, v, v, v;
java.lang.Object v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer;
v := @parameter: java.io.OutputStream;
v := @parameter: java.util.List;
v = 0;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
v = v - 1;
if v >= v goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: void streamObject(java.io.OutputStream,java.lang.Object)>(v, v);
v = <org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: byte[] b_comma>;
virtualinvoke v.<java.io.OutputStream: void write(byte[])>(v);
v = v + 1;
goto label;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
v = v - 1;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: void streamObject(java.io.OutputStream,java.lang.Object)>(v, v);
v = <org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: byte[] b_eol>;
virtualinvoke v.<java.io.OutputStream: void write(byte[])>(v);
virtualinvoke v.<java.io.OutputStream: void flush()>();
return;
}
private void streamObject(java.io.OutputStream, java.lang.Object) throws java.io.IOException
{
java.io.OutputStream v;
byte[] v;
org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer v;
java.lang.Object v;
java.lang.String v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer;
v := @parameter: java.io.OutputStream;
v := @parameter: java.lang.Object;
if v != null goto label;
return;
label:
v = virtualinvoke v.<java.lang.Object: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: byte[] getBytes()>();
virtualinvoke v.<java.io.OutputStream: void write(byte[])>(v);
return;
}
static void <clinit>()
{
byte[] v, v;
java.lang.String v, v;
v = ",";
v = virtualinvoke v.<java.lang.String: byte[] getBytes()>();
<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: byte[] b_comma> = v;
v = "\n";
v = virtualinvoke v.<java.lang.String: byte[] getBytes()>();
<org.finos.legend.engine.plan.execution.stores.relational.serialization.StringTDSSerializer: byte[] b_eol> = v;
return;
}
}