public class org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable extends java.lang.Object implements org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.statements.DDLStatement
{
private org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table table;
private final java.util.List modifiers;
private final java.util.List columns;
private final java.util.List tableConstraints;
private final java.util.List types;
private final java.util.List clusterKeys;
private final java.util.List partitionKeys;
public void <init>()
{
org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable v;
java.util.ArrayList v, v, v, v, v, v;
v := @this: org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List modifiers> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List columns> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List tableConstraints> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List types> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List clusterKeys> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List partitionKeys> = v;
return;
}
public void genSql(java.lang.StringBuilder) throws org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException
{
org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause v, v, v, v;
java.lang.String v, v, v, v, v, v, v;
boolean v, v;
org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable v;
org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table v;
java.util.List v, v, v, v, v, v, v, v;
java.lang.StringBuilder v;
v := @this: org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable;
v := @parameter: java.lang.StringBuilder;
virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: void validate()>();
v = <org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause CREATE>;
v = virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: java.lang.String get()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List types>;
staticinvoke <org.finos.legend.engine.persistence.components.relational.sqldom.SqlGen: void genSqlList(java.lang.StringBuilder,java.util.List,java.lang.String,java.lang.String)>(v, v, " ", " ");
v = <org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause TABLE>;
v = virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: java.lang.String get()>();
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[])>(" \u0001");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List modifiers>;
staticinvoke <org.finos.legend.engine.persistence.components.relational.sqldom.SqlGen: void genSqlList(java.lang.StringBuilder,java.util.List,java.lang.String,java.lang.String)>(v, v, " ", " ");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ");
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table table>;
virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table: void genSqlWithoutAlias(java.lang.StringBuilder)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("(");
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List columns>;
staticinvoke <org.finos.legend.engine.persistence.components.relational.sqldom.SqlGen: void genSqlList(java.lang.StringBuilder,java.util.List,java.lang.String,java.lang.String)>(v, v, "", ",");
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List tableConstraints>;
staticinvoke <org.finos.legend.engine.persistence.components.relational.sqldom.SqlGen: void genSqlList(java.lang.StringBuilder,java.util.List,java.lang.String,java.lang.String)>(v, v, ",", ",");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(")");
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List partitionKeys>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = <org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause PARTITION_BY>;
v = virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: java.lang.String get()>();
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[])>(" \u ");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List partitionKeys>;
staticinvoke <org.finos.legend.engine.persistence.components.relational.sqldom.SqlGen: void genSqlList(java.lang.StringBuilder,java.util.List,java.lang.String,java.lang.String)>(v, v, "", ",");
label:
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List clusterKeys>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = <org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause CLUSTER_BY>;
v = virtualinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.common.Clause: java.lang.String get()>();
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[])>(" \u ");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List clusterKeys>;
staticinvoke <org.finos.legend.engine.persistence.components.relational.sqldom.SqlGen: void genSqlList(java.lang.StringBuilder,java.util.List,java.lang.String,java.lang.String)>(v, v, "", ",");
label:
return;
}
public void push(java.lang.Object)
{
org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable v;
java.util.List v, v, v, v, v, v;
java.lang.Object v;
boolean v, v, v, v, v, v, v;
v := @this: org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable;
v := @parameter: java.lang.Object;
v = v instanceof org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table;
if v == 0 goto label;
v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table table> = v;
goto label;
label:
v = v instanceof org.finos.legend.engine.persistence.components.relational.sqldom.tabletypes.TableType;
if v == 0 goto label;
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List types>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = v instanceof org.finos.legend.engine.persistence.components.relational.sqldom.modifiers.TableModifier;
if v == 0 goto label;
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List modifiers>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = v instanceof org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.Column;
if v == 0 goto label;
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List columns>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = v instanceof org.finos.legend.engine.persistence.components.relational.sqldom.constraints.table.TableConstraint;
if v == 0 goto label;
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List tableConstraints>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = v instanceof org.finos.legend.engine.persistence.components.relational.sqldom.constraints.table.ClusteringKeyConstraint;
if v == 0 goto label;
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List clusterKeys>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = v instanceof org.finos.legend.engine.persistence.components.relational.sqldom.constraints.table.PartitionKeyConstraint;
if v == 0 goto label;
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List partitionKeys>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
return;
}
void validate() throws org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException
{
org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable v;
org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException v, v, v;
org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table v;
java.util.List v, v, v, v;
int v;
boolean v, v;
v := @this: org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable;
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: org.finos.legend.engine.persistence.components.relational.sqldom.schemaops.expresssions.table.Table table>;
if v != null goto label;
v = new org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException;
specialinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException: void <init>(java.lang.String)>("Table is mandatory for Create Table Command");
throw v;
label:
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List columns>;
if v == null goto label;
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List columns>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
label:
v = new org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException;
specialinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException: void <init>(java.lang.String)>("Columns list is mandatory for Create Table Command");
throw v;
label:
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List partitionKeys>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.finos.legend.engine.persistence.components.relational.bigquery.sqldom.schemaops.statements.CreateTable: java.util.List partitionKeys>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v == 1 goto label;
v = new org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException;
specialinvoke v.<org.finos.legend.engine.persistence.components.relational.sqldom.SqlDomException: void <init>(java.lang.String)>("Only one Partition Key expression is allowed for BigQuery Create Table Command");
throw v;
label:
return;
}
}