public class org.apache.drill.metastore.iceberg.schema.IcebergTableSchema extends java.lang.Object
{
private static final org.slf4j.Logger logger;
public static final int STARTING_SCHEMA_INDEX;
public static final int STARTING_COMPLEX_TYPES_INDEX;
private static final java.util.Map JAVA_TO_ICEBERG_TYPE_MAP;
private final org.apache.iceberg.Schema tableSchema;
private final org.apache.iceberg.PartitionSpec partitionSpec;
public void <init>(org.apache.iceberg.Schema, org.apache.iceberg.PartitionSpec)
{
org.apache.iceberg.PartitionSpec v;
org.apache.iceberg.Schema v;
org.apache.drill.metastore.iceberg.schema.IcebergTableSchema v;
v := @this: org.apache.drill.metastore.iceberg.schema.IcebergTableSchema;
v := @parameter: org.apache.iceberg.Schema;
v := @parameter: org.apache.iceberg.PartitionSpec;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: org.apache.iceberg.Schema tableSchema> = v;
v.<org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: org.apache.iceberg.PartitionSpec partitionSpec> = v;
return;
}
public static org.apache.drill.metastore.iceberg.schema.IcebergTableSchema of(java.lang.Class, java.util.List)
{
org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException v, v, v;
byte v;
java.util.Map v;
org.apache.drill.metastore.iceberg.schema.IcebergTableSchema v;
java.lang.reflect.AnnotatedType v, v;
org.apache.iceberg.Schema v;
org.apache.iceberg.types.Type v, v, v;
java.util.stream.Stream v;
java.lang.Object[] v, v, v, v;
java.util.ArrayList v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
java.lang.reflect.Field v;
org.apache.drill.metastore.MetastoreColumn v;
boolean v, v, v, v;
java.util.function.Predicate v;
org.apache.iceberg.types.Types$NestedField v;
java.util.List v, v;
java.lang.reflect.Type v, v, v, v, v;
java.lang.'annotation'.Annotation v;
java.lang.reflect.Type[] v;
org.apache.iceberg.PartitionSpec v;
int v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.iceberg.types.Types$NestedField[] v;
org.slf4j.Logger v;
java.lang.reflect.Field[] v;
java.lang.Class v, v;
java.lang.Object v, v;
v := @parameter: java.lang.Class;
v := @parameter: java.util.List;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (org.apache.iceberg.types.Types$NestedField)[v];
v = 1;
v = 10000;
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Field[] getDeclaredFields()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.'annotation'.Annotation getAnnotation(java.lang.Class)>(class "Lorg/apache/drill/metastore/MetastoreFieldDefinition;");
if v == null goto label;
v = interfaceinvoke v.<org.apache.drill.metastore.MetastoreFieldDefinition: org.apache.drill.metastore.MetastoreColumn column()>();
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.Class getType()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = virtualinvoke v.<java.lang.String: java.lang.String toLowerCase()>();
v = <org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: java.util.Map JAVA_TO_ICEBERG_TYPE_MAP>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.reflect.AnnotatedType getAnnotatedType()>();
v = interfaceinvoke v.<java.lang.reflect.AnnotatedType: java.lang.reflect.Type getType()>();
v = v instanceof java.lang.reflect.ParameterizedType;
if v == 0 goto label;
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.reflect.AnnotatedType getAnnotatedType()>();
v = interfaceinvoke v.<java.lang.reflect.AnnotatedType: java.lang.reflect.Type getType()>();
v = interfaceinvoke v.<java.lang.reflect.ParameterizedType: java.lang.reflect.Type[] getActualTypeArguments()>();
v = -1;
v = virtualinvoke v.<java.lang.String: int hashCode()>();
lookupswitch(v)
{
case 107868: goto label;
case 3322014: goto label;
default: goto label;
};
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("list");
if v == 0 goto label;
v = 0;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("map");
if v == 0 goto label;
v = 1;
label:
lookupswitch(v)
{
case 0: goto label;
case 1: goto label;
default: goto label;
};
label:
v = v[0];
v = staticinvoke <org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: org.apache.iceberg.types.Type getGenericsType(java.lang.reflect.Type)>(v);
v = v;
v = v + 1;
v = staticinvoke <org.apache.iceberg.types.Types$ListType: org.apache.iceberg.types.Types$ListType ofOptional(int,org.apache.iceberg.types.Type)>(v, v);
goto label;
label:
v = v[0];
v = staticinvoke <org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: org.apache.iceberg.types.Type getGenericsType(java.lang.reflect.Type)>(v);
v = v[1];
v = staticinvoke <org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: org.apache.iceberg.types.Type getGenericsType(java.lang.reflect.Type)>(v);
v = v;
v = v + 1;
v = v + 1;
v = staticinvoke <org.apache.iceberg.types.Types$MapType: org.apache.iceberg.types.Types$MapType ofOptional(int,int,org.apache.iceberg.types.Type,org.apache.iceberg.types.Type)>(v, v, v, v);
goto label;
label:
v = new org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException;
v = newarray (java.lang.Object)[2];
v = virtualinvoke v.<java.lang.Class: java.lang.String getCanonicalName()>();
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Unexpected parametrized type for class [%s]: %s", v);
specialinvoke v.<org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException: void <init>(java.lang.String)>(v);
throw v;
label:
if v != null goto label;
v = new org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException;
v = newarray (java.lang.Object)[2];
v = virtualinvoke v.<java.lang.Class: java.lang.String getCanonicalName()>();
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Unexpected type for class [%s]: %s", v);
specialinvoke v.<org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v;
v = v + 1;
v = virtualinvoke v.<org.apache.drill.metastore.MetastoreColumn: java.lang.String columnName()>();
v = staticinvoke <org.apache.iceberg.types.Types$NestedField: org.apache.iceberg.types.Types$NestedField optional(int,java.lang.String,org.apache.iceberg.types.Type)>(v, v, v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.List: int indexOf(java.lang.Object)>(v);
v = (int) -1;
if v == v goto label;
v[v] = v;
label:
v = v + 1;
goto label;
label:
v = staticinvoke <java.util.stream.Stream: java.util.stream.Stream of(java.lang.Object[])>(v);
v = staticinvoke <org.apache.drill.metastore.iceberg.schema.IcebergTableSchema$isNull__20: java.util.function.Predicate bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: boolean anyMatch(java.util.function.Predicate)>(v);
if v == 0 goto label;
v = new org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException;
v = newarray (java.lang.Object)[3];
v = virtualinvoke v.<java.lang.Class: java.lang.String getCanonicalName()>();
v[0] = v;
v[1] = v;
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
v[2] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Some of partition fields are missing in the class [%s]. Partition keys: %s. Partition values: %s.", v);
specialinvoke v.<org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new org.apache.iceberg.Schema;
specialinvoke v.<org.apache.iceberg.Schema: void <init>(java.util.List)>(v);
v = staticinvoke <org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: org.apache.iceberg.PartitionSpec buildPartitionSpec(org.apache.iceberg.types.Types$NestedField[])>(v);
v = <org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: org.slf4j.Logger logger>;
v = newarray (java.lang.Object)[3];
v = virtualinvoke v.<java.lang.Class: java.lang.String getCanonicalName()>();
v[0] = v;
v[1] = v;
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object[])>("Constructed Iceberg table schema for class [{}]. Table schema : {}. Partition spec: {}.", v);
v = new org.apache.drill.metastore.iceberg.schema.IcebergTableSchema;
specialinvoke v.<org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: void <init>(org.apache.iceberg.Schema,org.apache.iceberg.PartitionSpec)>(v, v);
return v;
}
public org.apache.iceberg.Schema tableSchema()
{
org.apache.iceberg.Schema v;
org.apache.drill.metastore.iceberg.schema.IcebergTableSchema v;
v := @this: org.apache.drill.metastore.iceberg.schema.IcebergTableSchema;
v = v.<org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: org.apache.iceberg.Schema tableSchema>;
return v;
}
public org.apache.iceberg.PartitionSpec partitionSpec()
{
org.apache.iceberg.PartitionSpec v;
org.apache.drill.metastore.iceberg.schema.IcebergTableSchema v;
v := @this: org.apache.drill.metastore.iceberg.schema.IcebergTableSchema;
v = v.<org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: org.apache.iceberg.PartitionSpec partitionSpec>;
return v;
}
private static org.apache.iceberg.types.Type getGenericsType(java.lang.reflect.Type)
{
org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException v, v;
java.lang.reflect.Type v;
java.util.Map v;
java.lang.Object v;
java.lang.String v, v, v, v, v;
boolean v;
v := @parameter: java.lang.reflect.Type;
v = v instanceof java.lang.Class;
if v != 0 goto label;
v = new org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException;
v = interfaceinvoke v.<java.lang.reflect.Type: java.lang.String getTypeName()>();
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[])>("Unexpected generics type: \u0001");
specialinvoke v.<org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = virtualinvoke v.<java.lang.String: java.lang.String toLowerCase()>();
v = <org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: java.util.Map JAVA_TO_ICEBERG_TYPE_MAP>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = new org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException;
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[])>("Unexpected type: \u0001");
specialinvoke v.<org.apache.drill.metastore.iceberg.exceptions.IcebergMetastoreException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
}
private static org.apache.iceberg.PartitionSpec buildPartitionSpec(org.apache.iceberg.types.Types$NestedField[])
{
org.apache.iceberg.PartitionSpec$Builder v;
org.apache.iceberg.Schema v;
java.util.function.Consumer v;
java.util.List v, v;
org.apache.iceberg.PartitionSpec v, v;
org.apache.iceberg.types.Types$NestedField[] v;
boolean v;
v := @parameter: org.apache.iceberg.types.Types$NestedField[];
v = new org.apache.iceberg.Schema;
specialinvoke v.<org.apache.iceberg.Schema: void <init>(org.apache.iceberg.types.Types$NestedField[])>(v);
v = virtualinvoke v.<org.apache.iceberg.Schema: java.util.List columns()>();
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
v = staticinvoke <org.apache.iceberg.PartitionSpec: org.apache.iceberg.PartitionSpec unpartitioned()>();
return v;
label:
v = staticinvoke <org.apache.iceberg.PartitionSpec: org.apache.iceberg.PartitionSpec$Builder builderFor(org.apache.iceberg.Schema)>(v);
v = virtualinvoke v.<org.apache.iceberg.Schema: java.util.List columns()>();
v = staticinvoke <org.apache.drill.metastore.iceberg.schema.IcebergTableSchema$lambda_buildPartitionSpec_0__21: java.util.function.Consumer bootstrap$(org.apache.iceberg.PartitionSpec$Builder)>(v);
interfaceinvoke v.<java.util.List: void forEach(java.util.function.Consumer)>(v);
v = virtualinvoke v.<org.apache.iceberg.PartitionSpec$Builder: org.apache.iceberg.PartitionSpec build()>();
return v;
}
static void <clinit>()
{
org.apache.iceberg.types.Types$BooleanType v;
org.apache.iceberg.types.Types$DoubleType v;
org.apache.iceberg.types.Types$FloatType v;
org.apache.iceberg.types.Types$IntegerType v, v;
org.apache.iceberg.types.Types$LongType v;
org.apache.iceberg.types.Types$StringType v;
org.slf4j.Logger v;
org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder v, v, v, v, v, v, v, v;
org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/drill/metastore/iceberg/schema/IcebergTableSchema;");
<org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: org.slf4j.Logger logger> = v;
v = staticinvoke <org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap: org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder builder()>();
v = staticinvoke <org.apache.iceberg.types.Types$StringType: org.apache.iceberg.types.Types$StringType get()>();
v = virtualinvoke v.<org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder: org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder put(java.lang.Object,java.lang.Object)>("string", v);
v = staticinvoke <org.apache.iceberg.types.Types$IntegerType: org.apache.iceberg.types.Types$IntegerType get()>();
v = virtualinvoke v.<org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder: org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder put(java.lang.Object,java.lang.Object)>("int", v);
v = staticinvoke <org.apache.iceberg.types.Types$IntegerType: org.apache.iceberg.types.Types$IntegerType get()>();
v = virtualinvoke v.<org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder: org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder put(java.lang.Object,java.lang.Object)>("integer", v);
v = staticinvoke <org.apache.iceberg.types.Types$LongType: org.apache.iceberg.types.Types$LongType get()>();
v = virtualinvoke v.<org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder: org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder put(java.lang.Object,java.lang.Object)>("long", v);
v = staticinvoke <org.apache.iceberg.types.Types$FloatType: org.apache.iceberg.types.Types$FloatType get()>();
v = virtualinvoke v.<org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder: org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder put(java.lang.Object,java.lang.Object)>("float", v);
v = staticinvoke <org.apache.iceberg.types.Types$DoubleType: org.apache.iceberg.types.Types$DoubleType get()>();
v = virtualinvoke v.<org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder: org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder put(java.lang.Object,java.lang.Object)>("double", v);
v = staticinvoke <org.apache.iceberg.types.Types$BooleanType: org.apache.iceberg.types.Types$BooleanType get()>();
v = virtualinvoke v.<org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder: org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder put(java.lang.Object,java.lang.Object)>("boolean", v);
v = virtualinvoke v.<org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap$Builder: org.apache.drill.shaded.guava.com.google.common.collect.ImmutableMap build()>();
<org.apache.drill.metastore.iceberg.schema.IcebergTableSchema: java.util.Map JAVA_TO_ICEBERG_TYPE_MAP> = v;
return;
}
}