public class nl.basjes.parse.useragent.hive.ParseUserAgent extends org.apache.hadoop.hive.ql.udf.generic.GenericUDF
{
private java.util.List argsOI;
private static java.lang.ThreadLocal threadLocalUserAgentAnalyzer;
private java.util.List fieldNames;
private java.util.List allHeaders;
public void <init>()
{
nl.basjes.parse.useragent.hive.ParseUserAgent v;
v := @this: nl.basjes.parse.useragent.hive.ParseUserAgent;
specialinvoke v.<org.apache.hadoop.hive.ql.udf.generic.GenericUDF: void <init>()>();
v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List argsOI> = null;
v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List fieldNames> = null;
v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List allHeaders> = null;
return;
}
public void close()
{
nl.basjes.parse.useragent.hive.ParseUserAgent v;
java.lang.ThreadLocal v;
v := @this: nl.basjes.parse.useragent.hive.ParseUserAgent;
v = <nl.basjes.parse.useragent.hive.ParseUserAgent: java.lang.ThreadLocal threadLocalUserAgentAnalyzer>;
virtualinvoke v.<java.lang.ThreadLocal: void remove()>();
return;
}
public org.apache.hadoop.hive.serde.objectinspector.ObjectInspector initialize(org.apache.hadoop.hive.serde.objectinspector.ObjectInspector[]) throws org.apache.hadoop.hive.ql.exec.UDFArgumentException
{
org.apache.hadoop.hive.ql.exec.UDFArgumentException v, v;
org.apache.hadoop.hive.serde.objectinspector.StandardStructObjectInspector v;
java.util.ArrayList v, v, v;
nl.basjes.parse.useragent.hive.ParseUserAgent v;
int v, v, v, v;
org.apache.hadoop.hive.serde.objectinspector.ObjectInspector v;
boolean v;
java.lang.ThreadLocal v;
org.apache.hadoop.hive.serde.objectinspector.ObjectInspector[] v;
java.util.function.Consumer v;
java.util.List v, v, v, v, v, v, v, v;
java.lang.Object v;
v := @this: nl.basjes.parse.useragent.hive.ParseUserAgent;
v := @parameter: org.apache.hadoop.hive.serde.objectinspector.ObjectInspector[];
v = lengthof v;
if v != 0 goto label;
v = new org.apache.hadoop.hive.ql.exec.UDFArgumentException;
specialinvoke v.<org.apache.hadoop.hive.ql.exec.UDFArgumentException: void <init>(java.lang.String)>("The argument list must be non empty");
throw v;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List argsOI> = v;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = v instanceof org.apache.hadoop.hive.serde.objectinspector.primitive.StringObjectInspector;
if v != 0 goto label;
v = new org.apache.hadoop.hive.ql.exec.UDFArgumentException;
specialinvoke v.<org.apache.hadoop.hive.ql.exec.UDFArgumentException: void <init>(java.lang.String)>("The argument must be a string");
throw v;
label:
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List argsOI>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = <nl.basjes.parse.useragent.hive.ParseUserAgent: java.lang.ThreadLocal threadLocalUserAgentAnalyzer>;
v = virtualinvoke v.<java.lang.ThreadLocal: java.lang.Object get()>();
v = virtualinvoke v.<nl.basjes.parse.useragent.UserAgentAnalyzer: java.util.List getAllPossibleFieldNamesSorted()>();
v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List fieldNames> = v;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List allHeaders> = v;
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List allHeaders>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>("User-Agent");
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List allHeaders>;
v = virtualinvoke v.<nl.basjes.parse.useragent.UserAgentAnalyzer: java.util.List supportedClientHintHeaders()>();
interfaceinvoke v.<java.util.List: boolean addAll(java.util.Collection)>(v);
v = new java.util.ArrayList;
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List fieldNames>;
v = interfaceinvoke v.<java.util.List: int size()>();
specialinvoke v.<java.util.ArrayList: void <init>(int)>(v);
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List fieldNames>;
v = staticinvoke <nl.basjes.parse.useragent.hive.ParseUserAgent$lambda_initialize_1__1167: java.util.function.Consumer bootstrap$(java.util.List)>(v);
interfaceinvoke v.<java.util.List: void forEach(java.util.function.Consumer)>(v);
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List fieldNames>;
v = staticinvoke <org.apache.hadoop.hive.serde.objectinspector.ObjectInspectorFactory: org.apache.hadoop.hive.serde.objectinspector.StandardStructObjectInspector getStandardStructObjectInspector(java.util.List,java.util.List)>(v, v);
return v;
}
public java.lang.Object evaluate(org.apache.hadoop.hive.ql.udf.generic.GenericUDF$DeferredObject[]) throws org.apache.hadoop.hive.ql.metadata.HiveException
{
org.apache.hadoop.io.Text v;
nl.basjes.parse.useragent.hive.ParseUserAgent v;
boolean v, v;
java.lang.ThreadLocal v;
java.util.function.Predicate v;
java.util.List v, v, v, v, v, v, v;
java.util.stream.Stream v;
java.lang.Object[] v;
java.util.ArrayList v;
nl.basjes.parse.useragent.UserAgent$ImmutableUserAgent v;
int v, v, v, v, v, v, v, v;
java.lang.String v, v, v;
java.util.Iterator v;
java.lang.IllegalArgumentException v, v;
org.apache.hadoop.hive.ql.udf.generic.GenericUDF$DeferredObject[] v;
java.util.TreeMap v;
org.apache.hadoop.hive.ql.udf.generic.GenericUDF$DeferredObject v, v;
java.lang.Object v, v, v, v, v, v;
v := @this: nl.basjes.parse.useragent.hive.ParseUserAgent;
v := @parameter: org.apache.hadoop.hive.ql.udf.generic.GenericUDF$DeferredObject[];
v = new java.util.TreeMap;
specialinvoke v.<java.util.TreeMap: void <init>()>();
v = 0;
label:
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List argsOI>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List argsOI>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v = v[v];
v = interfaceinvoke v.<org.apache.hadoop.hive.ql.udf.generic.GenericUDF$DeferredObject: java.lang.Object get()>();
v = interfaceinvoke v.<org.apache.hadoop.hive.serde.objectinspector.primitive.StringObjectInspector: java.lang.String getPrimitiveJavaObject(java.lang.Object)>(v);
if v == null goto label;
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List allHeaders>;
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <nl.basjes.parse.useragent.hive.ParseUserAgent$equalsIgnoreCase__1168: java.util.function.Predicate bootstrap$(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.stream.Stream: boolean anyMatch(java.util.function.Predicate)>(v);
if v == 0 goto label;
v = v + 1;
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List argsOI>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v < v goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Invalid last element in argument list (was a header name which requires a value to follow)");
throw v;
label:
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List argsOI>;
v = v + 1;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v = v + 1;
v = v[v];
v = interfaceinvoke v.<org.apache.hadoop.hive.ql.udf.generic.GenericUDF$DeferredObject: java.lang.Object get()>();
v = interfaceinvoke v.<org.apache.hadoop.hive.serde.objectinspector.primitive.StringObjectInspector: java.lang.String getPrimitiveJavaObject(java.lang.Object)>(v);
v = v + 1;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v + 1;
goto label;
label:
if v != 0 goto label;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("User-Agent", v);
v = v + 1;
goto label;
label:
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Bad argument list for ParseUserAgent.");
throw v;
label:
v = <nl.basjes.parse.useragent.hive.ParseUserAgent: java.lang.ThreadLocal threadLocalUserAgentAnalyzer>;
v = virtualinvoke v.<java.lang.ThreadLocal: java.lang.Object get()>();
v = virtualinvoke v.<nl.basjes.parse.useragent.UserAgentAnalyzer: nl.basjes.parse.useragent.UserAgent$ImmutableUserAgent parse(java.util.Map)>(v);
v = new java.util.ArrayList;
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List fieldNames>;
v = interfaceinvoke v.<java.util.List: int size()>();
specialinvoke v.<java.util.ArrayList: void <init>(int)>(v);
v = v.<nl.basjes.parse.useragent.hive.ParseUserAgent: java.util.List fieldNames>;
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 = interfaceinvoke v.<nl.basjes.parse.useragent.UserAgent: java.lang.String getValue(java.lang.String)>(v);
if v != null goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(null);
goto label;
label:
v = new org.apache.hadoop.io.Text;
specialinvoke v.<org.apache.hadoop.io.Text: void <init>(java.lang.String)>(v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray()>();
return v;
}
public java.lang.String getDisplayString(java.lang.String[])
{
nl.basjes.parse.useragent.hive.ParseUserAgent v;
java.lang.String[] v;
v := @this: nl.basjes.parse.useragent.hive.ParseUserAgent;
v := @parameter: java.lang.String[];
return "Parses the UserAgent into all possible pieces.";
}
static void <clinit>()
{
java.lang.ThreadLocal v;
java.util.function.Supplier v;
v = staticinvoke <nl.basjes.parse.useragent.hive.ParseUserAgent$lambda_static_0__1169: java.util.function.Supplier bootstrap$()>();
v = staticinvoke <java.lang.ThreadLocal: java.lang.ThreadLocal withInitial(java.util.function.Supplier)>(v);
<nl.basjes.parse.useragent.hive.ParseUserAgent: java.lang.ThreadLocal threadLocalUserAgentAnalyzer> = v;
return;
}
}