public class org.glassfish.hk.classmodel.reflect.Parser extends java.lang.Object implements java.io.Closeable
{
public static final java.lang.String DEFAULT_WAIT_SYSPROP;
private final org.glassfish.hk.classmodel.reflect.ParsingContext context;
private final java.util.Map processedURI;
private final java.util.Stack futures;
private final java.util.concurrent.ExecutorService executorService;
private final boolean ownES;
private final java.util.concurrent.locks.ReadWriteLock lock;
private final int DEFAULT_TIMEOUT;
public void <init>(org.glassfish.hk.classmodel.reflect.ParsingContext)
{
java.util.HashMap v;
java.util.concurrent.locks.ReentrantReadWriteLock v;
java.lang.Integer v;
java.util.Stack v;
org.glassfish.hk.classmodel.reflect.Parser v;
java.util.Map v;
int v;
java.util.concurrent.ExecutorService v, v, v;
org.glassfish.hk.classmodel.reflect.ParsingContext v;
boolean v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v := @parameter: org.glassfish.hk.classmodel.reflect.ParsingContext;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = staticinvoke <java.util.Collections: java.util.Map synchronizedMap(java.util.Map)>(v);
v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.Map processedURI> = v;
v = new java.util.Stack;
specialinvoke v.<java.util.Stack: void <init>()>();
v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.Stack futures> = v;
v = new java.util.concurrent.locks.ReentrantReadWriteLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: void <init>()>();
v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.locks.ReadWriteLock lock> = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer getInteger(java.lang.String,int)>("hk.parser.timeout", 100);
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v.<org.glassfish.hk.classmodel.reflect.Parser: int DEFAULT_TIMEOUT> = v;
v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context> = v;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.concurrent.ExecutorService executorService>;
if v != null goto label;
v = specialinvoke v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.ExecutorService createExecutorService()>();
goto label;
label:
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.concurrent.ExecutorService executorService>;
label:
v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.ExecutorService executorService> = v;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.concurrent.ExecutorService executorService>;
if v != null goto label;
v = 1;
goto label;
label:
v = 0;
label:
v.<org.glassfish.hk.classmodel.reflect.Parser: boolean ownES> = v;
return;
}
public java.lang.Exception[] awaitTermination() throws java.lang.InterruptedException
{
java.util.concurrent.TimeUnit v;
int v;
java.lang.Exception[] v;
org.glassfish.hk.classmodel.reflect.Parser v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: int DEFAULT_TIMEOUT>;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
v = virtualinvoke v.<org.glassfish.hk.classmodel.reflect.Parser: java.lang.Exception[] awaitTermination(int,java.util.concurrent.TimeUnit)>(v, v);
return v;
}
public java.lang.Exception[] awaitTermination(int, java.util.concurrent.TimeUnit) throws java.lang.InterruptedException
{
java.util.concurrent.locks.ReadWriteLock v, v, v;
org.glassfish.hk.classmodel.reflect.impl.TypesCtr v, v;
java.lang.Exception v, v, v;
org.glassfish.hk.classmodel.reflect.Parser$1 v;
java.lang.Exception[] v;
java.lang.Throwable v, v;
java.lang.Object[] v;
long v, v;
java.util.ArrayList v;
java.lang.String v, v, v;
java.util.EmptyStackException v;
org.glassfish.hk.classmodel.reflect.Parser v;
java.util.concurrent.ExecutionException v;
java.util.concurrent.locks.Lock v, v, v;
org.glassfish.hk.classmodel.reflect.util.ResourceLocator v;
java.util.concurrent.TimeoutException v;
boolean v, v;
java.util.logging.Logger v, v, v, v, v, v, v, v;
java.util.Stack v, v, v, v;
java.util.logging.Level v, v, v, v, v, v;
int v, v, v, v;
java.util.concurrent.TimeUnit v;
java.lang.Object v, v;
org.glassfish.hk.classmodel.reflect.ParsingContext v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v := @parameter: int;
v := @parameter: java.util.concurrent.TimeUnit;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.logging.Logger logger>;
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.Stack futures>;
v = virtualinvoke v.<java.util.Stack: int size()>();
if v <= 0 goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.Stack futures>;
v = virtualinvoke v.<java.util.Stack: int size()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long,int)>(v, 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[])>("Await iterating at \u waiting for \u0001");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.Stack futures>;
entermonitor v;
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.Stack futures>;
v = virtualinvoke v.<java.util.Stack: java.lang.Object pop()>();
label:
goto label;
label:
v := @caughtexception;
v = null;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v == null goto label;
label:
v = interfaceinvoke v.<java.util.concurrent.Future: java.lang.Object get(long,java.util.concurrent.TimeUnit)>(v, v);
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v.<org.glassfish.hk.classmodel.reflect.Parser$Result: java.lang.String name>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long,java.lang.String)>(v, 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[])>("future finished at \u for \u0001");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level FINER>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "result {0}", v);
if v == null goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser$Result: java.lang.Exception fault>;
if v == null goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.logging.Logger logger>;
v = <java.util.logging.Level: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "result fault {0}", v);
label:
if v == null goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser$Result: java.lang.Exception fault>;
if v == null goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser$Result: java.lang.Exception fault>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
goto label;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock writeLock()>();
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = virtualinvoke v.<org.glassfish.hk.classmodel.reflect.ParsingContext: org.glassfish.hk.classmodel.reflect.util.ResourceLocator getLocator()>();
if v == null goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.logging.Logger logger>;
virtualinvoke v.<java.util.logging.Logger: void fine(java.lang.String)>("Visiting unvisited references ...");
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: org.glassfish.hk.classmodel.reflect.impl.TypesCtr types>;
v = new org.glassfish.hk.classmodel.reflect.Parser$1;
specialinvoke v.<org.glassfish.hk.classmodel.reflect.Parser$1: void <init>(org.glassfish.hk.classmodel.reflect.Parser,org.glassfish.hk.classmodel.reflect.util.ResourceLocator,java.util.logging.Logger)>(v, v, v);
virtualinvoke v.<org.glassfish.hk.classmodel.reflect.impl.TypesCtr: void onNotVisitedEntries(org.glassfish.hk.classmodel.reflect.impl.TypesCtr$ProxyTask)>(v);
goto label;
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: org.glassfish.hk.classmodel.reflect.impl.TypesCtr types>;
virtualinvoke v.<org.glassfish.hk.classmodel.reflect.impl.TypesCtr: void clearNonVisitedEntries()>();
label:
virtualinvoke v.<org.glassfish.hk.classmodel.reflect.Parser: void close()>();
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.lang.Exception)[v];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock writeLock()>();
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock writeLock()>();
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
catch java.util.EmptyStackException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.util.concurrent.TimeoutException from label to label with label;
catch java.util.concurrent.ExecutionException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private static java.net.URI getDefiningURI(java.io.File)
{
java.io.IOException v;
java.lang.RuntimeException v;
java.net.URI v;
java.io.File v, v;
v := @parameter: java.io.File;
label:
v = virtualinvoke v.<java.io.File: java.io.File getCanonicalFile()>();
v = virtualinvoke v.<java.io.File: java.net.URI toURI()>();
label:
return v;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.io.IOException from label to label with label;
}
private static java.io.File getFilePath(java.lang.String, java.lang.String)
{
java.io.File v;
int v, v, v, v, v, v;
java.lang.String v, v, v;
boolean v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: int length()>();
v = v - v;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(0, v);
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>("!/");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = v - 2;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(0, v);
label:
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("file:/");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(6, v);
label:
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
return v;
}
public void close()
{
java.util.concurrent.ExecutorService v, v;
boolean v;
org.glassfish.hk.classmodel.reflect.Parser v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.ExecutorService executorService>;
if v == null goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: boolean ownES>;
if v == 0 goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.ExecutorService executorService>;
interfaceinvoke v.<java.util.concurrent.ExecutorService: void shutdown()>();
label:
return;
}
public void parse(java.io.File, java.lang.Runnable) throws java.io.IOException
{
org.glassfish.hk.classmodel.reflect.ArchiveAdapter v;
org.glassfish.hk.classmodel.reflect.Parser$2 v;
java.lang.Runnable v;
java.io.File v;
org.glassfish.hk.classmodel.reflect.Parser v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v := @parameter: java.io.File;
v := @parameter: java.lang.Runnable;
v = specialinvoke v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ArchiveAdapter createArchiveAdapter(java.io.File,java.lang.Runnable)>(v, v);
v = new org.glassfish.hk.classmodel.reflect.Parser$2;
specialinvoke v.<org.glassfish.hk.classmodel.reflect.Parser$2: void <init>(org.glassfish.hk.classmodel.reflect.Parser,org.glassfish.hk.classmodel.reflect.ArchiveAdapter,java.lang.Runnable)>(v, v, v);
virtualinvoke v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.Future parse(org.glassfish.hk.classmodel.reflect.ArchiveAdapter,java.lang.Runnable)>(v, v);
return;
}
private org.glassfish.hk.classmodel.reflect.ArchiveAdapter createArchiveAdapter(java.io.File, java.lang.Runnable) throws java.io.IOException
{
org.glassfish.hk.classmodel.reflect.util.JarArchive v;
java.io.IOException v;
java.lang.Runnable v;
java.io.File v;
org.glassfish.hk.classmodel.reflect.Parser v;
org.glassfish.hk.classmodel.reflect.util.DirectoryArchive v;
org.glassfish.hk.classmodel.reflect.util.AbstractAdapter v;
java.net.URI v;
boolean v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v := @parameter: java.io.File;
v := @parameter: java.lang.Runnable;
label:
v = virtualinvoke v.<java.io.File: boolean isFile()>();
if v == 0 goto label;
v = new org.glassfish.hk.classmodel.reflect.util.JarArchive;
v = v;
v = virtualinvoke v.<java.io.File: java.net.URI toURI()>();
specialinvoke v.<org.glassfish.hk.classmodel.reflect.util.JarArchive: void <init>(org.glassfish.hk.classmodel.reflect.Parser,java.net.URI)>(v, v);
goto label;
label:
v = new org.glassfish.hk.classmodel.reflect.util.DirectoryArchive;
v = v;
specialinvoke v.<org.glassfish.hk.classmodel.reflect.util.DirectoryArchive: void <init>(org.glassfish.hk.classmodel.reflect.Parser,java.io.File)>(v, v);
label:
return v;
label:
v := @caughtexception;
if v == null goto label;
interfaceinvoke v.<java.lang.Runnable: void run()>();
label:
throw v;
catch java.io.IOException from label to label with label;
}
public java.util.concurrent.Future parse(org.glassfish.hk.classmodel.reflect.ArchiveAdapter, java.lang.Runnable) throws java.io.IOException
{
java.lang.Runnable v;
java.util.concurrent.Future v;
java.net.URI v, v, v, v;
org.glassfish.hk.classmodel.reflect.ArchiveAdapter v;
java.util.concurrent.locks.ReadWriteLock v, v, v, v;
boolean v, v, v, v;
java.util.logging.Logger v, v;
org.glassfish.hk.classmodel.reflect.Parser$3 v;
java.lang.Throwable v, v;
long v;
java.util.Stack v, v;
java.util.logging.Level v, v, v, v;
java.lang.String v, v, v, v, v;
java.util.concurrent.ExecutorService v;
org.glassfish.hk.classmodel.reflect.Types v;
org.glassfish.hk.classmodel.reflect.Parser v;
java.util.concurrent.locks.Lock v, v, v, v;
org.glassfish.hk.classmodel.reflect.ParsingContext v, v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v := @parameter: org.glassfish.hk.classmodel.reflect.ArchiveAdapter;
v := @parameter: java.lang.Runnable;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock readLock()>();
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.ExecutorService executorService>;
v = 0;
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean isShutdown()>();
if v == 0 goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.logging.Logger logger>;
virtualinvoke v.<java.util.logging.Logger: void info(java.lang.String)>("Executor service is shutdown, since awaitTermination was called, provide an executor service instance from the context to avoid automatic shutdown");
v = specialinvoke v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.ExecutorService createExecutorService()>();
v = 1;
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.logging.Logger logger>;
v = interfaceinvoke v.<org.glassfish.hk.classmodel.reflect.ArchiveAdapter: java.net.URI getURI()>();
v = specialinvoke v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.Types getResult(java.net.URI)>(v);
if v == null goto label;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<org.glassfish.hk.classmodel.reflect.ArchiveAdapter: java.net.URI getURI()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.URI)>(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[])>("Skipping reparsing...\u0001");
virtualinvoke v.<java.util.logging.Logger: void fine(java.lang.String)>(v);
label:
interfaceinvoke v.<java.lang.Runnable: void run()>();
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock readLock()>();
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return null;
label:
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = interfaceinvoke v.<org.glassfish.hk.classmodel.reflect.ArchiveAdapter: java.net.URI getURI()>();
v = virtualinvoke v.<java.net.URI: java.lang.String getPath()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long,org.glassfish.hk.classmodel.reflect.Parser,java.lang.String)>(v, v, 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[])>("at \u0001in \u submitting file \u0001");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = interfaceinvoke v.<org.glassfish.hk.classmodel.reflect.ArchiveAdapter: java.net.URI getURI()>();
v = virtualinvoke v.<java.net.URI: java.lang.String getPath()>();
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[])>("submitting file \u0001");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
label:
v = new org.glassfish.hk.classmodel.reflect.Parser$3;
specialinvoke v.<org.glassfish.hk.classmodel.reflect.Parser$3: void <init>(org.glassfish.hk.classmodel.reflect.Parser,java.util.logging.Logger,org.glassfish.hk.classmodel.reflect.ArchiveAdapter,java.lang.Runnable)>(v, v, v, v);
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: java.util.concurrent.Future submit(java.util.concurrent.Callable)>(v);
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.Stack futures>;
entermonitor v;
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.Stack futures>;
virtualinvoke v.<java.util.Stack: boolean add(java.lang.Object)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v == 0 goto label;
interfaceinvoke v.<java.util.concurrent.ExecutorService: void shutdown()>();
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock readLock()>();
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return v;
label:
v := @caughtexception;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock readLock()>();
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private synchronized org.glassfish.hk.classmodel.reflect.Types getResult(java.net.URI)
{
java.util.Map v;
java.lang.Object v;
java.lang.String v;
java.net.URI v;
org.glassfish.hk.classmodel.reflect.Parser v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v := @parameter: java.net.URI;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.Map processedURI>;
v = virtualinvoke v.<java.net.URI: java.lang.String getSchemeSpecificPart()>();
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
return v;
}
private synchronized void saveResult(java.net.URI, org.glassfish.hk.classmodel.reflect.Types)
{
java.util.Map v;
java.lang.String v;
java.net.URI v;
org.glassfish.hk.classmodel.reflect.Parser v;
org.glassfish.hk.classmodel.reflect.Types v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v := @parameter: java.net.URI;
v := @parameter: org.glassfish.hk.classmodel.reflect.Types;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: java.util.Map processedURI>;
v = virtualinvoke v.<java.net.URI: java.lang.String getPath()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
return;
}
private void doJob(org.glassfish.hk.classmodel.reflect.ArchiveAdapter, java.lang.Runnable) throws java.lang.Exception
{
java.lang.Runnable v;
java.lang.Thread v;
java.net.URI v, v, v, v, v;
org.glassfish.hk.classmodel.reflect.ArchiveAdapter v;
boolean v, v, v, v, v, v;
java.util.logging.Logger v;
org.glassfish.hk.classmodel.reflect.ArchiveSelector v, v;
org.glassfish.hk.classmodel.reflect.Parser$4 v;
org.glassfish.hk.classmodel.reflect.Parser$5 v;
long v, v, v, v;
java.util.logging.Level v, v, v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v;
org.glassfish.hk.classmodel.reflect.Types v;
org.glassfish.hk.classmodel.reflect.Parser v;
org.glassfish.hk.classmodel.reflect.ParsingContext v, v, v, v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v := @parameter: org.glassfish.hk.classmodel.reflect.ArchiveAdapter;
v := @parameter: java.lang.Runnable;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: java.util.logging.Logger logger>;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<org.glassfish.hk.classmodel.reflect.ArchiveAdapter: java.net.URI getURI()>();
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.URI,java.lang.String)>(v, 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[])>("Parsing \u on thread \u0001");
virtualinvoke v.<java.util.logging.Logger: void fine(java.lang.String)>(v);
label:
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: org.glassfish.hk.classmodel.reflect.ArchiveSelector archiveSelector>;
if v == null goto label;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = v.<org.glassfish.hk.classmodel.reflect.ParsingContext: org.glassfish.hk.classmodel.reflect.ArchiveSelector archiveSelector>;
v = interfaceinvoke v.<org.glassfish.hk.classmodel.reflect.ArchiveSelector: boolean selects(org.glassfish.hk.classmodel.reflect.ArchiveAdapter)>(v);
if v == 0 goto label;
label:
v = interfaceinvoke v.<org.glassfish.hk.classmodel.reflect.ArchiveAdapter: java.net.URI getURI()>();
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = virtualinvoke v.<java.net.URI: java.lang.String getPath()>();
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String,java.lang.Object)>(v, "Parsing file {0}", v);
label:
v = new org.glassfish.hk.classmodel.reflect.Parser$4;
specialinvoke v.<org.glassfish.hk.classmodel.reflect.Parser$4: void <init>(org.glassfish.hk.classmodel.reflect.Parser)>(v);
v = new org.glassfish.hk.classmodel.reflect.Parser$5;
specialinvoke v.<org.glassfish.hk.classmodel.reflect.Parser$5: void <init>(org.glassfish.hk.classmodel.reflect.Parser,java.util.logging.Logger,java.net.URI)>(v, v, v);
interfaceinvoke v.<org.glassfish.hk.classmodel.reflect.ArchiveAdapter: void onSelectedEntries(org.glassfish.hk.classmodel.reflect.ArchiveAdapter$Selector,org.glassfish.hk.classmodel.reflect.ArchiveAdapter$EntryTask,java.util.logging.Logger)>(v, v, v);
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
v = virtualinvoke v.<org.glassfish.hk.classmodel.reflect.ParsingContext: org.glassfish.hk.classmodel.reflect.Types getTypes()>();
specialinvoke v.<org.glassfish.hk.classmodel.reflect.Parser: void saveResult(java.net.URI,org.glassfish.hk.classmodel.reflect.Types)>(v, v);
label:
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = interfaceinvoke v.<org.glassfish.hk.classmodel.reflect.ArchiveAdapter: java.net.URI getURI()>();
v = virtualinvoke v.<java.net.URI: java.lang.String getPath()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,long,long)>(v, v, 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[])>("Finished parsing \u at \u in \u ms");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
label:
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = interfaceinvoke v.<org.glassfish.hk.classmodel.reflect.ArchiveAdapter: java.net.URI getURI()>();
v = virtualinvoke v.<java.net.URI: java.lang.String getPath()>();
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[])>("before running doneHook\u0001");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
label:
if v == null goto label;
interfaceinvoke v.<java.lang.Runnable: void run()>();
label:
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = <java.util.logging.Level: java.util.logging.Level FINE>;
v = interfaceinvoke v.<org.glassfish.hk.classmodel.reflect.ArchiveAdapter: java.net.URI getURI()>();
v = virtualinvoke v.<java.net.URI: java.lang.String getPath()>();
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[])>("after running doneHook \u0001");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
label:
return;
}
public org.glassfish.hk.classmodel.reflect.ParsingContext getContext()
{
org.glassfish.hk.classmodel.reflect.ParsingContext v;
org.glassfish.hk.classmodel.reflect.Parser v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v = v.<org.glassfish.hk.classmodel.reflect.Parser: org.glassfish.hk.classmodel.reflect.ParsingContext context>;
return v;
}
private java.util.concurrent.ExecutorService createExecutorService()
{
org.glassfish.hk.classmodel.reflect.Parser$6 v;
java.util.concurrent.ExecutorService v;
org.glassfish.hk.classmodel.reflect.Parser v;
v := @this: org.glassfish.hk.classmodel.reflect.Parser;
v = new org.glassfish.hk.classmodel.reflect.Parser$6;
specialinvoke v.<org.glassfish.hk.classmodel.reflect.Parser$6: void <init>(org.glassfish.hk.classmodel.reflect.Parser)>(v);
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ExecutorService newFixedThreadPool(int,java.util.concurrent.ThreadFactory)>(1, v);
return v;
}
}