public class org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl extends java.lang.Object implements org.apache.axiom.attachments.lifecycle.LifecycleManager
{
private static final org.apache.commons.logging.Log log;
private static java.util.Hashtable table;
private org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook hook;
public void <init>()
{
org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl v;
v := @this: org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook hook> = null;
return;
}
public org.apache.axiom.attachments.lifecycle.impl.FileAccessor create(java.lang.String) throws java.io.IOException
{
org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl v;
java.lang.String v, v, v, v;
org.apache.axiom.attachments.lifecycle.impl.FileAccessor v;
java.util.Hashtable v;
boolean v, v, v, v;
java.lang.IllegalArgumentException v;
java.io.File v, v, v;
org.apache.commons.logging.Log v, v, v, v;
v := @this: org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl;
v := @parameter: java.lang.String;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("Start Create()");
label:
v = null;
if v == null goto label;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = v;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
virtualinvoke v.<java.io.File: boolean mkdirs()>();
label:
v = virtualinvoke v.<java.io.File: boolean isDirectory()>();
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
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[])>("Given Attachment File Cache Location \u should be a directory.");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = staticinvoke <org.apache.axiom.util.UIDGenerator: java.lang.String generateUID()>();
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[])>("axiom\u.att");
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
v = new org.apache.axiom.attachments.lifecycle.impl.FileAccessor;
specialinvoke v.<org.apache.axiom.attachments.lifecycle.impl.FileAccessor: void <init>(org.apache.axiom.attachments.lifecycle.LifecycleManager,java.io.File)>(v, v);
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: java.util.Hashtable table>;
virtualinvoke v.<java.util.Hashtable: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
virtualinvoke v.<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: void deleteOnExit(java.io.File)>(v);
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("End Create()");
label:
return v;
}
public void delete(java.io.File) throws java.io.IOException
{
org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook v;
org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl v;
java.lang.String v;
java.util.Hashtable v;
boolean v, v, v, v, v, v, v, v, v;
java.io.File v;
org.apache.commons.logging.Log v, v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl;
v := @parameter: java.io.File;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("Start delete()");
label:
if v == null goto label;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: java.util.Hashtable table>;
v = virtualinvoke v.<java.io.File: java.lang.String getName()>();
virtualinvoke v.<java.util.Hashtable: java.lang.Object remove(java.lang.Object)>(v);
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("invoking file.delete()");
label:
v = virtualinvoke v.<java.io.File: boolean delete()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("delete() successful");
label:
v = staticinvoke <org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook: org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook hook()>();
v = virtualinvoke v.<org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook: boolean isRegistered()>();
if v == 0 goto label;
virtualinvoke v.<org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook: void remove(java.io.File)>(v);
label:
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("File Purged and removed from Shutdown Hook Collection");
goto label;
label:
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("Cannot delete file, set to delete on VM shutdown");
label:
virtualinvoke v.<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: void deleteOnExit(java.io.File)>(v);
label:
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("End delete()");
label:
return;
}
public void deleteOnExit(java.io.File) throws java.io.IOException
{
org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook v, v, v;
org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl v;
java.lang.String v, v, v;
java.util.Hashtable v;
boolean v, v, v;
java.io.File v;
org.apache.commons.logging.Log v, v, v, v, v, v;
v := @this: org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl;
v := @parameter: java.io.File;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("Start deleteOnExit()");
label:
v = v.<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook hook>;
if v != null goto label;
v = specialinvoke v.<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook RegisterVMShutdownHook()>();
v.<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook hook> = v;
label:
if v == null goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
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[])>("Invoking deleteOnExit() for file = \u0001");
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>(v);
label:
v = v.<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook hook>;
virtualinvoke v.<org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook: void add(java.io.File)>(v);
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: java.util.Hashtable table>;
v = virtualinvoke v.<java.io.File: java.lang.String getName()>();
virtualinvoke v.<java.util.Hashtable: java.lang.Object remove(java.lang.Object)>(v);
label:
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("End deleteOnExit()");
label:
return;
}
public void deleteOnTimeInterval(int, java.io.File) throws java.io.IOException
{
java.io.File v;
org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl v;
java.lang.Thread v;
int v;
org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl$FileDeletor v;
org.apache.commons.logging.Log v, v, v, v;
boolean v, v;
v := @this: org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl;
v := @parameter: int;
v := @parameter: java.io.File;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("Start deleteOnTimeInterval()");
label:
v = new java.lang.Thread;
v = new org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl$FileDeletor;
specialinvoke v.<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl$FileDeletor: void <init>(org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl,int,java.io.File)>(v, v, v);
specialinvoke v.<java.lang.Thread: void <init>(java.lang.Runnable)>(v);
virtualinvoke v.<java.lang.Thread: void setDaemon(boolean)>(1);
virtualinvoke v.<java.lang.Thread: void start()>();
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("End deleteOnTimeInterval()");
label:
return;
}
private org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook RegisterVMShutdownHook() throws java.lang.RuntimeException
{
org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook v;
org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl v;
java.lang.String v;
boolean v, v, v;
java.security.PrivilegedActionException v;
java.lang.RuntimeException v;
java.lang.Object v;
org.apache.commons.logging.Log v, v, v, v, v, v, v;
org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl$1 v;
v := @this: org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("Start RegisterVMShutdownHook()");
label:
v = new org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl$1;
specialinvoke v.<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl$1: void <init>(org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl)>(v);
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedExceptionAction)>(v);
v.<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook hook> = v;
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.security.PrivilegedActionException)>(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[])>("Exception thrown from AccessController: \u0001");
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>(v);
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("VM Shutdown Hook not registered.");
label:
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
v = interfaceinvoke v.<org.apache.commons.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log>;
interfaceinvoke v.<org.apache.commons.logging.Log: void debug(java.lang.Object)>("Exit RegisterVMShutdownHook()");
label:
v = v.<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.axiom.attachments.lifecycle.impl.VMShutdownHook hook>;
return v;
catch java.security.PrivilegedActionException from label to label with label;
}
public org.apache.axiom.attachments.lifecycle.impl.FileAccessor getFileAccessor(java.lang.String) throws java.io.IOException
{
java.lang.Object v;
java.lang.String v;
java.util.Hashtable v;
org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl v;
v := @this: org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl;
v := @parameter: java.lang.String;
v = <org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: java.util.Hashtable table>;
v = virtualinvoke v.<java.util.Hashtable: java.lang.Object get(java.lang.Object)>(v);
return v;
}
static void <clinit>()
{
org.apache.commons.logging.Log v;
java.util.Hashtable v;
v = staticinvoke <org.apache.commons.logging.LogFactory: org.apache.commons.logging.Log getLog(java.lang.Class)>(class "Lorg/apache/axiom/attachments/lifecycle/impl/LifecycleManagerImpl;");
<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: org.apache.commons.logging.Log log> = v;
v = new java.util.Hashtable;
specialinvoke v.<java.util.Hashtable: void <init>()>();
<org.apache.axiom.attachments.lifecycle.impl.LifecycleManagerImpl: java.util.Hashtable table> = v;
return;
}
}