public class org.eclipse.core.internal.jobs.LockManager
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.eclipse.core.internal.jobs.LockManager
super_class: java.lang.Object
{
protected org.eclipse.core.runtime.jobs.LockListener lockListener;
descriptor: Lorg/eclipse/core/runtime/jobs/LockListener;
flags: (0x0004) ACC_PROTECTED
private org.eclipse.core.internal.jobs.DeadlockDetector locks;
descriptor: Lorg/eclipse/core/internal/jobs/DeadlockDetector;
flags: (0x0002) ACC_PRIVATE
private final java.util.HashMap<java.lang.Thread, java.util.ArrayDeque<org.eclipse.core.internal.jobs.LockManager$LockState[]>> suspendedLocks;
descriptor: Ljava/util/HashMap;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/HashMap<Ljava/lang/Thread;Ljava/util/ArrayDeque<[Lorg/eclipse/core/internal/jobs/LockManager$LockState;>;>;
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new org.eclipse.core.internal.jobs.DeadlockDetector
dup
invokespecial org.eclipse.core.internal.jobs.DeadlockDetector.<init>:()V
putfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
2: aload 0
new java.util.HashMap
dup
invokespecial java.util.HashMap.<init>:()V
putfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
3: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/eclipse/core/internal/jobs/LockManager;
public void aboutToRelease();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=2, args_size=1
start local 0 0: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
ifnonnull 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
getfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
invokevirtual org.eclipse.core.runtime.jobs.LockListener.aboutToRelease:()V
3: goto 6
StackMap locals:
StackMap stack: java.lang.Throwable
4: astore 1
start local 1 5: aload 1
invokestatic org.eclipse.core.internal.jobs.LockManager.handleException:(Ljava/lang/Throwable;)V
end local 1 6: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/eclipse/core/internal/jobs/LockManager;
5 6 1 e Ljava/lang/Throwable;
Exception table:
from to target type
2 3 4 Class java.lang.Exception
2 3 4 Class java.lang.LinkageError
public boolean canBlock();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=2, args_size=1
start local 0 0: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
ifnonnull 2
1: iconst_1
ireturn
2: StackMap locals:
StackMap stack:
aload 0
getfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
invokevirtual org.eclipse.core.runtime.jobs.LockListener.canBlock:()Z
3: ireturn
4: StackMap locals:
StackMap stack: java.lang.Throwable
astore 1
start local 1 5: aload 1
invokestatic org.eclipse.core.internal.jobs.LockManager.handleException:(Ljava/lang/Throwable;)V
end local 1 6: iconst_0
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/eclipse/core/internal/jobs/LockManager;
5 6 1 e Ljava/lang/Throwable;
Exception table:
from to target type
2 3 4 Class java.lang.Exception
2 3 4 Class java.lang.LinkageError
public boolean aboutToWait(java.lang.Thread);
descriptor: (Ljava/lang/Thread;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
ifnonnull 2
1: iconst_0
ireturn
2: StackMap locals:
StackMap stack:
aload 0
getfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
aload 1
invokevirtual org.eclipse.core.runtime.jobs.LockListener.aboutToWait:(Ljava/lang/Thread;)Z
3: ireturn
4: StackMap locals:
StackMap stack: java.lang.Throwable
astore 2
start local 2 5: aload 2
invokestatic org.eclipse.core.internal.jobs.LockManager.handleException:(Ljava/lang/Throwable;)V
end local 2 6: iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/eclipse/core/internal/jobs/LockManager;
0 7 1 lockOwner Ljava/lang/Thread;
5 6 2 e Ljava/lang/Throwable;
Exception table:
from to target type
2 3 4 Class java.lang.Exception
2 3 4 Class java.lang.LinkageError
MethodParameters:
Name Flags
lockOwner
void addLockThread(java.lang.Thread, org.eclipse.core.runtime.jobs.ISchedulingRule);
descriptor: (Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
flags: (0x0000)
Code:
stack=3, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
astore 3
start local 3 1: aload 3
ifnonnull 3
2: return
3: StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack:
aload 3
dup
astore 4
monitorenter
4: aload 3
aload 1
aload 2
invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.lockAcquired:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
5: goto 8
StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.runtime.jobs.ISchedulingRule org.eclipse.core.internal.jobs.DeadlockDetector org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack: java.lang.Exception
6: astore 5
start local 5 7: aload 0
aload 3
aload 5
invokevirtual org.eclipse.core.internal.jobs.LockManager.createDebugException:(Lorg/eclipse/core/internal/jobs/DeadlockDetector;Ljava/lang/Exception;)Ljava/lang/Exception;
athrow
end local 5 8: StackMap locals:
StackMap stack:
aload 4
monitorexit
9: goto 14
StackMap locals:
StackMap stack: java.lang.Throwable
10: aload 4
monitorexit
11: athrow
12: StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.runtime.jobs.ISchedulingRule org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack: java.lang.Exception
astore 4
start local 4 13: aload 0
aload 4
invokevirtual org.eclipse.core.internal.jobs.LockManager.handleInternalError:(Ljava/lang/Throwable;)V
end local 4 14: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/eclipse/core/internal/jobs/LockManager;
0 15 1 thread Ljava/lang/Thread;
0 15 2 lock Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
1 15 3 tempLocks Lorg/eclipse/core/internal/jobs/DeadlockDetector;
7 8 5 e Ljava/lang/Exception;
13 14 4 e Ljava/lang/Exception;
Exception table:
from to target type
4 5 6 Class java.lang.Exception
4 9 10 any
10 11 10 any
3 12 12 Class java.lang.Exception
MethodParameters:
Name Flags
thread
lock
void addLockWaitThread(java.lang.Thread, org.eclipse.core.runtime.jobs.ISchedulingRule);
descriptor: (Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
flags: (0x0000)
Code:
stack=4, locals=8, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
astore 3
start local 3 1: aload 3
ifnonnull 3
2: return
3: StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack:
aconst_null
astore 4
start local 4 4: aload 3
dup
astore 5
monitorenter
5: aload 3
aload 1
aload 2
invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.lockWaitStart:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)Lorg/eclipse/core/internal/jobs/Deadlock;
astore 4
6: goto 9
StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.runtime.jobs.ISchedulingRule org.eclipse.core.internal.jobs.DeadlockDetector org.eclipse.core.internal.jobs.Deadlock org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack: java.lang.Exception
7: astore 6
start local 6 8: aload 0
aload 3
aload 6
invokevirtual org.eclipse.core.internal.jobs.LockManager.createDebugException:(Lorg/eclipse/core/internal/jobs/DeadlockDetector;Ljava/lang/Exception;)Ljava/lang/Exception;
athrow
end local 6 9: StackMap locals:
StackMap stack:
aload 5
monitorexit
10: goto 13
StackMap locals:
StackMap stack: java.lang.Throwable
11: aload 5
monitorexit
12: athrow
13: StackMap locals:
StackMap stack:
aload 4
ifnonnull 15
14: return
15: StackMap locals:
StackMap stack:
aload 4
invokevirtual org.eclipse.core.internal.jobs.Deadlock.getLocks:()[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
astore 5
start local 5 16: aload 5
arraylength
anewarray org.eclipse.core.internal.jobs.LockManager$LockState
astore 6
start local 6 17: iconst_0
istore 7
start local 7 18: goto 21
19: StackMap locals: org.eclipse.core.runtime.jobs.ISchedulingRule[] org.eclipse.core.internal.jobs.LockManager$LockState[] int
StackMap stack:
aload 6
iload 7
aload 5
iload 7
aaload
checkcast org.eclipse.core.internal.jobs.OrderedLock
invokestatic org.eclipse.core.internal.jobs.LockManager$LockState.suspend:(Lorg/eclipse/core/internal/jobs/OrderedLock;)Lorg/eclipse/core/internal/jobs/LockManager$LockState;
aastore
20: iinc 7 1
StackMap locals:
StackMap stack:
21: iload 7
aload 5
arraylength
if_icmplt 19
end local 7 22: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
dup
astore 7
monitorenter
23: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
aload 4
invokevirtual org.eclipse.core.internal.jobs.Deadlock.getCandidate:()Ljava/lang/Thread;
invokedynamic apply()Ljava/util/function/Function;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
(Ljava/lang/Object;)Ljava/lang/Object;
org/eclipse/core/internal/jobs/LockManager.lambda$0(Ljava/lang/Thread;)Ljava/util/ArrayDeque; (6)
(Ljava/lang/Thread;)Ljava/util/ArrayDeque;
invokevirtual java.util.HashMap.computeIfAbsent:(Ljava/lang/Object;Ljava/util/function/Function;)Ljava/lang/Object;
checkcast java.util.ArrayDeque
aload 6
invokevirtual java.util.ArrayDeque.push:(Ljava/lang/Object;)V
24: aload 7
monitorexit
25: goto 30
StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.runtime.jobs.ISchedulingRule org.eclipse.core.internal.jobs.DeadlockDetector org.eclipse.core.internal.jobs.Deadlock org.eclipse.core.runtime.jobs.ISchedulingRule[] org.eclipse.core.internal.jobs.LockManager$LockState[] java.util.HashMap
StackMap stack: java.lang.Throwable
26: aload 7
monitorexit
27: athrow
end local 6 end local 5 end local 4 28: StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.runtime.jobs.ISchedulingRule org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack: java.lang.Exception
astore 4
start local 4 29: aload 0
aload 4
invokevirtual org.eclipse.core.internal.jobs.LockManager.handleInternalError:(Ljava/lang/Throwable;)V
end local 4 30: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 31 0 this Lorg/eclipse/core/internal/jobs/LockManager;
0 31 1 thread Ljava/lang/Thread;
0 31 2 lock Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
1 31 3 tempLocks Lorg/eclipse/core/internal/jobs/DeadlockDetector;
4 28 4 found Lorg/eclipse/core/internal/jobs/Deadlock;
8 9 6 e Ljava/lang/Exception;
16 28 5 toSuspend [Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
17 28 6 suspended [Lorg/eclipse/core/internal/jobs/LockManager$LockState;
18 22 7 i I
29 30 4 e Ljava/lang/Exception;
Exception table:
from to target type
5 6 7 Class java.lang.Exception
5 10 11 any
11 12 11 any
23 25 26 any
26 27 26 any
3 14 28 Class java.lang.Exception
15 28 28 Class java.lang.Exception
MethodParameters:
Name Flags
thread
lock
private java.lang.Exception createDebugException(org.eclipse.core.internal.jobs.DeadlockDetector, java.lang.Exception);
descriptor: (Lorg/eclipse/core/internal/jobs/DeadlockDetector;Ljava/lang/Exception;)Ljava/lang/Exception;
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aconst_null
astore 3
start local 3 1: aload 1
invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.toDebugString:()Ljava/lang/String;
astore 3
2: goto 4
StackMap locals: org.eclipse.core.internal.jobs.LockManager org.eclipse.core.internal.jobs.DeadlockDetector java.lang.Exception java.lang.String
StackMap stack: java.lang.Exception
3: pop
4: StackMap locals:
StackMap stack:
new java.lang.Exception
dup
aload 3
aload 2
invokespecial java.lang.Exception.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/eclipse/core/internal/jobs/LockManager;
0 5 1 tempLocks Lorg/eclipse/core/internal/jobs/DeadlockDetector;
0 5 2 rootException Ljava/lang/Exception;
1 5 3 debugString Ljava/lang/String;
Exception table:
from to target type
1 2 3 Class java.lang.Exception
MethodParameters:
Name Flags
tempLocks
rootException
private static void handleException(java.lang.Throwable);
descriptor: (Ljava/lang/Throwable;)V
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=7, locals=2, args_size=1
start local 0 0: aload 0
instanceof org.eclipse.core.runtime.CoreException
ifeq 4
1: new org.eclipse.core.runtime.MultiStatus
dup
ldc "org.eclipse.core.jobs"
iconst_2
ldc "LockManager.handleException"
aload 0
invokespecial org.eclipse.core.runtime.MultiStatus.<init>:(Ljava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
astore 1
start local 1 2: aload 1
checkcast org.eclipse.core.runtime.MultiStatus
aload 0
checkcast org.eclipse.core.runtime.CoreException
invokevirtual org.eclipse.core.runtime.CoreException.getStatus:()Lorg/eclipse/core/runtime/IStatus;
invokevirtual org.eclipse.core.runtime.MultiStatus.merge:(Lorg/eclipse/core/runtime/IStatus;)V
3: goto 5
end local 1 4: StackMap locals:
StackMap stack:
new org.eclipse.core.runtime.Status
dup
iconst_4
ldc "org.eclipse.core.jobs"
iconst_2
ldc "LockManager.handleException"
aload 0
invokespecial org.eclipse.core.runtime.Status.<init>:(ILjava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
astore 1
start local 1 5: StackMap locals: org.eclipse.core.runtime.IStatus
StackMap stack:
aload 1
invokestatic org.eclipse.core.internal.runtime.RuntimeLog.log:(Lorg/eclipse/core/runtime/IStatus;)V
6: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 e Ljava/lang/Throwable;
2 4 1 status Lorg/eclipse/core/runtime/IStatus;
5 7 1 status Lorg/eclipse/core/runtime/IStatus;
MethodParameters:
Name Flags
e
private void handleInternalError(java.lang.Throwable);
descriptor: (Ljava/lang/Throwable;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
invokestatic org.eclipse.core.internal.jobs.LockManager.handleException:(Ljava/lang/Throwable;)V
1: goto 3
StackMap locals:
StackMap stack: java.lang.Exception
2: pop
3: StackMap locals:
StackMap stack:
aload 0
aconst_null
putfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
4: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/eclipse/core/internal/jobs/LockManager;
0 5 1 t Ljava/lang/Throwable;
Exception table:
from to target type
0 1 2 Class java.lang.Exception
MethodParameters:
Name Flags
t
public boolean isEmpty();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.isEmpty:()Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/eclipse/core/internal/jobs/LockManager;
public boolean isLockOwner();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=4, args_size=1
start local 0 0: invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
astore 1
start local 1 1: aload 1
instanceof org.eclipse.core.internal.jobs.Worker
ifeq 3
2: iconst_1
ireturn
3: StackMap locals: java.lang.Thread
StackMap stack:
aload 0
getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
astore 2
start local 2 4: aload 2
ifnonnull 6
5: iconst_0
ireturn
6: StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack:
aload 2
dup
astore 3
monitorenter
7: aload 2
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.contains:(Ljava/lang/Thread;)Z
aload 3
monitorexit
8: ireturn
9: StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.internal.jobs.DeadlockDetector org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack: java.lang.Throwable
aload 3
monitorexit
10: athrow
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lorg/eclipse/core/internal/jobs/LockManager;
1 11 1 current Ljava/lang/Thread;
4 11 2 tempLocks Lorg/eclipse/core/internal/jobs/DeadlockDetector;
Exception table:
from to target type
7 8 9 any
9 10 9 any
public synchronized org.eclipse.core.internal.jobs.OrderedLock newLock();
descriptor: ()Lorg/eclipse/core/internal/jobs/OrderedLock;
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=3, locals=1, args_size=1
start local 0 0: new org.eclipse.core.internal.jobs.OrderedLock
dup
aload 0
invokespecial org.eclipse.core.internal.jobs.OrderedLock.<init>:(Lorg/eclipse/core/internal/jobs/LockManager;)V
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/eclipse/core/internal/jobs/LockManager;
void removeLockCompletely(java.lang.Thread, org.eclipse.core.runtime.jobs.ISchedulingRule);
descriptor: (Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
flags: (0x0000)
Code:
stack=3, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
astore 3
start local 3 1: aload 3
ifnonnull 3
2: return
3: StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack:
aload 3
dup
astore 4
monitorenter
4: aload 3
aload 1
aload 2
invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.lockReleasedCompletely:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
5: goto 8
StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.runtime.jobs.ISchedulingRule org.eclipse.core.internal.jobs.DeadlockDetector org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack: java.lang.Exception
6: astore 5
start local 5 7: aload 0
aload 3
aload 5
invokevirtual org.eclipse.core.internal.jobs.LockManager.createDebugException:(Lorg/eclipse/core/internal/jobs/DeadlockDetector;Ljava/lang/Exception;)Ljava/lang/Exception;
athrow
end local 5 8: StackMap locals:
StackMap stack:
aload 4
monitorexit
9: goto 14
StackMap locals:
StackMap stack: java.lang.Throwable
10: aload 4
monitorexit
11: athrow
12: StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.runtime.jobs.ISchedulingRule org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack: java.lang.Exception
astore 4
start local 4 13: aload 0
aload 4
invokevirtual org.eclipse.core.internal.jobs.LockManager.handleInternalError:(Ljava/lang/Throwable;)V
end local 4 14: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/eclipse/core/internal/jobs/LockManager;
0 15 1 thread Ljava/lang/Thread;
0 15 2 rule Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
1 15 3 tempLocks Lorg/eclipse/core/internal/jobs/DeadlockDetector;
7 8 5 e Ljava/lang/Exception;
13 14 4 e Ljava/lang/Exception;
Exception table:
from to target type
4 5 6 Class java.lang.Exception
4 9 10 any
10 11 10 any
3 12 12 Class java.lang.Exception
MethodParameters:
Name Flags
thread
rule
void removeLockThread(java.lang.Thread, org.eclipse.core.runtime.jobs.ISchedulingRule);
descriptor: (Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
flags: (0x0000)
Code:
stack=3, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
astore 3
start local 3 1: aload 3
ifnonnull 3
2: return
3: StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack:
aload 3
dup
astore 4
monitorenter
4: aload 3
aload 1
aload 2
invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.lockReleased:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
5: goto 8
StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.runtime.jobs.ISchedulingRule org.eclipse.core.internal.jobs.DeadlockDetector org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack: java.lang.Exception
6: astore 5
start local 5 7: aload 0
aload 3
aload 5
invokevirtual org.eclipse.core.internal.jobs.LockManager.createDebugException:(Lorg/eclipse/core/internal/jobs/DeadlockDetector;Ljava/lang/Exception;)Ljava/lang/Exception;
athrow
end local 5 8: StackMap locals:
StackMap stack:
aload 4
monitorexit
9: goto 14
StackMap locals:
StackMap stack: java.lang.Throwable
10: aload 4
monitorexit
11: athrow
12: StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.runtime.jobs.ISchedulingRule org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack: java.lang.Exception
astore 4
start local 4 13: aload 0
aload 4
invokevirtual org.eclipse.core.internal.jobs.LockManager.handleInternalError:(Ljava/lang/Throwable;)V
end local 4 14: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/eclipse/core/internal/jobs/LockManager;
0 15 1 thread Ljava/lang/Thread;
0 15 2 lock Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
1 15 3 tempLocks Lorg/eclipse/core/internal/jobs/DeadlockDetector;
7 8 5 e Ljava/lang/Exception;
13 14 4 e Ljava/lang/Exception;
Exception table:
from to target type
4 5 6 Class java.lang.Exception
4 9 10 any
10 11 10 any
3 12 12 Class java.lang.Exception
MethodParameters:
Name Flags
thread
lock
void removeLockWaitThread(java.lang.Thread, org.eclipse.core.runtime.jobs.ISchedulingRule);
descriptor: (Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
flags: (0x0000)
Code:
stack=3, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
astore 3
start local 3 1: aload 3
ifnonnull 3
2: return
3: StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack:
aload 3
dup
astore 4
monitorenter
4: aload 3
aload 1
aload 2
invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.lockWaitStop:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
5: goto 8
StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.runtime.jobs.ISchedulingRule org.eclipse.core.internal.jobs.DeadlockDetector org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack: java.lang.Exception
6: astore 5
start local 5 7: aload 0
aload 3
aload 5
invokevirtual org.eclipse.core.internal.jobs.LockManager.createDebugException:(Lorg/eclipse/core/internal/jobs/DeadlockDetector;Ljava/lang/Exception;)Ljava/lang/Exception;
athrow
end local 5 8: StackMap locals:
StackMap stack:
aload 4
monitorexit
9: goto 14
StackMap locals:
StackMap stack: java.lang.Throwable
10: aload 4
monitorexit
11: athrow
12: StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.runtime.jobs.ISchedulingRule org.eclipse.core.internal.jobs.DeadlockDetector
StackMap stack: java.lang.Exception
astore 4
start local 4 13: aload 0
aload 4
invokevirtual org.eclipse.core.internal.jobs.LockManager.handleInternalError:(Ljava/lang/Throwable;)V
end local 4 14: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/eclipse/core/internal/jobs/LockManager;
0 15 1 thread Ljava/lang/Thread;
0 15 2 lock Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
1 15 3 tempLocks Lorg/eclipse/core/internal/jobs/DeadlockDetector;
7 8 5 e Ljava/lang/Exception;
13 14 4 e Ljava/lang/Exception;
Exception table:
from to target type
4 5 6 Class java.lang.Exception
4 9 10 any
10 11 10 any
3 12 12 Class java.lang.Exception
MethodParameters:
Name Flags
thread
lock
void resumeSuspendedLocks(java.lang.Thread);
descriptor: (Ljava/lang/Thread;)V
flags: (0x0000)
Code:
stack=2, locals=7, args_size=2
start local 0 start local 1 0: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
dup
astore 3
monitorenter
1: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
aload 1
invokevirtual java.util.HashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.util.ArrayDeque
astore 4
start local 4 2: aload 4
ifnonnull 5
3: aload 3
monitorexit
4: return
5: StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread top java.util.HashMap java.util.ArrayDeque
StackMap stack:
aload 4
invokevirtual java.util.ArrayDeque.pop:()Ljava/lang/Object;
checkcast org.eclipse.core.internal.jobs.LockManager$LockState[]
astore 2
start local 2 6: aload 4
invokevirtual java.util.ArrayDeque.isEmpty:()Z
ifeq 8
7: aload 0
getfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
aload 1
invokevirtual java.util.HashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
pop
end local 4 8: StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.internal.jobs.LockManager$LockState[] java.util.HashMap
StackMap stack:
aload 3
monitorexit
9: goto 12
end local 2 StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread top java.util.HashMap
StackMap stack: java.lang.Throwable
10: aload 3
monitorexit
11: athrow
start local 2 12: StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.internal.jobs.LockManager$LockState[]
StackMap stack:
aload 2
dup
astore 6
arraylength
istore 5
iconst_0
istore 4
goto 16
StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.internal.jobs.LockManager$LockState[] top int int org.eclipse.core.internal.jobs.LockManager$LockState[]
StackMap stack:
13: aload 6
iload 4
aaload
astore 3
start local 3 14: aload 3
invokevirtual org.eclipse.core.internal.jobs.LockManager$LockState.resume:()V
end local 3 15: iinc 4 1
StackMap locals:
StackMap stack:
16: iload 4
iload 5
if_icmplt 13
17: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Lorg/eclipse/core/internal/jobs/LockManager;
0 18 1 owner Ljava/lang/Thread;
6 10 2 toResume [Lorg/eclipse/core/internal/jobs/LockManager$LockState;
12 18 2 toResume [Lorg/eclipse/core/internal/jobs/LockManager$LockState;
2 8 4 prevLocks Ljava/util/ArrayDeque;
14 15 3 element Lorg/eclipse/core/internal/jobs/LockManager$LockState;
Exception table:
from to target type
1 4 10 any
5 9 10 any
10 11 10 any
MethodParameters:
Name Flags
owner
public void setLockListener(org.eclipse.core.runtime.jobs.LockListener);
descriptor: (Lorg/eclipse/core/runtime/jobs/LockListener;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/eclipse/core/internal/jobs/LockManager;
0 2 1 listener Lorg/eclipse/core/runtime/jobs/LockListener;
MethodParameters:
Name Flags
listener
private static java.util.ArrayDeque lambda$0(java.lang.Thread);
descriptor: (Ljava/lang/Thread;)Ljava/util/ArrayDeque;
flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: new java.util.ArrayDeque
dup
invokespecial java.util.ArrayDeque.<init>:()V
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 key Ljava/lang/Thread;
}
SourceFile: "LockManager.java"
NestMembers:
org.eclipse.core.internal.jobs.LockManager$LockState
InnerClasses:
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
private LockState = org.eclipse.core.internal.jobs.LockManager$LockState of org.eclipse.core.internal.jobs.LockManager