public class org.apache.hive.common.util.TimestampParser extends java.lang.Object
{
private static final org.slf4j.Logger LOG;
public static final java.lang.String MILLIS_FORMAT_STR;
public static final java.lang.String ISO_8601_FORMAT_STR;
public static final java.lang.String RFC_1123_FORMAT_STR;
private final java.util.Collection dtFormatters;
private final boolean supportMillisEpoch;
public void <init>()
{
java.util.List v;
org.apache.hive.common.util.TimestampParser v;
v := @this: org.apache.hive.common.util.TimestampParser;
v = staticinvoke <java.util.Collections: java.util.List emptyList()>();
specialinvoke v.<org.apache.hive.common.util.TimestampParser: void <init>(java.util.Collection)>(v);
return;
}
public void <init>(org.apache.hive.common.util.TimestampParser)
{
java.util.Collection v;
org.apache.hive.common.util.TimestampParser v, v;
boolean v;
v := @this: org.apache.hive.common.util.TimestampParser;
v := @parameter: org.apache.hive.common.util.TimestampParser;
specialinvoke v.<java.lang.Object: void <init>()>();
v = v.<org.apache.hive.common.util.TimestampParser: java.util.Collection dtFormatters>;
v.<org.apache.hive.common.util.TimestampParser: java.util.Collection dtFormatters> = v;
v = v.<org.apache.hive.common.util.TimestampParser: boolean supportMillisEpoch>;
v.<org.apache.hive.common.util.TimestampParser: boolean supportMillisEpoch> = v;
return;
}
public void <init>(java.lang.String[])
{
java.lang.String[] v;
java.util.List v;
org.apache.hive.common.util.TimestampParser v;
v := @this: org.apache.hive.common.util.TimestampParser;
v := @parameter: java.lang.String[];
if v != null goto label;
v = staticinvoke <java.util.Collections: java.util.List emptyList()>();
goto label;
label:
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
label:
specialinvoke v.<org.apache.hive.common.util.TimestampParser: void <init>(java.util.Collection)>(v);
return;
}
public void <init>(java.util.Collection)
{
java.util.ArrayList v;
java.util.HashSet v;
byte v;
int v;
boolean v, v, v, v, v;
java.util.Iterator v;
java.util.Collection v, v;
java.util.List v;
java.time.format.DateTimeFormatter v;
java.lang.Object v;
org.apache.hive.common.util.TimestampParser v;
v := @this: org.apache.hive.common.util.TimestampParser;
v := @parameter: java.util.Collection;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>(java.util.Collection)>(v);
v = interfaceinvoke v.<java.util.Collection: boolean remove(java.lang.Object)>("millis");
v.<org.apache.hive.common.util.TimestampParser: boolean supportMillisEpoch> = v;
v = interfaceinvoke v.<java.util.Collection: boolean isEmpty()>();
if v == 0 goto label;
v = staticinvoke <java.util.Collections: java.util.List emptyList()>();
v.<org.apache.hive.common.util.TimestampParser: java.util.Collection dtFormatters> = v;
return;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.apache.hive.common.util.TimestampParser: java.util.Collection dtFormatters> = v;
v = interfaceinvoke v.<java.util.Collection: 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 = -1;
v = virtualinvoke v.<java.lang.String: int hashCode()>();
lookupswitch(v)
{
case 1109314960: goto label;
case 2095190916: goto label;
default: goto label;
};
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("iso8601");
if v == 0 goto label;
v = 0;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("rfc1123");
if v == 0 goto label;
v = 1;
label:
lookupswitch(v)
{
case 0: goto label;
case 1: goto label;
default: goto label;
};
label:
v = <java.time.format.DateTimeFormatter: java.time.format.DateTimeFormatter ISO_INSTANT>;
goto label;
label:
v = <java.time.format.DateTimeFormatter: java.time.format.DateTimeFormatter RFC_1123_DATE_TIME>;
goto label;
label:
v = staticinvoke <java.time.format.DateTimeFormatter: java.time.format.DateTimeFormatter ofPattern(java.lang.String)>(v);
label:
v = v.<org.apache.hive.common.util.TimestampParser: java.util.Collection dtFormatters>;
interfaceinvoke v.<java.util.Collection: boolean add(java.lang.Object)>(v);
goto label;
label:
return;
}
public org.apache.hadoop.hive.common.type.Timestamp parseTimestamp(java.lang.String)
{
long v, v;
java.time.temporal.TemporalAccessor v, v;
java.math.BigDecimal v, v;
java.lang.String v;
boolean v, v;
java.math.RoundingMode v;
org.slf4j.Logger v, v;
java.util.Iterator v;
org.apache.hadoop.hive.common.type.Timestamp v, v, v;
java.util.Collection v;
java.lang.NumberFormatException v;
java.lang.IllegalArgumentException v;
java.time.Instant v;
java.time.format.DateTimeParseException v;
java.lang.Object v;
org.apache.hive.common.util.TimestampParser v;
v := @this: org.apache.hive.common.util.TimestampParser;
v := @parameter: java.lang.String;
v = v.<org.apache.hive.common.util.TimestampParser: boolean supportMillisEpoch>;
if v == 0 goto label;
label:
v = new java.math.BigDecimal;
specialinvoke v.<java.math.BigDecimal: void <init>(java.lang.String)>(v);
v = <java.math.RoundingMode: java.math.RoundingMode DOWN>;
v = virtualinvoke v.<java.math.BigDecimal: java.math.BigDecimal setScale(int,java.math.RoundingMode)>(0, v);
v = virtualinvoke v.<java.math.BigDecimal: long longValueExact()>();
v = staticinvoke <org.apache.hadoop.hive.common.type.Timestamp: org.apache.hadoop.hive.common.type.Timestamp ofEpochMilli(long)>(v);
label:
return v;
label:
v := @caughtexception;
v = <org.apache.hive.common.util.TimestampParser: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Could not format millis: {}", v);
label:
v = v.<org.apache.hive.common.util.TimestampParser: java.util.Collection dtFormatters>;
v = interfaceinvoke v.<java.util.Collection: 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 = virtualinvoke v.<java.time.format.DateTimeFormatter: java.time.temporal.TemporalAccessor parse(java.lang.CharSequence)>(v);
v = specialinvoke v.<org.apache.hive.common.util.TimestampParser: java.time.temporal.TemporalAccessor wrap(java.time.temporal.TemporalAccessor)>(v);
v = staticinvoke <java.time.Instant: java.time.Instant 'from'(java.time.temporal.TemporalAccessor)>(v);
v = virtualinvoke v.<java.time.Instant: long toEpochMilli()>();
v = staticinvoke <org.apache.hadoop.hive.common.type.Timestamp: org.apache.hadoop.hive.common.type.Timestamp ofEpochMilli(long)>(v);
label:
return v;
label:
v := @caughtexception;
v = <org.apache.hive.common.util.TimestampParser: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Could not parse timestamp text: {}", v);
goto label;
label:
v = staticinvoke <org.apache.hadoop.hive.common.type.Timestamp: org.apache.hadoop.hive.common.type.Timestamp valueOf(java.lang.String)>(v);
label:
return v;
label:
v := @caughtexception;
return null;
catch java.lang.NumberFormatException from label to label with label;
catch java.time.format.DateTimeParseException from label to label with label;
catch java.lang.IllegalArgumentException from label to label with label;
}
private java.time.temporal.TemporalAccessor wrap(java.time.temporal.TemporalAccessor)
{
java.time.temporal.ChronoField v, v;
org.apache.hive.common.util.TimestampParser$DefaultingTemporalAccessor v;
org.apache.hive.common.util.TimestampParser v;
boolean v, v;
java.time.temporal.TemporalAccessor v;
v := @this: org.apache.hive.common.util.TimestampParser;
v := @parameter: java.time.temporal.TemporalAccessor;
v = <java.time.temporal.ChronoField: java.time.temporal.ChronoField INSTANT_SECONDS>;
v = interfaceinvoke v.<java.time.temporal.TemporalAccessor: boolean isSupported(java.time.temporal.TemporalField)>(v);
if v == 0 goto label;
v = <java.time.temporal.ChronoField: java.time.temporal.ChronoField NANO_OF_SECOND>;
v = interfaceinvoke v.<java.time.temporal.TemporalAccessor: boolean isSupported(java.time.temporal.TemporalField)>(v);
if v == 0 goto label;
return v;
label:
v = new org.apache.hive.common.util.TimestampParser$DefaultingTemporalAccessor;
specialinvoke v.<org.apache.hive.common.util.TimestampParser$DefaultingTemporalAccessor: void <init>(java.time.temporal.TemporalAccessor)>(v);
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/hive/common/util/TimestampParser;");
<org.apache.hive.common.util.TimestampParser: org.slf4j.Logger LOG> = v;
return;
}
}