public class org.glassfish.hk.runlevel.internal.AsyncRunLevelContext extends java.lang.Object
{
private static final java.lang.String DEBUG_CONTEXT_PROPERTY;
private static final boolean DEBUG_CONTEXT;
private static final java.util.logging.Logger logger;
private static final java.util.Timer TIMER;
private static final java.util.concurrent.ThreadFactory THREAD_FACTORY;
private final org.glassfish.hk.utilities.reflection.Logger hk2Logger;
private int currentLevel;
private org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask;
private static final java.util.concurrent.Executor DEFAULT_EXECUTOR;
private final java.util.Map backingMap;
private final java.util.Map levelErrorMap;
private boolean wasCancelled;
private final java.util.HashMap creatingDescriptors;
private final java.util.HashSet hardCancelledDescriptors;
private final java.util.LinkedList orderedCreationList;
private java.util.concurrent.Executor executor;
private final org.glassfish.hk.api.ServiceLocator locator;
private int maxThreads;
private org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy policy;
private long cancelTimeout;
private java.lang.Integer modeOverride;
private void <init>(org.glassfish.hk.api.ServiceLocator)
{
java.util.concurrent.Executor v;
org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy v;
org.glassfish.hk.utilities.reflection.Logger v;
java.util.HashMap v, v, v;
java.util.HashSet v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
int v;
org.glassfish.hk.api.ServiceLocator v;
java.util.LinkedList v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: org.glassfish.hk.api.ServiceLocator;
specialinvoke v.<java.lang.Object: void <init>()>();
v = staticinvoke <org.glassfish.hk.utilities.reflection.Logger: org.glassfish.hk.utilities.reflection.Logger getLogger()>();
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger> = v;
v = (int) -2;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: int currentLevel> = v;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask> = null;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Map backingMap> = v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Map levelErrorMap> = v;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean wasCancelled> = 0;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashMap creatingDescriptors> = v;
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashSet hardCancelledDescriptors> = v;
v = new java.util.LinkedList;
specialinvoke v.<java.util.LinkedList: void <init>()>();
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.LinkedList orderedCreationList> = v;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.concurrent.Executor DEFAULT_EXECUTOR>;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.concurrent.Executor executor> = v;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: int maxThreads> = 2147483647;
v = <org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy: org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy FULLY_THREADED>;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy policy> = v;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: long cancelTimeout> = 5000L;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.lang.Integer modeOverride> = null;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.api.ServiceLocator locator> = v;
return;
}
public java.lang.Object findOrCreate(org.glassfish.hk.api.ActiveDescriptor, org.glassfish.hk.api.ServiceHandle)
{
org.glassfish.hk.utilities.reflection.Logger v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.Integer v;
org.glassfish.hk.api.ActiveDescriptor v;
byte v;
java.lang.Long v;
java.lang.Thread v, v;
java.util.Map v, v, v, v, v, v;
long v, v, v;
org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper v, v, v, v;
org.glassfish.hk.runlevel.internal.WasCancelledException v, v, v;
java.util.HashSet v, v, v;
int v, v, v;
java.util.LinkedList v;
org.glassfish.hk.api.ServiceHandle v;
java.lang.Object v, v, v, v, v, v, v;
org.glassfish.hk.api.MultiException v, v, v, v, v, v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
org.glassfish.hk.api.ServiceLocator v;
java.lang.Throwable v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.RuntimeException v, v, v;
java.lang.IllegalStateException v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.glassfish.hk.runlevel.internal.WouldBlockException v;
java.util.HashMap v, v, v, v, v;
java.lang.InterruptedException v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: org.glassfish.hk.api.ActiveDescriptor;
v := @parameter: org.glassfish.hk.api.ServiceHandle;
v = null;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = staticinvoke <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.lang.String oneLineDescriptor(org.glassfish.hk.api.ActiveDescriptor)>(v);
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
v = staticinvoke <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.lang.String oneLineRoot(org.glassfish.hk.api.ServiceHandle)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,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[])>("AsyncRunLevelController findOrCreate for \u and root \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
if v != null goto label;
v = 0;
goto label;
label:
v = interfaceinvoke v.<org.glassfish.hk.api.ServiceHandle: java.lang.Object getServiceData()>();
if v != null goto label;
v = 0;
goto label;
label:
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
label:
entermonitor v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.lang.Integer modeOverride>;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Map backingMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
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[])>("AsyncRunLevelController found \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
exitmonitor v;
label:
return v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Map levelErrorMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
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[])>("AsyncRunLevelController tried once, it failed, rethrowing \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = v instanceof java.lang.RuntimeException;
if v == 0 goto label;
throw v;
label:
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashSet hardCancelledDescriptors>;
v = virtualinvoke v.<java.util.HashSet: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
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[])>("AsyncRunLevelController hard cancelled \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
v = new org.glassfish.hk.api.MultiException;
v = new org.glassfish.hk.runlevel.internal.WasCancelledException;
specialinvoke v.<org.glassfish.hk.runlevel.internal.WasCancelledException: void <init>(org.glassfish.hk.api.Descriptor)>(v);
specialinvoke v.<org.glassfish.hk.api.MultiException: void <init>(java.lang.Throwable,boolean)>(v, 0);
throw v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashMap creatingDescriptors>;
v = virtualinvoke v.<java.util.HashMap: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
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[])>("AsyncRunLevelController already being created \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashMap creatingDescriptors>;
v = virtualinvoke v.<java.util.HashMap: java.lang.Object get(java.lang.Object)>(v);
v = virtualinvoke v.<java.lang.Long: long longValue()>();
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: long getId()>();
v = v cmp v;
if v != 0 goto label;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
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[])>("AsyncRunLevelController circular dependency \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
v = new org.glassfish.hk.api.MultiException;
v = new java.lang.IllegalStateException;
v = interfaceinvoke v.<org.glassfish.hk.api.ActiveDescriptor: java.lang.String getImplementation()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,org.glassfish.hk.api.ActiveDescriptor)>(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[])>("Circular dependency involving \u was found.  Full descriptor is \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
specialinvoke v.<org.glassfish.hk.api.MultiException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
if v == 0 goto label;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
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[])>("AsyncRunLevelController would block optimization \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
v = new org.glassfish.hk.api.MultiException;
v = new org.glassfish.hk.runlevel.internal.WouldBlockException;
specialinvoke v.<org.glassfish.hk.runlevel.internal.WouldBlockException: void <init>(org.glassfish.hk.api.Descriptor)>(v);
specialinvoke v.<org.glassfish.hk.api.MultiException: void <init>(java.lang.Throwable,boolean)>(v, 0);
throw v;
label:
virtualinvoke v.<java.lang.Object: void wait()>();
label:
goto label;
label:
v := @caughtexception;
v = new org.glassfish.hk.api.MultiException;
specialinvoke v.<org.glassfish.hk.api.MultiException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
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[])>("AsyncRunLevelController finished creating wait for \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Map backingMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
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[])>("AsyncRunLevelController second chance found \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
exitmonitor v;
label:
return v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Map levelErrorMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
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[])>("AsyncRunLevelController service already threw \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
v = v instanceof java.lang.RuntimeException;
if v == 0 goto label;
throw v;
label:
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashSet hardCancelledDescriptors>;
v = virtualinvoke v.<java.util.HashSet: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
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[])>("AsyncRunLevelController second chance hard cancel \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
v = new org.glassfish.hk.api.MultiException;
v = new org.glassfish.hk.runlevel.internal.WasCancelledException;
specialinvoke v.<org.glassfish.hk.runlevel.internal.WasCancelledException: void <init>(org.glassfish.hk.api.Descriptor)>(v);
specialinvoke v.<org.glassfish.hk.api.MultiException: void <init>(java.lang.Throwable,boolean)>(v, 0);
throw v;
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: long getId()>();
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,long)>(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[])>("AsyncRunLevelController am creating \u in thread \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashMap creatingDescriptors>;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
virtualinvoke v.<java.util.HashMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: int currentLevel>;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask>;
if v == null goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask>;
v = virtualinvoke v.<org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper: boolean isUp()>();
if v == 0 goto label;
v = v + 1;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask>;
v = virtualinvoke v.<org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper: int getProposedLevel()>();
if v <= v goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask>;
v = virtualinvoke v.<org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper: int getProposedLevel()>();
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.api.ServiceLocator locator>;
v = staticinvoke <org.glassfish.hk.runlevel.utilities.Utilities: int getRunLevelMode(org.glassfish.hk.api.ServiceLocator,org.glassfish.hk.api.Descriptor,java.lang.Integer)>(v, v, v);
if v != 1 goto label;
specialinvoke v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: void validate(org.glassfish.hk.api.ActiveDescriptor,int)>(v, v);
label:
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,long)>(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[])>("AsyncRunLevelController prior to actual create \u in thread \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
v = interfaceinvoke v.<org.glassfish.hk.api.ActiveDescriptor: java.lang.Object create(org.glassfish.hk.api.ServiceHandle)>(v);
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,long)>(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[])>("AsyncRunLevelController after actual create \u in thread \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
v = v;
label:
entermonitor v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashSet hardCancelledDescriptors>;
v = virtualinvoke v.<java.util.HashSet: boolean remove(java.lang.Object)>(v);
if v == null goto label;
if v != 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Map backingMap>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.LinkedList orderedCreationList>;
virtualinvoke v.<java.util.LinkedList: void addFirst(java.lang.Object)>(v);
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean wasCancelled>;
if v != 0 goto label;
if v == 0 goto label;
label:
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,long)>(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[])>("AsyncRunLevelController cancellation race failed \u in thread \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
v = new org.glassfish.hk.api.MultiException;
v = new org.glassfish.hk.runlevel.internal.WasCancelledException;
specialinvoke v.<org.glassfish.hk.runlevel.internal.WasCancelledException: void <init>(org.glassfish.hk.api.Descriptor)>(v);
specialinvoke v.<org.glassfish.hk.api.MultiException: void <init>(java.lang.Throwable,boolean)>(v, 0);
if v != 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Map levelErrorMap>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashMap creatingDescriptors>;
virtualinvoke v.<java.util.HashMap: java.lang.Object remove(java.lang.Object)>(v);
virtualinvoke v.<java.lang.Object: void notifyAll()>();
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,long)>(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[])>("AsyncRunLevelController other threads notified cancellation path for \u in thread \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
throw v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashMap creatingDescriptors>;
virtualinvoke v.<java.util.HashMap: java.lang.Object remove(java.lang.Object)>(v);
virtualinvoke v.<java.lang.Object: void notifyAll()>();
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,long)>(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[])>("AsyncRunLevelController other threads notified for \u in thread \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return v;
label:
v := @caughtexception;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT>;
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.utilities.reflection.Logger hk2Logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,long)>(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[])>("AsyncRunLevelController got exception for \u in thread \u0001");
virtualinvoke v.<org.glassfish.hk.utilities.reflection.Logger: void debug(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = v instanceof org.glassfish.hk.api.MultiException;
if v == 0 goto label;
staticinvoke <org.glassfish.hk.runlevel.internal.CurrentTaskFuture: boolean isWouldBlock(java.lang.Throwable)>(v);
label:
v = v instanceof java.lang.RuntimeException;
if v == 0 goto label;
throw v;
label:
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.lang.InterruptedException 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;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public boolean containsKey(org.glassfish.hk.api.ActiveDescriptor)
{
java.lang.Throwable v;
org.glassfish.hk.api.ActiveDescriptor v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
java.util.Map v;
boolean v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: org.glassfish.hk.api.ActiveDescriptor;
entermonitor v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Map backingMap>;
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
}
boolean wouldBlockRightNow(org.glassfish.hk.api.ActiveDescriptor)
{
java.lang.Throwable v;
org.glassfish.hk.api.ActiveDescriptor v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
java.util.HashMap v;
boolean v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: org.glassfish.hk.api.ActiveDescriptor;
entermonitor v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashMap creatingDescriptors>;
v = virtualinvoke v.<java.util.HashMap: boolean containsKey(java.lang.Object)>(v);
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
}
void hardCancelOne(org.glassfish.hk.api.ActiveDescriptor)
{
java.util.HashSet v;
org.glassfish.hk.api.ActiveDescriptor v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
java.util.HashMap v;
boolean v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: org.glassfish.hk.api.ActiveDescriptor;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashMap creatingDescriptors>;
v = virtualinvoke v.<java.util.HashMap: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.HashSet hardCancelledDescriptors>;
virtualinvoke v.<java.util.HashSet: boolean add(java.lang.Object)>(v);
label:
return;
}
public void destroyOne(org.glassfish.hk.api.ActiveDescriptor)
{
java.lang.Throwable v;
org.glassfish.hk.api.ActiveDescriptor v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
java.util.Map v;
java.lang.Object v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: org.glassfish.hk.api.ActiveDescriptor;
entermonitor v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Map backingMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
if v != null goto label;
exitmonitor v;
label:
return;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
interfaceinvoke v.<org.glassfish.hk.api.ActiveDescriptor: void dispose(java.lang.Object)>(v);
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void validate(org.glassfish.hk.api.ActiveDescriptor, int) throws java.lang.IllegalStateException
{
java.lang.IllegalStateException v;
java.lang.Integer v;
org.glassfish.hk.api.ActiveDescriptor v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
int v, v, v;
java.lang.String v, v;
org.glassfish.hk.api.ServiceLocator v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: org.glassfish.hk.api.ActiveDescriptor;
v := @parameter: int;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.api.ServiceLocator locator>;
v = staticinvoke <org.glassfish.hk.runlevel.utilities.Utilities: int getRunLevelValue(org.glassfish.hk.api.ServiceLocator,org.glassfish.hk.api.Descriptor)>(v, v);
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
if v <= v goto label;
v = new java.lang.IllegalStateException;
v = interfaceinvoke v.<org.glassfish.hk.api.ActiveDescriptor: java.lang.String getImplementation()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int,java.lang.Integer,org.glassfish.hk.api.ActiveDescriptor)>(v, 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[])>("Service \u was started at level \u but it has a run level of \u.  The full descriptor is \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
return;
}
synchronized int getCurrentLevel()
{
int v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: int currentLevel>;
return v;
}
synchronized void levelCancelled()
{
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean wasCancelled> = 1;
return;
}
synchronized void setCurrentLevel(int)
{
int v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: int;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: int currentLevel> = v;
return;
}
synchronized void setPolicy(org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy)
{
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy policy> = v;
return;
}
synchronized void setExecutor(java.util.concurrent.Executor)
{
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
java.util.concurrent.Executor v, v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: java.util.concurrent.Executor;
if v != null goto label;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.concurrent.Executor DEFAULT_EXECUTOR>;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.concurrent.Executor executor> = v;
goto label;
label:
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.concurrent.Executor executor> = v;
label:
return;
}
synchronized java.util.concurrent.Executor getExecutor()
{
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
java.util.concurrent.Executor v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.concurrent.Executor executor>;
return v;
}
synchronized org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy getPolicy()
{
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy policy>;
return v;
}
java.util.List getOrderedListOfServicesAtLevel(int)
{
java.lang.Throwable v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
int v, v;
java.lang.Object v, v;
org.glassfish.hk.api.ServiceLocator v;
java.util.LinkedList v, v, v, v;
boolean v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: int;
entermonitor v;
label:
v = new java.util.LinkedList;
specialinvoke v.<java.util.LinkedList: void <init>()>();
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.LinkedList orderedCreationList>;
v = virtualinvoke v.<java.util.LinkedList: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.LinkedList orderedCreationList>;
v = virtualinvoke v.<java.util.LinkedList: java.lang.Object get(int)>(0);
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.api.ServiceLocator locator>;
v = staticinvoke <org.glassfish.hk.runlevel.utilities.Utilities: int getRunLevelValue(org.glassfish.hk.api.ServiceLocator,org.glassfish.hk.api.Descriptor)>(v, v);
if v >= v goto label;
exitmonitor v;
label:
return v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.LinkedList orderedCreationList>;
v = virtualinvoke v.<java.util.LinkedList: java.lang.Object remove(int)>(0);
virtualinvoke v.<java.util.LinkedList: boolean add(java.lang.Object)>(v);
goto label;
label:
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public org.glassfish.hk.runlevel.RunLevelFuture proceedTo(int) throws org.glassfish.hk.runlevel.CurrentlyRunningException
{
java.lang.Throwable v;
org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy v, v;
java.util.Timer v;
long v;
int v, v;
org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper v, v, v, v;
boolean v;
java.util.concurrent.Executor v;
org.glassfish.hk.runlevel.CurrentlyRunningException v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
org.glassfish.hk.runlevel.internal.CurrentTaskFuture v, v;
org.glassfish.hk.api.ServiceLocator v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: int;
entermonitor v;
label:
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy policy>;
v = <org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy: org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy FULLY_THREADED>;
v = virtualinvoke v.<org.glassfish.hk.runlevel.RunLevelController$ThreadingPolicy: boolean equals(java.lang.Object)>(v);
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask>;
if v == null goto label;
v = new org.glassfish.hk.runlevel.CurrentlyRunningException;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask>;
specialinvoke v.<org.glassfish.hk.runlevel.CurrentlyRunningException: void <init>(org.glassfish.hk.runlevel.RunLevelFuture)>(v);
throw v;
label:
v = new org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper;
v = new org.glassfish.hk.runlevel.internal.CurrentTaskFuture;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.concurrent.Executor executor>;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.api.ServiceLocator locator>;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: int maxThreads>;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: long cancelTimeout>;
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Timer TIMER>;
specialinvoke v.<org.glassfish.hk.runlevel.internal.CurrentTaskFuture: void <init>(org.glassfish.hk.runlevel.internal.AsyncRunLevelContext,java.util.concurrent.Executor,org.glassfish.hk.api.ServiceLocator,int,int,boolean,long,java.util.Timer)>(v, v, v, v, v, v, v, v);
specialinvoke v.<org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper: void <init>(org.glassfish.hk.runlevel.internal.CurrentTaskFuture)>(v);
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask> = v;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask>;
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = virtualinvoke v.<org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper: org.glassfish.hk.runlevel.internal.CurrentTaskFuture getDelegate()>();
virtualinvoke v.<org.glassfish.hk.runlevel.internal.CurrentTaskFuture: void go()>();
return v;
catch java.lang.Throwable from label to label with label;
}
synchronized void jobDone()
{
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask> = null;
return;
}
public synchronized org.glassfish.hk.runlevel.RunLevelFuture getCurrentFuture()
{
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: org.glassfish.hk.runlevel.internal.CurrentTaskFutureWrapper currentTask>;
return v;
}
synchronized void setMaximumThreads(int)
{
int v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: int;
if v >= 1 goto label;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: int maxThreads> = 1;
goto label;
label:
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: int maxThreads> = v;
label:
return;
}
synchronized int getMaximumThreads()
{
int v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: int maxThreads>;
return v;
}
synchronized void clearErrors()
{
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
java.util.Map v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Map levelErrorMap>;
interfaceinvoke v.<java.util.Map: void clear()>();
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean wasCancelled> = 0;
return;
}
synchronized void setCancelTimeout(long)
{
long v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: long;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: long cancelTimeout> = v;
return;
}
synchronized long getCancelTimeout()
{
long v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: long cancelTimeout>;
return v;
}
synchronized java.lang.Integer getModeOverride()
{
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
java.lang.Integer v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v = v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.lang.Integer modeOverride>;
return v;
}
synchronized void setModeOverride(java.lang.Integer)
{
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext v;
java.lang.Integer v;
v := @this: org.glassfish.hk.runlevel.internal.AsyncRunLevelContext;
v := @parameter: java.lang.Integer;
v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.lang.Integer modeOverride> = v;
return;
}
private static java.lang.String oneLineDescriptor(org.glassfish.hk.api.ActiveDescriptor)
{
org.glassfish.hk.api.ActiveDescriptor v;
java.lang.Long v, v;
int v;
java.lang.String v, v, v, v, v;
v := @parameter: org.glassfish.hk.api.ActiveDescriptor;
if v != null goto label;
return "null-descriptor";
label:
v = interfaceinvoke v.<org.glassfish.hk.api.ActiveDescriptor: java.lang.String getImplementation()>();
v = interfaceinvoke v.<org.glassfish.hk.api.ActiveDescriptor: java.lang.String getName()>();
if v == null goto label;
v = interfaceinvoke v.<org.glassfish.hk.api.ActiveDescriptor: 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[])>("/\u0001");
goto label;
label:
v = "";
label:
v = interfaceinvoke v.<org.glassfish.hk.api.ActiveDescriptor: java.lang.Long getServiceId()>();
v = interfaceinvoke v.<org.glassfish.hk.api.ActiveDescriptor: java.lang.Long getLocatorId()>();
v = staticinvoke <java.lang.System: int identityHashCode(java.lang.Object)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,java.lang.Long,java.lang.Long,int)>(v, v, 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[])>("\u0001\u0001(\u,\u,\u)");
return v;
}
private static java.lang.String oneLineRoot(org.glassfish.hk.api.ServiceHandle)
{
org.glassfish.hk.api.ActiveDescriptor v;
int v;
java.lang.String v, v;
org.glassfish.hk.api.ServiceHandle v;
v := @parameter: org.glassfish.hk.api.ServiceHandle;
if v != null goto label;
return "null-root";
label:
interfaceinvoke v.<org.glassfish.hk.api.ServiceHandle: org.glassfish.hk.api.ActiveDescriptor getActiveDescriptor()>();
v = interfaceinvoke v.<org.glassfish.hk.api.ServiceHandle: org.glassfish.hk.api.ActiveDescriptor getActiveDescriptor()>();
v = staticinvoke <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.lang.String oneLineDescriptor(org.glassfish.hk.api.ActiveDescriptor)>(v);
v = staticinvoke <java.lang.System: int identityHashCode(java.lang.Object)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,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[])>("root(\u,\u)");
return v;
}
static void <clinit>()
{
java.util.concurrent.SynchronousQueue v;
java.util.concurrent.ThreadPoolExecutor v;
java.util.Timer v;
java.util.logging.Logger v;
java.util.concurrent.TimeUnit v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext$1 v;
org.glassfish.hk.runlevel.internal.AsyncRunLevelContext$RunLevelThreadFactory v;
java.lang.Class v;
java.lang.Object v;
java.lang.String v;
java.util.concurrent.ThreadFactory v;
boolean v;
v = new org.glassfish.hk.runlevel.internal.AsyncRunLevelContext$1;
specialinvoke v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext$1: void <init>()>();
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedAction)>(v);
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: boolean DEBUG_CONTEXT> = v;
v = class "Lorg/glassfish/hk2/runlevel/internal/AsyncRunLevelContext;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <java.util.logging.Logger: java.util.logging.Logger getLogger(java.lang.String)>(v);
<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.logging.Logger logger> = v;
v = new java.util.Timer;
specialinvoke v.<java.util.Timer: void <init>(java.lang.String,boolean)>("hk2-asyncrunlevelcontext", 1);
<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.Timer TIMER> = v;
v = new org.glassfish.hk.runlevel.internal.AsyncRunLevelContext$RunLevelThreadFactory;
specialinvoke v.<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext$RunLevelThreadFactory: void <init>()>();
<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.concurrent.ThreadFactory THREAD_FACTORY> = v;
v = new java.util.concurrent.ThreadPoolExecutor;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
v = new java.util.concurrent.SynchronousQueue;
specialinvoke v.<java.util.concurrent.SynchronousQueue: void <init>(boolean)>(1);
v = <org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.concurrent.ThreadFactory THREAD_FACTORY>;
specialinvoke v.<java.util.concurrent.ThreadPoolExecutor: void <init>(int,int,long,java.util.concurrent.TimeUnit,java.util.concurrent.BlockingQueue,java.util.concurrent.ThreadFactory)>(0, 2147483647, 60L, v, v, v);
<org.glassfish.hk.runlevel.internal.AsyncRunLevelContext: java.util.concurrent.Executor DEFAULT_EXECUTOR> = v;
return;
}
}