public interface  nl.basjes.parse.useragent.AnalyzerPreHeater extends java.lang.Object implements nl.basjes.parse.useragent.Analyzer
{
public static final org.apache.logging.log4j.Logger LOG;
public static final long MAX_PRE_HEAT_ITERATIONS;
public abstract java.util.List getPreheatTestCases();
public java.util.List internalGetTestCasesForPreheat()
{
nl.basjes.parse.useragent.AnalyzerPreHeater v;
java.util.function.Function v;
java.util.List v, v;
java.util.stream.Stream v, v;
java.lang.Object v;
java.util.stream.Collector v;
boolean v;
v := @this: nl.basjes.parse.useragent.AnalyzerPreHeater;
v = interfaceinvoke v.<nl.basjes.parse.useragent.AnalyzerPreHeater: java.util.List getPreheatTestCases()>();
if v == null goto label;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
label:
v = <nl.basjes.parse.useragent.PreHeatCases: java.util.List USERAGENTS>;
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = staticinvoke <nl.basjes.parse.useragent.AnalyzerPreHeater$lambda_internalGetTestCasesForPreheat_0__506: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream map(java.util.function.Function)>(v);
v = staticinvoke <java.util.stream.Collectors: java.util.stream.Collector toList()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object collect(java.util.stream.Collector)>(v);
label:
return v;
}
public long preHeat()
{
java.util.List v;
int v;
nl.basjes.parse.useragent.AnalyzerPreHeater v;
long v;
v := @this: nl.basjes.parse.useragent.AnalyzerPreHeater;
v = interfaceinvoke v.<nl.basjes.parse.useragent.AnalyzerPreHeater: java.util.List internalGetTestCasesForPreheat()>();
v = interfaceinvoke v.<java.util.List: int size()>();
v = interfaceinvoke v.<nl.basjes.parse.useragent.AnalyzerPreHeater: long preHeat(java.util.List,long,boolean)>(v, v, 1);
return v;
}
public long preHeat(long)
{
nl.basjes.parse.useragent.AnalyzerPreHeater v;
long v, v;
v := @this: nl.basjes.parse.useragent.AnalyzerPreHeater;
v := @parameter: long;
v = interfaceinvoke v.<nl.basjes.parse.useragent.AnalyzerPreHeater: long preHeat(long,boolean)>(v, 1);
return v;
}
public long preHeat(long, boolean)
{
java.util.List v;
nl.basjes.parse.useragent.AnalyzerPreHeater v;
long v, v;
boolean v;
v := @this: nl.basjes.parse.useragent.AnalyzerPreHeater;
v := @parameter: long;
v := @parameter: boolean;
v = interfaceinvoke v.<nl.basjes.parse.useragent.AnalyzerPreHeater: java.util.List internalGetTestCasesForPreheat()>();
v = interfaceinvoke v.<nl.basjes.parse.useragent.AnalyzerPreHeater: long preHeat(java.util.List,long,boolean)>(v, v, v);
return v;
}
public long preHeat(java.util.List, long, boolean)
{
byte v, v, v, v;
java.lang.Long v, v, v, v, v, v, v;
java.util.Map v;
boolean v, v, v, v;
java.util.List v;
org.apache.logging.log4j.Logger v, v, v, v, v, v;
java.lang.Double v;
nl.basjes.parse.useragent.AnalyzerPreHeater v;
long v, v, v, v, v, v, v, v;
nl.basjes.parse.useragent.UserAgent$ImmutableUserAgent v;
double v, v;
java.util.Iterator v;
java.lang.Object v;
v := @this: nl.basjes.parse.useragent.AnalyzerPreHeater;
v := @parameter: java.util.List;
v := @parameter: long;
v := @parameter: boolean;
if v == null goto label;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
label:
v = <nl.basjes.parse.useragent.AnalyzerPreHeater: org.apache.logging.log4j.Logger LOG>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void fatal(java.lang.String)>("NO PREHEAT WAS DONE. This should never occur.");
return 0L;
label:
v = v cmp 0L;
if v > 0 goto label;
v = <nl.basjes.parse.useragent.AnalyzerPreHeater: org.apache.logging.log4j.Logger LOG>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object)>("NO PREHEAT WAS DONE. Simply because you asked for %d to run.", v);
return 0L;
label:
v = v cmp 1000000L;
if v <= 0 goto label;
v = <nl.basjes.parse.useragent.AnalyzerPreHeater: org.apache.logging.log4j.Logger LOG>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(1000000L);
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("NO PREHEAT WAS DONE. Simply because you asked for too many (%d > %d) to run.", v, v);
return 0L;
label:
if v == 0 goto label;
v = <nl.basjes.parse.useragent.AnalyzerPreHeater: org.apache.logging.log4j.Logger LOG>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
interfaceinvoke v.<org.apache.logging.log4j.Logger: void info(java.lang.String,java.lang.Object)>("Preheating JVM by running %d testcases.", v);
label:
v = v;
v = 0L;
v = staticinvoke <java.lang.System: long nanoTime()>();
label:
v = v cmp 0L;
if v <= 0 goto label;
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 - 1L;
v = virtualinvoke v.<nl.basjes.parse.useragent.config.TestCase: java.util.Map getHeaders()>();
v = interfaceinvoke v.<nl.basjes.parse.useragent.AnalyzerPreHeater: nl.basjes.parse.useragent.UserAgent$ImmutableUserAgent parse(java.util.Map)>(v);
v = virtualinvoke v.<nl.basjes.parse.useragent.UserAgent$ImmutableUserAgent: boolean hasSyntaxError()>();
if v == 0 goto label;
v = v + 1L;
label:
v = v cmp 0L;
if v <= 0 goto label;
goto label;
label:
v = staticinvoke <java.lang.System: long nanoTime()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.AnalyzerPreHeater: org.apache.logging.log4j.Logger LOG>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = v - v;
v = v / 1000000L;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = v - v;
v = v / 1000000.0;
v = v / v;
v = staticinvoke <java.lang.Double: java.lang.Double valueOf(double)>(v);
interfaceinvoke v.<org.apache.logging.log4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object,java.lang.Object)>("Preheating JVM completed. Parsing %d testcases took %d ms (average %6.6f ms)", v, v, v);
v = <nl.basjes.parse.useragent.AnalyzerPreHeater: org.apache.logging.log4j.Logger LOG>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object)>("Of those %d had a Syntax Error", v);
label:
return v;
}
static void <clinit>()
{
org.apache.logging.log4j.Logger v;
v = staticinvoke <org.apache.logging.log4j.LogManager: org.apache.logging.log4j.Logger getFormatterLogger(java.lang.Class)>(class "Lnl/basjes/parse/useragent/AnalyzerPreHeater;");
<nl.basjes.parse.useragent.AnalyzerPreHeater: org.apache.logging.log4j.Logger LOG> = v;
return;
}
}