class org.glassfish.web.loader.JarFileManager extends java.lang.Object implements java.io.Closeable
{
private static final int SECONDS_TO_CLOSE_UNUSED_JARS;
private static final int SECONDS_TO_CHECK_UNUSED_JARS;
private static final java.lang.System$Logger LOG;
private final java.util.List files;
private final java.util.concurrent.ScheduledExecutorService scheduler;
private final java.util.concurrent.locks.ReadWriteLock lock;
private volatile long lastJarFileAccess;
private java.util.concurrent.ScheduledFuture unusedJarsCheck;
private volatile boolean resourcesExtracted;
void <init>()
{
java.util.concurrent.ScheduledExecutorService v;
org.glassfish.web.loader.JarFileManager v;
org.glassfish.web.loader.JarFileManager$JarFileManagerThreadFactory v;
java.util.concurrent.locks.ReentrantReadWriteLock v;
java.util.ArrayList v;
v := @this: org.glassfish.web.loader.JarFileManager;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v.<org.glassfish.web.loader.JarFileManager: java.util.List files> = v;
v = new org.glassfish.web.loader.JarFileManager$JarFileManagerThreadFactory;
specialinvoke v.<org.glassfish.web.loader.JarFileManager$JarFileManagerThreadFactory: void <init>()>();
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ScheduledExecutorService newScheduledThreadPool(int,java.util.concurrent.ThreadFactory)>(1, v);
v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.ScheduledExecutorService scheduler> = v;
v = new java.util.concurrent.locks.ReentrantReadWriteLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantReadWriteLock: void <init>()>();
v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.locks.ReadWriteLock lock> = v;
return;
}
void addJarFile(java.io.File)
{
java.lang.Throwable v;
java.util.List v;
java.util.concurrent.locks.Lock v;
org.glassfish.web.loader.JarFileManager v;
org.glassfish.web.loader.JarFileManager$JarResource v;
java.io.File v;
java.util.concurrent.locks.ReadWriteLock v;
v := @this: org.glassfish.web.loader.JarFileManager;
v := @parameter: java.io.File;
v = v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock writeLock()>();
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
v = v.<org.glassfish.web.loader.JarFileManager: java.util.List files>;
v = new org.glassfish.web.loader.JarFileManager$JarResource;
specialinvoke v.<org.glassfish.web.loader.JarFileManager$JarResource: void <init>(java.io.File)>(v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
java.util.jar.JarFile[] getJarFiles()
{
java.lang.Throwable v;
java.lang.Object[] v;
org.glassfish.web.loader.JarFileManager v;
long v;
java.util.function.Function v;
java.util.List v;
java.util.concurrent.locks.Lock v;
java.util.stream.Stream v, v;
java.util.concurrent.locks.ReadWriteLock v;
boolean v, v;
java.util.function.IntFunction v;
v := @this: org.glassfish.web.loader.JarFileManager;
v = specialinvoke v.<org.glassfish.web.loader.JarFileManager: boolean isJarsOpen()>();
if v != 0 goto label;
v = specialinvoke v.<org.glassfish.web.loader.JarFileManager: boolean openJARs()>();
if v != 0 goto label;
return null;
label:
v = v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock readLock()>();
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v.<org.glassfish.web.loader.JarFileManager: long lastJarFileAccess> = v;
v = v.<org.glassfish.web.loader.JarFileManager: java.util.List files>;
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = staticinvoke <org.glassfish.web.loader.JarFileManager$lambda_getJarFiles_0__1: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream map(java.util.function.Function)>(v);
v = staticinvoke <org.glassfish.web.loader.JarFileManager$lambda_getJarFiles_1__2: java.util.function.IntFunction bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object[] toArray(java.util.function.IntFunction)>(v);
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return v;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
java.io.File[] getJarRealFiles()
{
java.lang.Throwable v;
java.lang.Object[] v;
org.glassfish.web.loader.JarFileManager v;
java.util.function.Function v;
java.util.List v;
java.util.concurrent.locks.Lock v;
java.util.stream.Stream v, v;
java.util.concurrent.locks.ReadWriteLock v;
java.util.function.IntFunction v;
v := @this: org.glassfish.web.loader.JarFileManager;
v = v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock readLock()>();
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
v = v.<org.glassfish.web.loader.JarFileManager: java.util.List files>;
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = staticinvoke <org.glassfish.web.loader.JarFileManager$lambda_getJarRealFiles_2__3: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream map(java.util.function.Function)>(v);
v = staticinvoke <org.glassfish.web.loader.JarFileManager$lambda_getJarRealFiles_3__4: java.util.function.IntFunction bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object[] toArray(java.util.function.IntFunction)>(v);
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return v;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
catch java.lang.Throwable from label to label with label;
}
org.glassfish.web.loader.ResourceEntry findResource(java.lang.String, java.lang.String, java.io.File, boolean)
{
java.lang.Throwable v;
java.lang.Object[] v;
org.glassfish.web.loader.JarFileManager v;
java.util.jar.JarFile v;
long v;
org.glassfish.web.loader.ResourceEntry v;
java.lang.System$Logger$Level v;
java.util.jar.JarEntry v;
java.lang.Boolean v;
java.lang.String v, v, v;
java.util.concurrent.locks.ReadWriteLock v;
boolean v, v, v, v, v, v, v;
java.lang.System$Logger v;
java.util.Iterator v;
java.io.File v, v, v;
java.util.List v;
java.util.concurrent.locks.Lock v;
java.lang.Object v;
v := @this: org.glassfish.web.loader.JarFileManager;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.io.File;
v := @parameter: boolean;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level TRACE>;
v = newarray (java.lang.Object)[4];
v[0] = v;
v[1] = v;
v[2] = v;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
v[3] = v;
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Object[])>(v, "findResource(name={0}, path={1}, loaderDir={2}, antiJARLocking={3})", v);
v = specialinvoke v.<org.glassfish.web.loader.JarFileManager: boolean isJarsOpen()>();
if v != 0 goto label;
v = specialinvoke v.<org.glassfish.web.loader.JarFileManager: boolean openJARs()>();
if v != 0 goto label;
return null;
label:
v = v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock readLock()>();
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v.<org.glassfish.web.loader.JarFileManager: long lastJarFileAccess> = v;
v = v.<org.glassfish.web.loader.JarFileManager: java.util.List files>;
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.glassfish.web.loader.JarFileManager$JarResource: java.util.jar.JarFile jarFile>;
v = virtualinvoke v.<java.util.jar.JarFile: java.util.jar.JarEntry getJarEntry(java.lang.String)>(v);
if v == null goto label;
v = v.<org.glassfish.web.loader.JarFileManager$JarResource: java.io.File file>;
v = specialinvoke v.<org.glassfish.web.loader.JarFileManager: org.glassfish.web.loader.ResourceEntry createResourceEntry(java.lang.String,java.io.File,java.util.jar.JarFile,java.util.jar.JarEntry,java.lang.String)>(v, v, v, v, v);
if v != null goto label;
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return null;
label:
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>(".class");
if v != 0 goto label;
v = new java.io.File;
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
v = v.<org.glassfish.web.loader.JarFileManager: boolean resourcesExtracted>;
if v != 0 goto label;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
virtualinvoke v.<org.glassfish.web.loader.JarFileManager: void extractResources(java.io.File,java.lang.String)>(v, v);
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return v;
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
label:
return null;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
void extractResources(java.io.File, java.lang.String)
{
java.lang.Throwable v;
java.lang.System$Logger v;
java.lang.Object[] v;
java.util.Iterator v;
org.glassfish.web.loader.JarFileManager v;
java.util.jar.JarFile v;
java.io.File v;
java.lang.System$Logger$Level v;
java.util.List v;
java.util.concurrent.locks.Lock v;
java.lang.Object v;
java.lang.String v;
java.util.concurrent.locks.ReadWriteLock v;
boolean v, v;
v := @this: org.glassfish.web.loader.JarFileManager;
v := @parameter: java.io.File;
v := @parameter: java.lang.String;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Object[])>(v, "extractResources(loaderDir={0}, canonicalLoaderDir={1})", v);
v = v.<org.glassfish.web.loader.JarFileManager: boolean resourcesExtracted>;
if v == 0 goto label;
return;
label:
v = v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock readLock()>();
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
v = v.<org.glassfish.web.loader.JarFileManager: java.util.List files>;
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.glassfish.web.loader.JarFileManager$JarResource: java.util.jar.JarFile jarFile>;
staticinvoke <org.glassfish.web.loader.JarFileManager: void extractResource(java.util.jar.JarFile,java.io.File,java.lang.String)>(v, v, v);
goto label;
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
label:
v.<org.glassfish.web.loader.JarFileManager: boolean resourcesExtracted> = 1;
return;
catch java.lang.Throwable from label to label with label;
}
void closeJarFiles()
{
java.lang.Throwable v;
java.lang.System$Logger v;
java.util.concurrent.ScheduledFuture v, v;
org.glassfish.web.loader.JarFileManager v;
java.lang.System$Logger$Level v;
java.util.List v;
java.util.concurrent.locks.Lock v;
java.util.concurrent.locks.ReadWriteLock v;
v := @this: org.glassfish.web.loader.JarFileManager;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String)>(v, "closeJarFiles()");
v = v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock writeLock()>();
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
v.<org.glassfish.web.loader.JarFileManager: long lastJarFileAccess> = 0L;
v = v.<org.glassfish.web.loader.JarFileManager: java.util.List files>;
staticinvoke <org.glassfish.web.loader.JarFileManager: void closeJarFiles(java.util.List)>(v);
label:
v = v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.ScheduledFuture unusedJarsCheck>;
interfaceinvoke v.<java.util.concurrent.ScheduledFuture: boolean cancel(boolean)>(0);
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.ScheduledFuture unusedJarsCheck>;
interfaceinvoke v.<java.util.concurrent.ScheduledFuture: boolean cancel(boolean)>(0);
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void close() throws java.io.IOException
{
java.util.concurrent.ScheduledExecutorService v;
org.glassfish.web.loader.JarFileManager v;
v := @this: org.glassfish.web.loader.JarFileManager;
virtualinvoke v.<org.glassfish.web.loader.JarFileManager: void closeJarFiles()>();
v = v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.ScheduledExecutorService scheduler>;
interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: void shutdown()>();
return;
}
private boolean openJARs()
{
java.lang.Throwable v;
java.lang.Object[] v;
java.util.concurrent.ScheduledFuture v;
org.glassfish.web.loader.JarFileManager v;
java.util.jar.JarFile v, v;
long v;
java.lang.Integer v;
java.lang.Runnable v;
java.lang.System$Logger$Level v, v, v;
int v, v, v;
java.util.concurrent.ScheduledExecutorService v;
java.util.concurrent.locks.ReadWriteLock v;
boolean v, v;
java.lang.System$Logger v, v, v;
java.util.Iterator v;
java.io.IOException v;
java.io.File v;
java.util.concurrent.TimeUnit v;
java.util.List v, v;
java.util.concurrent.locks.Lock v;
java.lang.Object v;
v := @this: org.glassfish.web.loader.JarFileManager;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String)>(v, "openJARs()");
v = v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.locks.ReadWriteLock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.ReadWriteLock: java.util.concurrent.locks.Lock writeLock()>();
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
v = specialinvoke v.<org.glassfish.web.loader.JarFileManager: boolean isJarsOpen()>();
if v == 0 goto label;
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return 1;
label:
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v.<org.glassfish.web.loader.JarFileManager: long lastJarFileAccess> = v;
v = v.<org.glassfish.web.loader.JarFileManager: java.util.List files>;
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.glassfish.web.loader.JarFileManager$JarResource: java.util.jar.JarFile jarFile>;
if v != null goto label;
label:
v = new java.util.jar.JarFile;
v = v.<org.glassfish.web.loader.JarFileManager$JarResource: java.io.File file>;
specialinvoke v.<java.util.jar.JarFile: void <init>(java.io.File)>(v);
v.<org.glassfish.web.loader.JarFileManager$JarResource: java.util.jar.JarFile jarFile> = v;
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Throwable)>(v, "Failed to open JAR", v);
v.<org.glassfish.web.loader.JarFileManager: long lastJarFileAccess> = 0L;
v = v.<org.glassfish.web.loader.JarFileManager: java.util.List files>;
staticinvoke <org.glassfish.web.loader.JarFileManager: void closeJarFiles(java.util.List)>(v);
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return 0;
label:
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
v = newarray (java.lang.Object)[1];
v = <org.glassfish.web.loader.JarFileManager: int SECONDS_TO_CLOSE_UNUSED_JARS>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Object[])>(v, "JAR files are open. If unused, will be closed after {0} s", v);
v = v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.ScheduledExecutorService scheduler>;
v = staticinvoke <org.glassfish.web.loader.JarFileManager$closeJarFilesIfNotUsed__5: java.lang.Runnable bootstrap$(org.glassfish.web.loader.JarFileManager)>(v);
v = <org.glassfish.web.loader.JarFileManager: int SECONDS_TO_CHECK_UNUSED_JARS>;
v = <org.glassfish.web.loader.JarFileManager: int SECONDS_TO_CHECK_UNUSED_JARS>;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
v = interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.ScheduledFuture scheduleAtFixedRate(java.lang.Runnable,long,long,java.util.concurrent.TimeUnit)>(v, v, v, v);
v.<org.glassfish.web.loader.JarFileManager: java.util.concurrent.ScheduledFuture unusedJarsCheck> = v;
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return 1;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
catch java.io.IOException 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;
catch java.lang.Throwable from label to label with label;
}
private boolean isJarsOpen()
{
byte v;
org.glassfish.web.loader.JarFileManager v;
long v;
boolean v;
v := @this: org.glassfish.web.loader.JarFileManager;
v = v.<org.glassfish.web.loader.JarFileManager: long lastJarFileAccess>;
v = v cmp 0L;
if v <= 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private org.glassfish.web.loader.ResourceEntry createResourceEntry(java.lang.String, java.io.File, java.util.jar.JarFile, java.util.jar.JarEntry, java.lang.String)
{
java.util.jar.Manifest v;
java.net.URL v, v;
org.glassfish.web.loader.JarFileManager v;
java.util.jar.JarFile v;
java.lang.System$Logger$Level v, v, v, v;
java.net.URI v;
java.lang.Throwable v;
long v, v;
org.glassfish.web.loader.ResourceEntry v;
java.util.jar.JarEntry v;
java.lang.String v, v, v, v, v, v, v, v;
java.lang.System$Logger v, v, v, v;
java.net.MalformedURLException v;
java.io.IOException v, v, v;
java.io.File v, v;
java.io.InputStream v;
v := @this: org.glassfish.web.loader.JarFileManager;
v := @parameter: java.lang.String;
v := @parameter: java.io.File;
v := @parameter: java.util.jar.JarFile;
v := @parameter: java.util.jar.JarEntry;
v := @parameter: java.lang.String;
label:
v = virtualinvoke v.<java.io.File: java.io.File getCanonicalFile()>();
v = virtualinvoke v.<java.io.File: java.net.URI toURI()>();
v = virtualinvoke v.<java.net.URI: java.net.URL toURL()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("Invalid file: \u0001");
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Throwable)>(v, v, v);
return null;
label:
v = new java.net.URL;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.URL,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[])>("jar:\u0001!/\u0001");
specialinvoke v.<java.net.URL: void <init>(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File,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[])>("Cannot create valid URL of file \u and entry path \u0001");
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Throwable)>(v, v, v);
return null;
label:
v = new org.glassfish.web.loader.ResourceEntry;
specialinvoke v.<org.glassfish.web.loader.ResourceEntry: void <init>(java.net.URL,java.net.URL)>(v, v);
label:
v = virtualinvoke v.<java.util.jar.JarFile: java.util.jar.Manifest getManifest()>();
v.<org.glassfish.web.loader.ResourceEntry: java.util.jar.Manifest manifest> = v;
label:
goto label;
label:
v := @caughtexception;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
v = virtualinvoke v.<java.util.jar.JarFile: java.lang.String getName()>();
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[])>("Failed to get manifest from \u0001");
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Throwable)>(v, v, v);
return null;
label:
v = virtualinvoke v.<java.io.File: long lastModified()>();
v.<org.glassfish.web.loader.ResourceEntry: long lastModified> = v;
v = virtualinvoke v.<java.util.jar.JarEntry: long getSize()>();
label:
v = virtualinvoke v.<java.util.jar.JarFile: java.io.InputStream getInputStream(java.util.zip.ZipEntry)>(v);
label:
if v == null goto label;
virtualinvoke v.<org.glassfish.web.loader.ResourceEntry: void readEntryData(java.lang.String,java.io.InputStream,int,java.util.jar.JarEntry)>(v, v, v, v);
label:
if v == null goto label;
virtualinvoke v.<java.io.InputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
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[])>("Failed to read entry data for \u0001");
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Throwable)>(v, v, v);
return null;
label:
return v;
catch java.io.IOException from label to label with label;
catch java.net.MalformedURLException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
}
private static void extractResource(java.util.jar.JarFile, java.io.File, java.lang.String)
{
java.util.Enumeration v;
java.util.jar.JarFile v;
java.lang.System$Logger$Level v, v, v;
boolean v, v, v, v, v;
java.lang.Throwable v, v;
java.lang.Object[] v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v;
java.lang.System$Logger v, v, v;
java.io.FileOutputStream v;
java.io.IOException v, v;
java.lang.IllegalArgumentException v, v;
java.io.File v, v, v, v;
java.lang.Object v;
java.io.InputStream v;
v := @parameter: java.util.jar.JarFile;
v := @parameter: java.io.File;
v := @parameter: java.lang.String;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
v = newarray (java.lang.Object)[3];
v[0] = v;
v[1] = v;
v[2] = v;
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Object[])>(v, "extractResource(jarFile={0}, loaderDir={1}, pathPrefix={2})", v);
v = virtualinvoke v.<java.util.jar.JarFile: java.util.Enumeration entries()>();
label:
v = interfaceinvoke v.<java.util.Enumeration: boolean hasMoreElements()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Enumeration: java.lang.Object nextElement()>();
v = virtualinvoke v.<java.util.jar.JarEntry: boolean isDirectory()>();
if v != 0 goto label;
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>(".class");
if v != 0 goto label;
v = new java.io.File;
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
label:
v = virtualinvoke v.<java.io.File: java.lang.String getCanonicalPath()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>(v);
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
v = newarray (java.lang.Object)[1];
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
v[0] = v;
v = staticinvoke <org.glassfish.web.loader.LogFacade: java.lang.String getString(java.lang.String,java.lang.Object[])>("AS-WEB-UTIL-00021", v);
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v := @caughtexception;
v = new java.lang.IllegalArgumentException;
v = newarray (java.lang.Object)[1];
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
v[0] = v;
v = staticinvoke <org.glassfish.web.loader.LogFacade: java.lang.String getString(java.lang.String,java.lang.Object[])>("AS-WEB-UTIL-00022", v);
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v = virtualinvoke v.<java.io.File: java.io.File getParentFile()>();
v = staticinvoke <com.sun.enterprise.util.io.FileUtils: boolean mkdirsMaybe(java.io.File)>(v);
if v != 0 goto label;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level WARNING>;
v = newarray (java.lang.Object)[1];
v = virtualinvoke v.<java.io.File: java.io.File getParentFile()>();
v[0] = v;
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Object[])>(v, "AS-WEB-UTIL-00023", v);
label:
v = virtualinvoke v.<java.util.jar.JarFile: java.io.InputStream getInputStream(java.util.zip.ZipEntry)>(v);
label:
v = new java.io.FileOutputStream;
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File)>(v);
label:
staticinvoke <com.sun.enterprise.util.io.FileUtils: void copy(java.io.InputStream,java.io.FileOutputStream,long)>(v, v, 9223372036854775807L);
label:
virtualinvoke v.<java.io.FileOutputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
if v == null goto label;
virtualinvoke v.<java.io.InputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.util.jar.JarEntry)>(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[])>("Failed to copy entry \u0001");
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Throwable)>(v, v, v);
goto label;
label:
return;
catch java.io.IOException 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;
catch java.io.IOException from label to label with label;
}
public void closeJarFilesIfNotUsed()
{
java.lang.System$Logger v;
java.lang.Object[] v;
org.glassfish.web.loader.JarFileManager v;
long v, v, v, v;
java.lang.System$Logger$Level v;
byte v;
java.lang.Long v;
int v;
boolean v;
v := @this: org.glassfish.web.loader.JarFileManager;
v = specialinvoke v.<org.glassfish.web.loader.JarFileManager: boolean isJarsOpen()>();
if v != 0 goto label;
return;
label:
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v.<org.glassfish.web.loader.JarFileManager: long lastJarFileAccess>;
v = v - v;
v = v / 1000L;
v = <org.glassfish.web.loader.JarFileManager: int SECONDS_TO_CLOSE_UNUSED_JARS>;
v = v cmp v;
if v > 0 goto label;
return;
label:
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
v = newarray (java.lang.Object)[1];
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[0] = v;
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String,java.lang.Object[])>(v, "Closing jar files, because they were not used for {0} s.", v);
virtualinvoke v.<org.glassfish.web.loader.JarFileManager: void closeJarFiles()>();
return;
}
private static void closeJarFiles(java.util.List)
{
java.lang.System$Logger v;
java.util.Iterator v;
java.util.jar.JarFile v, v;
java.lang.System$Logger$Level v;
java.util.List v;
java.lang.Object v;
boolean v;
v := @parameter: java.util.List;
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.glassfish.web.loader.JarFileManager$JarResource: java.util.jar.JarFile jarFile>;
if v == null goto label;
v = v.<org.glassfish.web.loader.JarFileManager$JarResource: java.util.jar.JarFile jarFile>;
v.<org.glassfish.web.loader.JarFileManager$JarResource: java.util.jar.JarFile jarFile> = null;
staticinvoke <org.glassfish.web.loader.JarFileManager: void closeJarFile(java.util.jar.JarFile)>(v);
goto label;
label:
v = <org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG>;
v = <java.lang.System$Logger$Level: java.lang.System$Logger$Level DEBUG>;
interfaceinvoke v.<java.lang.System$Logger: void log(java.lang.System$Logger$Level,java.lang.String)>(v, "JAR files were closed.");
return;
}
private static void closeJarFile(java.util.jar.JarFile)
{
java.util.jar.JarFile v;
v := @parameter: java.util.jar.JarFile;
return;
}
static void <clinit>()
{
java.lang.System$Logger v;
int v, v;
java.lang.Class v;
java.lang.String v;
java.lang.Integer v, v;
v = staticinvoke <java.lang.Integer: java.lang.Integer getInteger(java.lang.String,int)>("org.glassfish.web.loader.unusedJars.secondsToClose", 60);
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
<org.glassfish.web.loader.JarFileManager: int SECONDS_TO_CLOSE_UNUSED_JARS> = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer getInteger(java.lang.String,int)>("org.glassfish.web.loader.unusedJars.secondsToRunCheck", 15);
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
<org.glassfish.web.loader.JarFileManager: int SECONDS_TO_CHECK_UNUSED_JARS> = v;
v = class "Lorg/glassfish/web/loader/JarFileManager;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <java.lang.System: java.lang.System$Logger getLogger(java.lang.String)>(v);
<org.glassfish.web.loader.JarFileManager: java.lang.System$Logger LOG> = v;
return;
}
}