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 // org.eclipse.core.internal.jobs.LockManager this
         0: .line 31
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 75
            aload 0 /* this */
            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: .line 82
            aload 0 /* this */
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
         3: .line 31
            return
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
         0: .line 85
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
            ifnonnull 2
         1: .line 86
            return
         2: .line 88
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
            invokevirtual org.eclipse.core.runtime.jobs.LockListener.aboutToRelease:()V
         3: .line 89
            goto 6
      StackMap locals:
      StackMap stack: java.lang.Throwable
         4: astore 1 /* e */
        start local 1 // java.lang.Throwable e
         5: .line 90
            aload 1 /* e */
            invokestatic org.eclipse.core.internal.jobs.LockManager.handleException:(Ljava/lang/Throwable;)V
        end local 1 // java.lang.Throwable e
         6: .line 92
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
         0: .line 95
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
            ifnonnull 2
         1: .line 96
            iconst_1
            ireturn
         2: .line 98
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            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: .line 99
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1 /* e */
        start local 1 // java.lang.Throwable e
         5: .line 100
            aload 1 /* e */
            invokestatic org.eclipse.core.internal.jobs.LockManager.handleException:(Ljava/lang/Throwable;)V
        end local 1 // java.lang.Throwable e
         6: .line 102
            iconst_0
            ireturn
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
        start local 1 // java.lang.Thread lockOwner
         0: .line 106
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
            ifnonnull 2
         1: .line 107
            iconst_0
            ireturn
         2: .line 109
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
            aload 1 /* lockOwner */
            invokevirtual org.eclipse.core.runtime.jobs.LockListener.aboutToWait:(Ljava/lang/Thread;)Z
         3: ireturn
         4: .line 110
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2 /* e */
        start local 2 // java.lang.Throwable e
         5: .line 111
            aload 2 /* e */
            invokestatic org.eclipse.core.internal.jobs.LockManager.handleException:(Ljava/lang/Throwable;)V
        end local 2 // java.lang.Throwable e
         6: .line 113
            iconst_0
            ireturn
        end local 1 // java.lang.Thread lockOwner
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
        start local 1 // java.lang.Thread thread
        start local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule lock
         0: .line 120
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
            astore 3 /* tempLocks */
        start local 3 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
         1: .line 121
            aload 3 /* tempLocks */
            ifnonnull 3
         2: .line 122
            return
         3: .line 124
      StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
      StackMap stack:
            aload 3 /* tempLocks */
            dup
            astore 4
            monitorenter
         4: .line 126
            aload 3 /* tempLocks */
            aload 1 /* thread */
            aload 2 /* lock */
            invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.lockAcquired:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
         5: .line 127
            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 /* e */
        start local 5 // java.lang.Exception e
         7: .line 128
            aload 0 /* this */
            aload 3 /* tempLocks */
            aload 5 /* e */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.createDebugException:(Lorg/eclipse/core/internal/jobs/DeadlockDetector;Ljava/lang/Exception;)Ljava/lang/Exception;
            athrow
        end local 5 // java.lang.Exception e
         8: .line 124
      StackMap locals:
      StackMap stack:
            aload 4
            monitorexit
         9: goto 14
      StackMap locals:
      StackMap stack: java.lang.Throwable
        10: aload 4
            monitorexit
        11: athrow
        12: .line 131
      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 /* e */
        start local 4 // java.lang.Exception e
        13: .line 132
            aload 0 /* this */
            aload 4 /* e */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.handleInternalError:(Ljava/lang/Throwable;)V
        end local 4 // java.lang.Exception e
        14: .line 134
      StackMap locals:
      StackMap stack:
            return
        end local 3 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
        end local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule lock
        end local 1 // java.lang.Thread thread
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
        start local 1 // java.lang.Thread thread
        start local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule lock
         0: .line 140
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
            astore 3 /* tempLocks */
        start local 3 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
         1: .line 141
            aload 3 /* tempLocks */
            ifnonnull 3
         2: .line 142
            return
         3: .line 144
      StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
      StackMap stack:
            aconst_null
            astore 4 /* found */
        start local 4 // org.eclipse.core.internal.jobs.Deadlock found
         4: .line 145
            aload 3 /* tempLocks */
            dup
            astore 5
            monitorenter
         5: .line 147
            aload 3 /* tempLocks */
            aload 1 /* thread */
            aload 2 /* lock */
            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 /* found */
         6: .line 148
            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 /* e */
        start local 6 // java.lang.Exception e
         8: .line 149
            aload 0 /* this */
            aload 3 /* tempLocks */
            aload 6 /* e */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.createDebugException:(Lorg/eclipse/core/internal/jobs/DeadlockDetector;Ljava/lang/Exception;)Ljava/lang/Exception;
            athrow
        end local 6 // java.lang.Exception e
         9: .line 145
      StackMap locals:
      StackMap stack:
            aload 5
            monitorexit
        10: goto 13
      StackMap locals:
      StackMap stack: java.lang.Throwable
        11: aload 5
            monitorexit
        12: athrow
        13: .line 152
      StackMap locals:
      StackMap stack:
            aload 4 /* found */
            ifnonnull 15
        14: .line 153
            return
        15: .line 156
      StackMap locals:
      StackMap stack:
            aload 4 /* found */
            invokevirtual org.eclipse.core.internal.jobs.Deadlock.getLocks:()[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            astore 5 /* toSuspend */
        start local 5 // org.eclipse.core.runtime.jobs.ISchedulingRule[] toSuspend
        16: .line 157
            aload 5 /* toSuspend */
            arraylength
            anewarray org.eclipse.core.internal.jobs.LockManager$LockState
            astore 6 /* suspended */
        start local 6 // org.eclipse.core.internal.jobs.LockManager$LockState[] suspended
        17: .line 158
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        18: goto 21
        19: .line 159
      StackMap locals: org.eclipse.core.runtime.jobs.ISchedulingRule[] org.eclipse.core.internal.jobs.LockManager$LockState[] int
      StackMap stack:
            aload 6 /* suspended */
            iload 7 /* i */
            aload 5 /* toSuspend */
            iload 7 /* i */
            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: .line 158
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        21: iload 7 /* i */
            aload 5 /* toSuspend */
            arraylength
            if_icmplt 19
        end local 7 // int i
        22: .line 160
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
            dup
            astore 7
            monitorenter
        23: .line 161
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
            aload 4 /* found */
            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 /* suspended */
            invokevirtual java.util.ArrayDeque.push:(Ljava/lang/Object;)V
        24: .line 160
            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 // org.eclipse.core.internal.jobs.LockManager$LockState[] suspended
        end local 5 // org.eclipse.core.runtime.jobs.ISchedulingRule[] toSuspend
        end local 4 // org.eclipse.core.internal.jobs.Deadlock found
        28: .line 163
      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 /* e */
        start local 4 // java.lang.Exception e
        29: .line 164
            aload 0 /* this */
            aload 4 /* e */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.handleInternalError:(Ljava/lang/Throwable;)V
        end local 4 // java.lang.Exception e
        30: .line 166
      StackMap locals:
      StackMap stack:
            return
        end local 3 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
        end local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule lock
        end local 1 // java.lang.Thread thread
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
        start local 1 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
        start local 2 // java.lang.Exception rootException
         0: .line 169
            aconst_null
            astore 3 /* debugString */
        start local 3 // java.lang.String debugString
         1: .line 171
            aload 1 /* tempLocks */
            invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.toDebugString:()Ljava/lang/String;
            astore 3 /* debugString */
         2: .line 172
            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: .line 175
      StackMap locals:
      StackMap stack:
            new java.lang.Exception
            dup
            aload 3 /* debugString */
            aload 2 /* rootException */
            invokespecial java.lang.Exception.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            areturn
        end local 3 // java.lang.String debugString
        end local 2 // java.lang.Exception rootException
        end local 1 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // java.lang.Throwable e
         0: .line 184
            aload 0 /* e */
            instanceof org.eclipse.core.runtime.CoreException
            ifeq 4
         1: .line 186
            new org.eclipse.core.runtime.MultiStatus
            dup
            ldc "org.eclipse.core.jobs"
            iconst_2
            ldc "LockManager.handleException"
            aload 0 /* e */
            invokespecial org.eclipse.core.runtime.MultiStatus.<init>:(Ljava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
            astore 1 /* status */
        start local 1 // org.eclipse.core.runtime.IStatus status
         2: .line 187
            aload 1 /* status */
            checkcast org.eclipse.core.runtime.MultiStatus
            aload 0 /* e */
            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: .line 188
            goto 5
        end local 1 // org.eclipse.core.runtime.IStatus status
         4: .line 189
      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 /* e */
            invokespecial org.eclipse.core.runtime.Status.<init>:(ILjava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
            astore 1 /* status */
        start local 1 // org.eclipse.core.runtime.IStatus status
         5: .line 191
      StackMap locals: org.eclipse.core.runtime.IStatus
      StackMap stack:
            aload 1 /* status */
            invokestatic org.eclipse.core.internal.runtime.RuntimeLog.log:(Lorg/eclipse/core/runtime/IStatus;)V
         6: .line 192
            return
        end local 1 // org.eclipse.core.runtime.IStatus status
        end local 0 // java.lang.Throwable e
      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 // org.eclipse.core.internal.jobs.LockManager this
        start local 1 // java.lang.Throwable t
         0: .line 201
            aload 1 /* t */
            invokestatic org.eclipse.core.internal.jobs.LockManager.handleException:(Ljava/lang/Throwable;)V
         1: .line 202
            goto 3
      StackMap locals:
      StackMap stack: java.lang.Exception
         2: pop
         3: .line 206
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
         4: .line 207
            return
        end local 1 // java.lang.Throwable t
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
         0: .line 214
            aload 0 /* this */
            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 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
         0: .line 223
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            astore 1 /* current */
        start local 1 // java.lang.Thread current
         1: .line 224
            aload 1 /* current */
            instanceof org.eclipse.core.internal.jobs.Worker
            ifeq 3
         2: .line 225
            iconst_1
            ireturn
         3: .line 226
      StackMap locals: java.lang.Thread
      StackMap stack:
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
            astore 2 /* tempLocks */
        start local 2 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
         4: .line 227
            aload 2 /* tempLocks */
            ifnonnull 6
         5: .line 228
            iconst_0
            ireturn
         6: .line 229
      StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
      StackMap stack:
            aload 2 /* tempLocks */
            dup
            astore 3
            monitorenter
         7: .line 230
            aload 2 /* tempLocks */
            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: .line 229
      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 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
        end local 1 // java.lang.Thread current
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
         0: .line 238
            new org.eclipse.core.internal.jobs.OrderedLock
            dup
            aload 0 /* this */
            invokespecial org.eclipse.core.internal.jobs.OrderedLock.<init>:(Lorg/eclipse/core/internal/jobs/LockManager;)V
            areturn
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
        start local 1 // java.lang.Thread thread
        start local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule rule
         0: .line 245
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
            astore 3 /* tempLocks */
        start local 3 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
         1: .line 246
            aload 3 /* tempLocks */
            ifnonnull 3
         2: .line 247
            return
         3: .line 249
      StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
      StackMap stack:
            aload 3 /* tempLocks */
            dup
            astore 4
            monitorenter
         4: .line 251
            aload 3 /* tempLocks */
            aload 1 /* thread */
            aload 2 /* rule */
            invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.lockReleasedCompletely:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
         5: .line 252
            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 /* e */
        start local 5 // java.lang.Exception e
         7: .line 253
            aload 0 /* this */
            aload 3 /* tempLocks */
            aload 5 /* e */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.createDebugException:(Lorg/eclipse/core/internal/jobs/DeadlockDetector;Ljava/lang/Exception;)Ljava/lang/Exception;
            athrow
        end local 5 // java.lang.Exception e
         8: .line 249
      StackMap locals:
      StackMap stack:
            aload 4
            monitorexit
         9: goto 14
      StackMap locals:
      StackMap stack: java.lang.Throwable
        10: aload 4
            monitorexit
        11: athrow
        12: .line 256
      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 /* e */
        start local 4 // java.lang.Exception e
        13: .line 257
            aload 0 /* this */
            aload 4 /* e */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.handleInternalError:(Ljava/lang/Throwable;)V
        end local 4 // java.lang.Exception e
        14: .line 259
      StackMap locals:
      StackMap stack:
            return
        end local 3 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
        end local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule rule
        end local 1 // java.lang.Thread thread
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
        start local 1 // java.lang.Thread thread
        start local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule lock
         0: .line 265
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
            astore 3 /* tempLocks */
        start local 3 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
         1: .line 266
            aload 3 /* tempLocks */
            ifnonnull 3
         2: .line 267
            return
         3: .line 269
      StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
      StackMap stack:
            aload 3 /* tempLocks */
            dup
            astore 4
            monitorenter
         4: .line 271
            aload 3 /* tempLocks */
            aload 1 /* thread */
            aload 2 /* lock */
            invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.lockReleased:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
         5: .line 272
            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 /* e */
        start local 5 // java.lang.Exception e
         7: .line 273
            aload 0 /* this */
            aload 3 /* tempLocks */
            aload 5 /* e */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.createDebugException:(Lorg/eclipse/core/internal/jobs/DeadlockDetector;Ljava/lang/Exception;)Ljava/lang/Exception;
            athrow
        end local 5 // java.lang.Exception e
         8: .line 269
      StackMap locals:
      StackMap stack:
            aload 4
            monitorexit
         9: goto 14
      StackMap locals:
      StackMap stack: java.lang.Throwable
        10: aload 4
            monitorexit
        11: athrow
        12: .line 276
      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 /* e */
        start local 4 // java.lang.Exception e
        13: .line 277
            aload 0 /* this */
            aload 4 /* e */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.handleInternalError:(Ljava/lang/Throwable;)V
        end local 4 // java.lang.Exception e
        14: .line 279
      StackMap locals:
      StackMap stack:
            return
        end local 3 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
        end local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule lock
        end local 1 // java.lang.Thread thread
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
        start local 1 // java.lang.Thread thread
        start local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule lock
         0: .line 287
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.locks:Lorg/eclipse/core/internal/jobs/DeadlockDetector;
            astore 3 /* tempLocks */
        start local 3 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
         1: .line 288
            aload 3 /* tempLocks */
            ifnonnull 3
         2: .line 289
            return
         3: .line 291
      StackMap locals: org.eclipse.core.internal.jobs.DeadlockDetector
      StackMap stack:
            aload 3 /* tempLocks */
            dup
            astore 4
            monitorenter
         4: .line 293
            aload 3 /* tempLocks */
            aload 1 /* thread */
            aload 2 /* lock */
            invokevirtual org.eclipse.core.internal.jobs.DeadlockDetector.lockWaitStop:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
         5: .line 294
            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 /* e */
        start local 5 // java.lang.Exception e
         7: .line 295
            aload 0 /* this */
            aload 3 /* tempLocks */
            aload 5 /* e */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.createDebugException:(Lorg/eclipse/core/internal/jobs/DeadlockDetector;Ljava/lang/Exception;)Ljava/lang/Exception;
            athrow
        end local 5 // java.lang.Exception e
         8: .line 291
      StackMap locals:
      StackMap stack:
            aload 4
            monitorexit
         9: goto 14
      StackMap locals:
      StackMap stack: java.lang.Throwable
        10: aload 4
            monitorexit
        11: athrow
        12: .line 298
      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 /* e */
        start local 4 // java.lang.Exception e
        13: .line 299
            aload 0 /* this */
            aload 4 /* e */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.handleInternalError:(Ljava/lang/Throwable;)V
        end local 4 // java.lang.Exception e
        14: .line 301
      StackMap locals:
      StackMap stack:
            return
        end local 3 // org.eclipse.core.internal.jobs.DeadlockDetector tempLocks
        end local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule lock
        end local 1 // java.lang.Thread thread
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
        start local 1 // java.lang.Thread owner
         0: .line 308
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
            dup
            astore 3
            monitorenter
         1: .line 309
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
            aload 1 /* owner */
            invokevirtual java.util.HashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.ArrayDeque
            astore 4 /* prevLocks */
        start local 4 // java.util.ArrayDeque prevLocks
         2: .line 310
            aload 4 /* prevLocks */
            ifnonnull 5
         3: .line 311
            aload 3
            monitorexit
         4: return
         5: .line 312
      StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread top java.util.HashMap java.util.ArrayDeque
      StackMap stack:
            aload 4 /* prevLocks */
            invokevirtual java.util.ArrayDeque.pop:()Ljava/lang/Object;
            checkcast org.eclipse.core.internal.jobs.LockManager$LockState[]
            astore 2 /* toResume */
        start local 2 // org.eclipse.core.internal.jobs.LockManager$LockState[] toResume
         6: .line 313
            aload 4 /* prevLocks */
            invokevirtual java.util.ArrayDeque.isEmpty:()Z
            ifeq 8
         7: .line 314
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.LockManager.suspendedLocks:Ljava/util/HashMap;
            aload 1 /* owner */
            invokevirtual java.util.HashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 4 // java.util.ArrayDeque prevLocks
         8: .line 308
      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 // org.eclipse.core.internal.jobs.LockManager$LockState[] toResume
      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 // org.eclipse.core.internal.jobs.LockManager$LockState[] toResume
        12: .line 316
      StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread org.eclipse.core.internal.jobs.LockManager$LockState[]
      StackMap stack:
            aload 2 /* toResume */
            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 /* element */
        start local 3 // org.eclipse.core.internal.jobs.LockManager$LockState element
        14: .line 317
            aload 3 /* element */
            invokevirtual org.eclipse.core.internal.jobs.LockManager$LockState.resume:()V
        end local 3 // org.eclipse.core.internal.jobs.LockManager$LockState element
        15: .line 316
            iinc 4 1
      StackMap locals:
      StackMap stack:
        16: iload 4
            iload 5
            if_icmplt 13
        17: .line 318
            return
        end local 2 // org.eclipse.core.internal.jobs.LockManager$LockState[] toResume
        end local 1 // java.lang.Thread owner
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // org.eclipse.core.internal.jobs.LockManager this
        start local 1 // org.eclipse.core.runtime.jobs.LockListener listener
         0: .line 321
            aload 0 /* this */
            aload 1 /* listener */
            putfield org.eclipse.core.internal.jobs.LockManager.lockListener:Lorg/eclipse/core/runtime/jobs/LockListener;
         1: .line 322
            return
        end local 1 // org.eclipse.core.runtime.jobs.LockListener listener
        end local 0 // org.eclipse.core.internal.jobs.LockManager this
      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 // java.lang.Thread key
         0: .line 161
            new java.util.ArrayDeque
            dup
            invokespecial java.util.ArrayDeque.<init>:()V
            areturn
        end local 0 // java.lang.Thread key
      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