public class org.apache.drill.exec.store.httpd.HttpdParser extends java.lang.Object
{
private static final org.slf4j.Logger logger;
public static final java.lang.String PARSER_WILDCARD;
private final nl.basjes.parse.core.Parser parser;
private final java.util.List requestedColumns;
private final java.util.Map mappedColumns;
private final java.util.Map columnCasts;
private final org.apache.drill.exec.store.httpd.HttpdLogRecord record;
private final java.lang.String logFormat;
private final boolean parseUserAgent;
private final java.lang.String logParserRemapping;
private java.util.Map requestedPaths;
public void <init>(java.lang.String, java.lang.String, boolean, boolean, java.lang.String, org.apache.drill.exec.store.dfs.easy.EasySubScan)
{
nl.basjes.parse.useragent.dissector.UserAgentDissector v;
nl.basjes.parse.core.Parser v, v;
org.apache.drill.exec.store.dfs.easy.EasySubScan v;
java.lang.String v, v, v, v, v, v;
boolean v, v, v, v, v, v;
nl.basjes.parse.httpdlog.HttpdLoglineParser v;
org.apache.drill.exec.store.httpd.HttpdLogRecord v;
org.slf4j.Logger v, v;
java.util.List v;
java.util.TreeMap v, v;
org.apache.drill.exec.store.httpd.HttpdParser v;
v := @this: org.apache.drill.exec.store.httpd.HttpdParser;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: boolean;
v := @parameter: boolean;
v := @parameter: java.lang.String;
v := @parameter: org.apache.drill.exec.store.dfs.easy.EasySubScan;
specialinvoke v.<java.lang.Object: void <init>()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
staticinvoke <org.apache.drill.shaded.guava.com.google.common.base.Preconditions: void checkArgument(boolean,java.lang.Object)>(v, "logFormat cannot be null or empty");
v.<org.apache.drill.exec.store.httpd.HttpdParser: java.lang.String logFormat> = v;
v.<org.apache.drill.exec.store.httpd.HttpdParser: boolean parseUserAgent> = v;
v = new org.apache.drill.exec.store.httpd.HttpdLogRecord;
specialinvoke v.<org.apache.drill.exec.store.httpd.HttpdLogRecord: void <init>(java.lang.String,boolean)>(v, v);
v.<org.apache.drill.exec.store.httpd.HttpdParser: org.apache.drill.exec.store.httpd.HttpdLogRecord record> = v;
v.<org.apache.drill.exec.store.httpd.HttpdParser: java.lang.String logParserRemapping> = v;
v = new nl.basjes.parse.httpdlog.HttpdLoglineParser;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.lang.String logFormat>;
specialinvoke v.<nl.basjes.parse.httpdlog.HttpdLoglineParser: void <init>(java.lang.Class,java.lang.String,java.lang.String)>(class "Lorg/apache/drill/exec/store/httpd/HttpdLogRecord;", v, v);
v.<org.apache.drill.exec.store.httpd.HttpdParser: nl.basjes.parse.core.Parser parser> = v;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: nl.basjes.parse.core.Parser parser>;
specialinvoke v.<org.apache.drill.exec.store.httpd.HttpdParser: void applyRemapping(nl.basjes.parse.core.Parser)>(v);
if v == 0 goto label;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: nl.basjes.parse.core.Parser parser>;
v = new nl.basjes.parse.useragent.dissector.UserAgentDissector;
specialinvoke v.<nl.basjes.parse.useragent.dissector.UserAgentDissector: void <init>()>();
virtualinvoke v.<nl.basjes.parse.core.Parser: nl.basjes.parse.core.Parser addDissector(nl.basjes.parse.core.Dissector)>(v);
label:
v = virtualinvoke v.<org.apache.drill.exec.store.dfs.easy.EasySubScan: java.util.List getColumns()>();
v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns> = v;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = <org.apache.drill.exec.store.httpd.HttpdParser: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>("Custom timestamp format has been specified. This is an informational note only as custom timestamps is rather unusual.");
label:
v = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>("\n");
if v == 0 goto label;
v = <org.apache.drill.exec.store.httpd.HttpdParser: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("Specified logformat is a multiline log format: {}", v);
label:
v = new java.util.TreeMap;
specialinvoke v.<java.util.TreeMap: void <init>()>();
v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map mappedColumns> = v;
v = new java.util.TreeMap;
specialinvoke v.<java.util.TreeMap: void <init>()>();
v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map columnCasts> = v;
return;
}
private void applyRemapping(nl.basjes.parse.core.Parser)
{
java.lang.String[] v, v;
nl.basjes.parse.core.Parser v;
byte v;
nl.basjes.parse.useragent.analyze.InvalidParserConfigurationException v;
int v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
java.util.EnumSet v, v, v;
boolean v, v, v, v, v;
org.apache.drill.exec.store.httpd.HttpdParser v;
v := @this: org.apache.drill.exec.store.httpd.HttpdParser;
v := @parameter: nl.basjes.parse.core.Parser;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.lang.String logParserRemapping>;
if v == null goto label;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.lang.String logParserRemapping>;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v == 0 goto label;
label:
return;
label:
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.lang.String logParserRemapping>;
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>(";");
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.String: java.lang.String replaceAll(java.lang.String,java.lang.String)>("\n", "");
v = virtualinvoke v.<java.lang.String: java.lang.String replaceAll(java.lang.String,java.lang.String)>(" ", "");
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>(":");
v = v[0];
v = v[1];
v = lengthof v;
if v != 3 goto label;
v = v[2];
goto label;
label:
v = "STRING";
label:
v = -1;
v = virtualinvoke v.<java.lang.String: int hashCode()>();
lookupswitch(v)
{
case -1838656495: goto label;
case 2342524: goto label;
case 2022338513: goto label;
default: goto label;
};
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("STRING");
if v == 0 goto label;
v = 0;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("LONG");
if v == 0 goto label;
v = 1;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("DOUBLE");
if v == 0 goto label;
v = 2;
label:
tableswitch(v)
{
case 0: goto label;
case 1: goto label;
case 2: goto label;
default: goto label;
};
label:
v = <nl.basjes.parse.core.Casts: java.util.EnumSet STRING_ONLY>;
virtualinvoke v.<nl.basjes.parse.core.Parser: nl.basjes.parse.core.Parser addTypeRemapping(java.lang.String,java.lang.String,java.util.EnumSet)>(v, v, v);
goto label;
label:
v = <nl.basjes.parse.core.Casts: java.util.EnumSet LONG_ONLY>;
virtualinvoke v.<nl.basjes.parse.core.Parser: nl.basjes.parse.core.Parser addTypeRemapping(java.lang.String,java.lang.String,java.util.EnumSet)>(v, v, v);
goto label;
label:
v = <nl.basjes.parse.core.Casts: java.util.EnumSet DOUBLE_ONLY>;
virtualinvoke v.<nl.basjes.parse.core.Parser: nl.basjes.parse.core.Parser addTypeRemapping(java.lang.String,java.lang.String,java.util.EnumSet)>(v, v, v);
goto label;
label:
v = new nl.basjes.parse.useragent.analyze.InvalidParserConfigurationException;
specialinvoke v.<nl.basjes.parse.useragent.analyze.InvalidParserConfigurationException: void <init>(java.lang.String)>("Invalid type remapping cast was specified");
throw v;
label:
v = v + 1;
goto label;
label:
return;
}
public void parse(java.lang.String) throws nl.basjes.parse.core.exceptions.DissectionFailure, nl.basjes.parse.core.exceptions.InvalidDissectorException, nl.basjes.parse.core.exceptions.MissingDissectorsException
{
org.apache.drill.exec.store.httpd.HttpdLogRecord v, v;
nl.basjes.parse.core.Parser v;
org.apache.drill.exec.store.httpd.HttpdParser v;
java.lang.String v;
v := @this: org.apache.drill.exec.store.httpd.HttpdParser;
v := @parameter: java.lang.String;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: nl.basjes.parse.core.Parser parser>;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: org.apache.drill.exec.store.httpd.HttpdLogRecord record>;
virtualinvoke v.<nl.basjes.parse.core.Parser: java.lang.Object parse(java.lang.Object,java.lang.String)>(v, v);
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: org.apache.drill.exec.store.httpd.HttpdLogRecord record>;
virtualinvoke v.<org.apache.drill.exec.store.httpd.HttpdLogRecord: void finishRecord()>();
return;
}
public org.apache.drill.exec.record.metadata.TupleMetadata setupParser() throws java.lang.NoSuchMethodException, nl.basjes.parse.core.exceptions.MissingDissectorsException, nl.basjes.parse.core.exceptions.InvalidDissectorException
{
org.apache.drill.exec.record.metadata.SchemaBuilder v;
java.util.Map v, v, v, v, v, v, v, v, v, v, v, v;
java.util.EnumSet v;
java.util.Set v;
nl.basjes.parse.core.Parser v;
java.lang.String v, v, v;
java.lang.Class[] v;
java.util.TreeMap v;
org.apache.drill.exec.store.httpd.HttpdParser v;
nl.basjes.parse.core.Casts v, v, v;
org.apache.drill.common.types.TypeProtos$MinorType v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
int[] v;
java.lang.reflect.Method v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.drill.exec.record.metadata.TupleMetadata v;
java.util.List v;
nl.basjes.parse.useragent.dissector.UserAgentDissector v;
int v, v;
nl.basjes.parse.httpdlog.HttpdLoglineParser v;
org.slf4j.Logger v;
java.util.Iterator v, v;
java.lang.Class v;
java.lang.Object v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.Comparator v;
v := @this: org.apache.drill.exec.store.httpd.HttpdParser;
v = new org.apache.drill.exec.record.metadata.SchemaBuilder;
specialinvoke v.<org.apache.drill.exec.record.metadata.SchemaBuilder: void <init>()>();
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: nl.basjes.parse.core.Parser parser>;
v = virtualinvoke v.<nl.basjes.parse.core.Parser: java.util.List getPossiblePaths()>();
v = staticinvoke <org.apache.drill.exec.store.httpd.HttpdParser$compareTo__1: java.util.Comparator bootstrap$()>();
interfaceinvoke v.<java.util.List: void sort(java.util.Comparator)>(v);
v = new java.util.TreeMap;
specialinvoke v.<java.util.TreeMap: void <init>()>();
v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map requestedPaths> = v;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map requestedPaths>;
v = staticinvoke <org.apache.drill.exec.store.httpd.HttpdUtils: java.lang.String drillFormattedFieldName(java.lang.String)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = new nl.basjes.parse.httpdlog.HttpdLoglineParser;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.lang.String logFormat>;
specialinvoke v.<nl.basjes.parse.httpdlog.HttpdLoglineParser: void <init>(java.lang.Class,java.lang.String)>(class "Ljava/lang/Object;", v);
specialinvoke v.<org.apache.drill.exec.store.httpd.HttpdParser: void applyRemapping(nl.basjes.parse.core.Parser)>(v);
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: boolean parseUserAgent>;
if v == 0 goto label;
v = new nl.basjes.parse.useragent.dissector.UserAgentDissector;
specialinvoke v.<nl.basjes.parse.useragent.dissector.UserAgentDissector: void <init>()>();
virtualinvoke v.<nl.basjes.parse.core.Parser: nl.basjes.parse.core.Parser addDissector(nl.basjes.parse.core.Dissector)>(v);
label:
v = class "Ljava/lang/String;";
v = newarray (java.lang.Class)[1];
v[0] = class "Ljava/lang/String;";
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>("indexOf", v);
virtualinvoke v.<nl.basjes.parse.core.Parser: nl.basjes.parse.core.Parser addParseTarget(java.lang.reflect.Method,java.util.List)>(v, v);
v = virtualinvoke v.<org.apache.drill.exec.store.httpd.HttpdParser: boolean isStarQuery()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.drill.exec.store.httpd.HttpdParser: boolean isMetadataQuery()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.drill.exec.store.httpd.HttpdParser: boolean isOnlyImplicitColumns()>();
if v != 0 goto label;
v = specialinvoke v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map getRequestedColumnPaths()>();
v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map requestedPaths> = v;
label:
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map requestedPaths>;
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<nl.basjes.parse.core.Parser: java.util.EnumSet getCasts(java.lang.String)>(v);
v = <nl.basjes.parse.core.Casts: nl.basjes.parse.core.Casts STRING>;
v = <nl.basjes.parse.core.Casts: nl.basjes.parse.core.Casts DOUBLE>;
v = virtualinvoke v.<java.util.EnumSet: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = <nl.basjes.parse.core.Casts: nl.basjes.parse.core.Casts DOUBLE>;
goto label;
label:
v = <nl.basjes.parse.core.Casts: nl.basjes.parse.core.Casts LONG>;
v = virtualinvoke v.<java.util.EnumSet: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = <nl.basjes.parse.core.Casts: nl.basjes.parse.core.Casts LONG>;
label:
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map columnCasts>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = <org.apache.drill.exec.store.httpd.HttpdParser$1: int[] $SwitchMap$nl$basjes$parse$core$Casts>;
v = virtualinvoke v.<nl.basjes.parse.core.Casts: int ordinal()>();
v = v[v];
tableswitch(v)
{
case 1: goto label;
case 2: goto label;
case 3: goto label;
default: goto label;
};
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("TIME.STAMP:");
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType TIMESTAMP>;
virtualinvoke v.<org.apache.drill.exec.record.metadata.SchemaBuilder: org.apache.drill.exec.record.metadata.SchemaBuilder addNullable(java.lang.String,org.apache.drill.common.types.TypeProtos$MinorType)>(v, v);
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map mappedColumns>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType TIMESTAMP>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("TIME.DATE:");
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType DATE>;
virtualinvoke v.<org.apache.drill.exec.record.metadata.SchemaBuilder: org.apache.drill.exec.record.metadata.SchemaBuilder addNullable(java.lang.String,org.apache.drill.common.types.TypeProtos$MinorType)>(v, v);
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map mappedColumns>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType DATE>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("TIME.TIME:");
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType TIME>;
virtualinvoke v.<org.apache.drill.exec.record.metadata.SchemaBuilder: org.apache.drill.exec.record.metadata.SchemaBuilder addNullable(java.lang.String,org.apache.drill.common.types.TypeProtos$MinorType)>(v, v);
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map mappedColumns>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType TIME>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = staticinvoke <org.apache.drill.exec.store.httpd.HttpdUtils: boolean isWildcard(java.lang.String)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
virtualinvoke v.<org.apache.drill.exec.record.metadata.SchemaBuilder: org.apache.drill.exec.record.metadata.MapBuilder addMap(java.lang.String)>(v);
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map mappedColumns>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType MAP>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType VARCHAR>;
virtualinvoke v.<org.apache.drill.exec.record.metadata.SchemaBuilder: org.apache.drill.exec.record.metadata.SchemaBuilder addNullable(java.lang.String,org.apache.drill.common.types.TypeProtos$MinorType)>(v, v);
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map mappedColumns>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType VARCHAR>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("TIME.EPOCH:");
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType TIMESTAMP>;
virtualinvoke v.<org.apache.drill.exec.record.metadata.SchemaBuilder: org.apache.drill.exec.record.metadata.SchemaBuilder addNullable(java.lang.String,org.apache.drill.common.types.TypeProtos$MinorType)>(v, v);
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map mappedColumns>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType TIMESTAMP>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType BIGINT>;
virtualinvoke v.<org.apache.drill.exec.record.metadata.SchemaBuilder: org.apache.drill.exec.record.metadata.SchemaBuilder addNullable(java.lang.String,org.apache.drill.common.types.TypeProtos$MinorType)>(v, v);
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map mappedColumns>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType BIGINT>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType FLOAT8>;
virtualinvoke v.<org.apache.drill.exec.record.metadata.SchemaBuilder: org.apache.drill.exec.record.metadata.SchemaBuilder addNullable(java.lang.String,org.apache.drill.common.types.TypeProtos$MinorType)>(v, v);
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map mappedColumns>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = <org.apache.drill.common.types.TypeProtos$MinorType: org.apache.drill.common.types.TypeProtos$MinorType FLOAT8>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = <org.apache.drill.exec.store.httpd.HttpdParser: org.slf4j.Logger logger>;
v = virtualinvoke v.<nl.basjes.parse.core.Casts: java.lang.String toString()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("HTTPD Unsupported data type {} for field {}", v, v);
goto label;
label:
v = virtualinvoke v.<org.apache.drill.exec.record.metadata.SchemaBuilder: org.apache.drill.exec.record.metadata.TupleMetadata build()>();
return v;
}
private java.util.Map getRequestedColumnPaths()
{
java.util.Map v, v;
java.lang.String v;
boolean v;
java.util.Iterator v;
java.util.function.Predicate v;
java.util.Set v;
java.util.function.Consumer v;
java.util.List v;
java.util.stream.Stream v, v;
java.util.TreeMap v;
org.apache.drill.exec.store.httpd.HttpdParser v;
java.util.Optional v;
java.lang.Object v, v;
v := @this: org.apache.drill.exec.store.httpd.HttpdParser;
v = new java.util.TreeMap;
specialinvoke v.<java.util.TreeMap: void <init>()>();
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.drill.common.expression.SchemaPath: java.lang.String getRootSegmentPath()>();
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map requestedPaths>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map requestedPaths>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.stream.Stream stream()>();
v = staticinvoke <org.apache.drill.exec.store.httpd.HttpdParser$lambda_getRequestedColumnPaths_0__2: java.util.function.Predicate bootstrap$(org.apache.drill.common.expression.SchemaPath)>(v);
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream filter(java.util.function.Predicate)>(v);
v = interfaceinvoke v.<java.util.stream.Stream: java.util.Optional findAny()>();
v = staticinvoke <org.apache.drill.exec.store.httpd.HttpdParser$lambda_getRequestedColumnPaths_1__3: java.util.function.Consumer bootstrap$(org.apache.drill.exec.store.httpd.HttpdParser,java.util.Map)>(v, v);
virtualinvoke v.<java.util.Optional: void ifPresent(java.util.function.Consumer)>(v);
goto label;
label:
return v;
}
public void addFieldsToParser(org.apache.drill.exec.physical.resultSet.RowSetLoader)
{
java.lang.NoSuchMethodException v;
org.apache.drill.exec.physical.resultSet.RowSetLoader v;
nl.basjes.parse.core.Parser v;
java.util.Map v, v, v;
boolean v;
org.apache.drill.exec.store.httpd.HttpdLogRecord v;
org.slf4j.Logger v, v;
java.util.Iterator v;
java.util.Set v;
org.apache.drill.exec.store.httpd.HttpdParser v;
java.lang.Object v, v, v;
v := @this: org.apache.drill.exec.store.httpd.HttpdParser;
v := @parameter: org.apache.drill.exec.physical.resultSet.RowSetLoader;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map requestedPaths>;
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
label:
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: org.apache.drill.exec.store.httpd.HttpdLogRecord record>;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: nl.basjes.parse.core.Parser parser>;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map columnCasts>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.Map mappedColumns>;
virtualinvoke v.<org.apache.drill.exec.store.httpd.HttpdLogRecord: void addField(nl.basjes.parse.core.Parser,org.apache.drill.exec.physical.resultSet.RowSetLoader,java.util.Map,java.lang.String,java.lang.String,java.util.Map)>(v, v, v, v, v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.drill.exec.store.httpd.HttpdParser: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>("Error adding fields to parser.");
goto label;
label:
v = <org.apache.drill.exec.store.httpd.HttpdParser: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Added Fields to Parser");
return;
catch java.lang.NoSuchMethodException from label to label with label;
}
public boolean isStarQuery()
{
java.util.List v;
java.util.stream.Stream v;
org.apache.drill.exec.store.httpd.HttpdParser v;
java.util.function.Predicate v;
boolean v;
v := @this: org.apache.drill.exec.store.httpd.HttpdParser;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns>;
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = staticinvoke <org.apache.drill.exec.store.httpd.HttpdParser$isDynamicStar__4: java.util.function.Predicate bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: boolean anyMatch(java.util.function.Predicate)>(v);
return v;
}
public boolean isMetadataQuery()
{
java.util.List v;
org.apache.drill.exec.store.httpd.HttpdParser v;
int v;
boolean v;
v := @this: org.apache.drill.exec.store.httpd.HttpdParser;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public boolean isOnlyImplicitColumns()
{
int v, v;
boolean v, v, v, v, v, v, v, v;
java.util.List v, v, v, v, v, v, v, v;
org.apache.drill.exec.store.httpd.HttpdParser v;
java.lang.Object v, v, v, v, v, v;
v := @this: org.apache.drill.exec.store.httpd.HttpdParser;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v <= 2 goto label;
return 0;
label:
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v != 1 goto label;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = virtualinvoke v.<org.apache.drill.common.expression.SchemaPath: boolean nameEquals(java.lang.String)>("_raw");
if v != 0 goto label;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = virtualinvoke v.<org.apache.drill.common.expression.SchemaPath: boolean nameEquals(java.lang.String)>("_matched");
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
label:
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = virtualinvoke v.<org.apache.drill.common.expression.SchemaPath: boolean nameEquals(java.lang.String)>("_raw");
if v != 0 goto label;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = virtualinvoke v.<org.apache.drill.common.expression.SchemaPath: boolean nameEquals(java.lang.String)>("_matched");
if v == 0 goto label;
label:
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(1);
v = virtualinvoke v.<org.apache.drill.common.expression.SchemaPath: boolean nameEquals(java.lang.String)>("_raw");
if v != 0 goto label;
v = v.<org.apache.drill.exec.store.httpd.HttpdParser: java.util.List requestedColumns>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(1);
v = virtualinvoke v.<org.apache.drill.common.expression.SchemaPath: boolean nameEquals(java.lang.String)>("_matched");
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/drill/exec/store/httpd/HttpdParser;");
<org.apache.drill.exec.store.httpd.HttpdParser: org.slf4j.Logger logger> = v;
return;
}
}