class org.eclipse.core.internal.jobs.ThreadJob extends org.eclipse.core.runtime.jobs.Job
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.eclipse.core.internal.jobs.ThreadJob
  super_class: org.eclipse.core.runtime.jobs.Job
{
  protected boolean acquireRule;
    descriptor: Z
    flags: (0x0004) ACC_PROTECTED

  boolean isBlocked;
    descriptor: Z
    flags: (0x0000) 

  protected boolean isRunning;
    descriptor: Z
    flags: (0x0004) ACC_PROTECTED

  private java.lang.RuntimeException lastPush;
    descriptor: Ljava/lang/RuntimeException;
    flags: (0x0002) ACC_PRIVATE

  protected org.eclipse.core.runtime.jobs.Job realJob;
    descriptor: Lorg/eclipse/core/runtime/jobs/Job;
    flags: (0x0004) ACC_PROTECTED

  private org.eclipse.core.runtime.jobs.ISchedulingRule[] ruleStack;
    descriptor: [Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
    flags: (0x0002) ACC_PRIVATE

  private int top;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  boolean isWaiting;
    descriptor: Z
    flags: (0x0000) 

  void <init>(org.eclipse.core.runtime.jobs.ISchedulingRule);
    descriptor: (Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
        start local 1 // org.eclipse.core.runtime.jobs.ISchedulingRule rule
         0: .line 78
            aload 0 /* this */
            ldc "Implicit Job"
            invokespecial org.eclipse.core.runtime.jobs.Job.<init>:(Ljava/lang/String;)V
         1: .line 30
            aload 0 /* this */
            iconst_0
            putfield org.eclipse.core.internal.jobs.ThreadJob.acquireRule:Z
         2: .line 37
            aload 0 /* this */
            iconst_0
            putfield org.eclipse.core.internal.jobs.ThreadJob.isBlocked:Z
         3: .line 43
            aload 0 /* this */
            iconst_0
            putfield org.eclipse.core.internal.jobs.ThreadJob.isRunning:Z
         4: .line 50
            aload 0 /* this */
            aconst_null
            putfield org.eclipse.core.internal.jobs.ThreadJob.lastPush:Ljava/lang/RuntimeException;
         5: .line 79
            aload 0 /* this */
            iconst_1
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.setSystem:(Z)V
         6: .line 83
            aload 0 /* this */
            bipush 10
            invokevirtual org.eclipse.core.internal.jobs.InternalJob.internalSetPriority:(I)V
         7: .line 84
            aload 0 /* this */
            iconst_2
            anewarray org.eclipse.core.runtime.jobs.ISchedulingRule
            putfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
         8: .line 85
            aload 0 /* this */
            iconst_m1
            putfield org.eclipse.core.internal.jobs.ThreadJob.top:I
         9: .line 86
            aload 0 /* this */
            aload 1 /* rule */
            invokevirtual org.eclipse.core.internal.jobs.InternalJob.internalSetRule:(Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
        10: .line 87
            return
        end local 1 // org.eclipse.core.runtime.jobs.ISchedulingRule rule
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lorg/eclipse/core/internal/jobs/ThreadJob;
            0   11     1  rule  Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
    MethodParameters:
      Name  Flags
      rule  

  boolean isResumingAfterYield();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
         0: .line 90
            iconst_0
            ireturn
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/eclipse/core/internal/jobs/ThreadJob;

  private void illegalPop(org.eclipse.core.runtime.jobs.ISchedulingRule);
    descriptor: (Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=6, args_size=2
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
        start local 1 // org.eclipse.core.runtime.jobs.ISchedulingRule rule
         0: .line 100
            new java.lang.StringBuilder
            dup
            ldc "Attempted to endRule: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            astore 2 /* buf */
        start local 2 // java.lang.StringBuilder buf
         1: .line 101
            aload 2 /* buf */
            aload 1 /* rule */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
         2: .line 102
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            iflt 6
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            arraylength
            if_icmpge 6
         3: .line 103
            aload 2 /* buf */
            ldc ", does not match most recent begin: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         4: .line 104
            aload 2 /* buf */
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
         5: .line 105
            goto 9
         6: .line 106
      StackMap locals: java.lang.StringBuilder
      StackMap stack:
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            ifge 8
         7: .line 107
            aload 2 /* buf */
            ldc ", but there was no matching beginRule"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
            goto 9
         8: .line 109
      StackMap locals:
      StackMap stack:
            aload 2 /* buf */
            new java.lang.StringBuilder
            dup
            ldc ", but the rule stack was out of bounds: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         9: .line 111
      StackMap locals:
      StackMap stack:
            aload 2 /* buf */
            ldc ".  See log for trace information if rule tracing is enabled."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        10: .line 112
            aload 2 /* buf */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* msg */
        start local 3 // java.lang.String msg
        11: .line 113
            getstatic org.eclipse.core.internal.jobs.JobManager.DEBUG:Z
            ifne 12
            getstatic org.eclipse.core.internal.jobs.JobManager.DEBUG_BEGIN_END:Z
            ifeq 18
        12: .line 114
      StackMap locals: java.lang.String
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 3 /* msg */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        13: .line 115
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.lastPush:Ljava/lang/RuntimeException;
            ifnonnull 14
            new java.lang.IllegalArgumentException
            dup
            invokespecial java.lang.IllegalArgumentException.<init>:()V
            goto 15
      StackMap locals:
      StackMap stack:
        14: aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.lastPush:Ljava/lang/RuntimeException;
      StackMap locals:
      StackMap stack: java.lang.RuntimeException
        15: astore 4 /* t */
        start local 4 // java.lang.Throwable t
        16: .line 116
            new org.eclipse.core.runtime.Status
            dup
            iconst_4
            ldc "org.eclipse.core.jobs"
            iconst_1
            aload 3 /* msg */
            aload 4 /* t */
            invokespecial org.eclipse.core.runtime.Status.<init>:(ILjava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
            astore 5 /* error */
        start local 5 // org.eclipse.core.runtime.IStatus error
        17: .line 117
            aload 5 /* error */
            invokestatic org.eclipse.core.internal.runtime.RuntimeLog.log:(Lorg/eclipse/core/runtime/IStatus;)V
        end local 5 // org.eclipse.core.runtime.IStatus error
        end local 4 // java.lang.Throwable t
        18: .line 119
      StackMap locals:
      StackMap stack:
            iconst_0
            aload 3 /* msg */
            invokestatic org.eclipse.core.runtime.Assert.isLegal:(ZLjava/lang/String;)Z
            pop
        19: .line 120
            return
        end local 3 // java.lang.String msg
        end local 2 // java.lang.StringBuilder buf
        end local 1 // org.eclipse.core.runtime.jobs.ISchedulingRule rule
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   20     0   this  Lorg/eclipse/core/internal/jobs/ThreadJob;
            0   20     1   rule  Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            1   20     2    buf  Ljava/lang/StringBuilder;
           11   20     3    msg  Ljava/lang/String;
           16   18     4      t  Ljava/lang/Throwable;
           17   18     5  error  Lorg/eclipse/core/runtime/IStatus;
    MethodParameters:
      Name  Flags
      rule  

  private void illegalPush(org.eclipse.core.runtime.jobs.ISchedulingRule, org.eclipse.core.runtime.jobs.ISchedulingRule);
    descriptor: (Lorg/eclipse/core/runtime/jobs/ISchedulingRule;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=8, locals=6, args_size=3
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
        start local 1 // org.eclipse.core.runtime.jobs.ISchedulingRule pushRule
        start local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule baseRule
         0: .line 127
            new java.lang.StringBuilder
            dup
            ldc "Attempted to beginRule: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            astore 3 /* buf */
        start local 3 // java.lang.StringBuilder buf
         1: .line 128
            aload 3 /* buf */
            aload 1 /* pushRule */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
         2: .line 129
            aload 3 /* buf */
            ldc ", does not match outer scope rule: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         3: .line 130
            aload 3 /* buf */
            aload 2 /* baseRule */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
         4: .line 131
            aload 3 /* buf */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 4 /* msg */
        start local 4 // java.lang.String msg
         5: .line 132
            getstatic org.eclipse.core.internal.jobs.JobManager.DEBUG:Z
            ifeq 9
         6: .line 133
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 4 /* msg */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         7: .line 134
            new org.eclipse.core.runtime.Status
            dup
            iconst_4
            ldc "org.eclipse.core.jobs"
            iconst_1
            aload 4 /* msg */
            new java.lang.IllegalArgumentException
            dup
            invokespecial java.lang.IllegalArgumentException.<init>:()V
            invokespecial org.eclipse.core.runtime.Status.<init>:(ILjava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
            astore 5 /* error */
        start local 5 // org.eclipse.core.runtime.IStatus error
         8: .line 135
            aload 5 /* error */
            invokestatic org.eclipse.core.internal.runtime.RuntimeLog.log:(Lorg/eclipse/core/runtime/IStatus;)V
        end local 5 // org.eclipse.core.runtime.IStatus error
         9: .line 137
      StackMap locals: java.lang.StringBuilder java.lang.String
      StackMap stack:
            iconst_0
            aload 4 /* msg */
            invokestatic org.eclipse.core.runtime.Assert.isLegal:(ZLjava/lang/String;)Z
            pop
        10: .line 139
            return
        end local 4 // java.lang.String msg
        end local 3 // java.lang.StringBuilder buf
        end local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule baseRule
        end local 1 // org.eclipse.core.runtime.jobs.ISchedulingRule pushRule
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   11     0      this  Lorg/eclipse/core/internal/jobs/ThreadJob;
            0   11     1  pushRule  Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            0   11     2  baseRule  Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            1   11     3       buf  Ljava/lang/StringBuilder;
            5   11     4       msg  Ljava/lang/String;
            8    9     5     error  Lorg/eclipse/core/runtime/IStatus;
    MethodParameters:
          Name  Flags
      pushRule  
      baseRule  

  private static boolean isCanceled(org.eclipse.core.runtime.IProgressMonitor);
    descriptor: (Lorg/eclipse/core/runtime/IProgressMonitor;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=3, args_size=1
        start local 0 // org.eclipse.core.runtime.IProgressMonitor monitor
         0: .line 147
            aload 0 /* monitor */
            invokeinterface org.eclipse.core.runtime.IProgressMonitor.isCanceled:()Z
         1: ireturn
         2: .line 148
      StackMap locals:
      StackMap stack: java.lang.RuntimeException
            astore 1 /* e */
        start local 1 // java.lang.RuntimeException e
         3: .line 150
            new org.eclipse.core.runtime.Status
            dup
            iconst_4
            ldc "org.eclipse.core.jobs"
            iconst_2
            ldc "ThreadJob.isCanceled"
            aload 1 /* e */
            invokespecial org.eclipse.core.runtime.Status.<init>:(ILjava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
            astore 2 /* status */
        start local 2 // org.eclipse.core.runtime.IStatus status
         4: .line 151
            aload 2 /* status */
            invokestatic org.eclipse.core.internal.runtime.RuntimeLog.log:(Lorg/eclipse/core/runtime/IStatus;)V
        end local 2 // org.eclipse.core.runtime.IStatus status
        end local 1 // java.lang.RuntimeException e
         5: .line 153
            iconst_0
            ireturn
        end local 0 // org.eclipse.core.runtime.IProgressMonitor monitor
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0  monitor  Lorg/eclipse/core/runtime/IProgressMonitor;
            3    5     1        e  Ljava/lang/RuntimeException;
            4    5     2   status  Lorg/eclipse/core/runtime/IStatus;
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.RuntimeException
    MethodParameters:
         Name  Flags
      monitor  

  synchronized boolean isRunning();
    descriptor: ()Z
    flags: (0x0020) ACC_SYNCHRONIZED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
         0: .line 161
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.isRunning:Z
            ireturn
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/eclipse/core/internal/jobs/ThreadJob;

  static org.eclipse.core.internal.jobs.ThreadJob joinRun(org.eclipse.core.internal.jobs.ThreadJob, org.eclipse.core.runtime.IProgressMonitor);
    descriptor: (Lorg/eclipse/core/internal/jobs/ThreadJob;Lorg/eclipse/core/runtime/IProgressMonitor;)Lorg/eclipse/core/internal/jobs/ThreadJob;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=8, args_size=2
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob threadJob
        start local 1 // org.eclipse.core.runtime.IProgressMonitor monitor
         0: .line 194
            aload 1 /* monitor */
            invokestatic org.eclipse.core.internal.jobs.ThreadJob.isCanceled:(Lorg/eclipse/core/runtime/IProgressMonitor;)Z
            ifeq 2
         1: .line 195
            new org.eclipse.core.runtime.OperationCanceledException
            dup
            invokespecial org.eclipse.core.runtime.OperationCanceledException.<init>:()V
            athrow
         2: .line 197
      StackMap locals:
      StackMap stack:
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.JobManager.findBlockingJob:(Lorg/eclipse/core/internal/jobs/InternalJob;)Lorg/eclipse/core/internal/jobs/InternalJob;
            astore 2 /* blockingJob */
        start local 2 // org.eclipse.core.internal.jobs.InternalJob blockingJob
         3: .line 198
            aload 2 /* blockingJob */
            ifnonnull 4
            aconst_null
            goto 5
      StackMap locals: org.eclipse.core.internal.jobs.InternalJob
      StackMap stack:
         4: aload 2 /* blockingJob */
            invokevirtual org.eclipse.core.internal.jobs.InternalJob.getThread:()Ljava/lang/Thread;
      StackMap locals:
      StackMap stack: java.lang.Thread
         5: astore 3 /* blocker */
        start local 3 // java.lang.Thread blocker
         6: .line 203
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            invokevirtual org.eclipse.core.internal.jobs.JobManager.getLockManager:()Lorg/eclipse/core/internal/jobs/LockManager;
            aload 3 /* blocker */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.aboutToWait:(Ljava/lang/Thread;)Z
            ifeq 11
         7: .line 204
            aload 0 /* threadJob */
            astore 7
         8: .line 212
            invokestatic java.lang.Thread.interrupted:()Z
            istore 5 /* interruptedDuringWaitForRun */
        start local 5 // boolean interruptedDuringWaitForRun
         9: .line 213
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            invokevirtual org.eclipse.core.internal.jobs.JobManager.getLockManager:()Lorg/eclipse/core/internal/jobs/LockManager;
            invokevirtual org.eclipse.core.internal.jobs.LockManager.aboutToRelease:()V
        10: .line 204
            aload 7
            areturn
        end local 5 // boolean interruptedDuringWaitForRun
        11: .line 205
      StackMap locals: java.lang.Thread
      StackMap stack:
            aload 0 /* threadJob */
            aload 1 /* monitor */
            aload 2 /* blockingJob */
            invokestatic org.eclipse.core.internal.jobs.ThreadJob.waitForRun:(Lorg/eclipse/core/internal/jobs/ThreadJob;Lorg/eclipse/core/runtime/IProgressMonitor;Lorg/eclipse/core/internal/jobs/InternalJob;)Lorg/eclipse/core/internal/jobs/ThreadJob;
            astore 4 /* result */
        start local 4 // org.eclipse.core.internal.jobs.ThreadJob result
        12: .line 206
            goto 17
        end local 4 // org.eclipse.core.internal.jobs.ThreadJob result
      StackMap locals:
      StackMap stack: java.lang.Throwable
        13: astore 6
        14: .line 212
            invokestatic java.lang.Thread.interrupted:()Z
            istore 5 /* interruptedDuringWaitForRun */
        start local 5 // boolean interruptedDuringWaitForRun
        15: .line 213
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            invokevirtual org.eclipse.core.internal.jobs.JobManager.getLockManager:()Lorg/eclipse/core/internal/jobs/LockManager;
            invokevirtual org.eclipse.core.internal.jobs.LockManager.aboutToRelease:()V
        16: .line 214
            aload 6
            athrow
        end local 5 // boolean interruptedDuringWaitForRun
        start local 4 // org.eclipse.core.internal.jobs.ThreadJob result
        17: .line 212
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob
      StackMap stack:
            invokestatic java.lang.Thread.interrupted:()Z
            istore 5 /* interruptedDuringWaitForRun */
        start local 5 // boolean interruptedDuringWaitForRun
        18: .line 213
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            invokevirtual org.eclipse.core.internal.jobs.JobManager.getLockManager:()Lorg/eclipse/core/internal/jobs/LockManager;
            invokevirtual org.eclipse.core.internal.jobs.LockManager.aboutToRelease:()V
        19: .line 219
            iload 5 /* interruptedDuringWaitForRun */
            ifeq 21
        20: .line 220
            new org.eclipse.core.runtime.OperationCanceledException
            dup
            invokespecial org.eclipse.core.runtime.OperationCanceledException.<init>:()V
            athrow
        21: .line 222
      StackMap locals: int
      StackMap stack:
            aload 4 /* result */
            areturn
        end local 5 // boolean interruptedDuringWaitForRun
        end local 4 // org.eclipse.core.internal.jobs.ThreadJob result
        end local 3 // java.lang.Thread blocker
        end local 2 // org.eclipse.core.internal.jobs.InternalJob blockingJob
        end local 1 // org.eclipse.core.runtime.IProgressMonitor monitor
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob threadJob
      LocalVariableTable:
        Start  End  Slot                         Name  Signature
            0   22     0                    threadJob  Lorg/eclipse/core/internal/jobs/ThreadJob;
            0   22     1                      monitor  Lorg/eclipse/core/runtime/IProgressMonitor;
            3   22     2                  blockingJob  Lorg/eclipse/core/internal/jobs/InternalJob;
            6   22     3                      blocker  Ljava/lang/Thread;
           12   13     4                       result  Lorg/eclipse/core/internal/jobs/ThreadJob;
           17   22     4                       result  Lorg/eclipse/core/internal/jobs/ThreadJob;
            9   11     5  interruptedDuringWaitForRun  Z
           15   17     5  interruptedDuringWaitForRun  Z
           18   22     5  interruptedDuringWaitForRun  Z
      Exception table:
        from    to  target  type
           6     8      13  any
          11    13      13  any
    MethodParameters:
           Name  Flags
      threadJob  
      monitor    

  private static org.eclipse.core.internal.jobs.ThreadJob waitForRun(org.eclipse.core.internal.jobs.ThreadJob, org.eclipse.core.runtime.IProgressMonitor, org.eclipse.core.internal.jobs.InternalJob);
    descriptor: (Lorg/eclipse/core/internal/jobs/ThreadJob;Lorg/eclipse/core/runtime/IProgressMonitor;Lorg/eclipse/core/internal/jobs/InternalJob;)Lorg/eclipse/core/internal/jobs/ThreadJob;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=16, args_size=3
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob threadJob
        start local 1 // org.eclipse.core.runtime.IProgressMonitor monitor
        start local 2 // org.eclipse.core.internal.jobs.InternalJob blockingJob
         0: .line 247
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            invokevirtual org.eclipse.core.internal.jobs.JobManager.getLockManager:()Lorg/eclipse/core/internal/jobs/LockManager;
            invokevirtual org.eclipse.core.internal.jobs.LockManager.canBlock:()Z
            istore 3 /* canBlock */
        start local 3 // boolean canBlock
         1: .line 248
            aload 0 /* threadJob */
            astore 4 /* result */
        start local 4 // org.eclipse.core.internal.jobs.ThreadJob result
         2: .line 249
            iconst_0
            istore 5 /* interrupted */
        start local 5 // boolean interrupted
         3: .line 250
            iconst_0
            istore 6 /* waiting */
        start local 6 // boolean waiting
         4: .line 251
            iconst_0
            istore 7 /* ruleCompatibleAndTransferred */
        start local 7 // boolean ruleCompatibleAndTransferred
         5: .line 253
            aload 0 /* threadJob */
            aload 1 /* monitor */
            aload 2 /* blockingJob */
            invokestatic org.eclipse.core.internal.jobs.ThreadJob.waitStart:(Lorg/eclipse/core/internal/jobs/ThreadJob;Lorg/eclipse/core/runtime/IProgressMonitor;Lorg/eclipse/core/internal/jobs/InternalJob;)V
         6: .line 254
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            getfield org.eclipse.core.internal.jobs.JobManager.implicitJobs:Lorg/eclipse/core/internal/jobs/ImplicitJobs;
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.ImplicitJobs.addWaiting:(Lorg/eclipse/core/internal/jobs/ThreadJob;)V
         7: .line 255
            iconst_1
            istore 6 /* waiting */
         8: .line 260
            iload 3 /* canBlock */
            ifeq 10
         9: .line 261
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            aload 0 /* threadJob */
            aload 1 /* monitor */
            invokevirtual org.eclipse.core.internal.jobs.JobManager.beginMonitoring:(Lorg/eclipse/core/internal/jobs/ThreadJob;Lorg/eclipse/core/runtime/IProgressMonitor;)V
        10: .line 262
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int
      StackMap stack:
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            astore 8 /* currentThread */
        start local 8 // java.lang.Thread currentThread
        11: .line 276
      StackMap locals: java.lang.Thread
      StackMap stack:
            iload 5 /* interrupted */
            ifne 12
            aload 1 /* monitor */
            invokestatic org.eclipse.core.internal.jobs.ThreadJob.isCanceled:(Lorg/eclipse/core/runtime/IProgressMonitor;)Z
            ifeq 13
        12: .line 278
      StackMap locals:
      StackMap stack:
            new org.eclipse.core.runtime.OperationCanceledException
            dup
            invokespecial org.eclipse.core.runtime.OperationCanceledException.<init>:()V
            athrow
        13: .line 282
      StackMap locals:
      StackMap stack:
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            aload 0 /* threadJob */
            iconst_1
            invokevirtual org.eclipse.core.internal.jobs.JobManager.runNow:(Lorg/eclipse/core/internal/jobs/ThreadJob;Z)Lorg/eclipse/core/internal/jobs/InternalJob;
            astore 2 /* blockingJob */
        14: .line 283
            aload 2 /* blockingJob */
            ifnonnull 30
        15: .line 285
            iconst_0
            istore 6 /* waiting */
        16: .line 286
            aload 0 /* threadJob */
            astore 13
        17: .line 337
            aload 0 /* threadJob */
            aload 4 /* result */
            if_acmpeq 21
        18: .line 341
            iload 7 /* ruleCompatibleAndTransferred */
            istore 14 /* canStopWaiting */
        start local 14 // boolean canStopWaiting
        19: .line 343
            iconst_0
            istore 15 /* updateLockState */
        start local 15 // boolean updateLockState
        20: .line 344
            goto 23
        end local 15 // boolean updateLockState
        end local 14 // boolean canStopWaiting
        21: .line 346
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int java.lang.Thread top top top top org.eclipse.core.internal.jobs.ThreadJob
      StackMap stack:
            iconst_1
            istore 14 /* canStopWaiting */
        start local 14 // boolean canStopWaiting
        22: .line 348
            iconst_1
            istore 15 /* updateLockState */
        start local 15 // boolean updateLockState
        23: .line 350
      StackMap locals: int int
      StackMap stack:
            aload 0 /* threadJob */
            iload 15 /* updateLockState */
            aload 1 /* monitor */
            invokestatic org.eclipse.core.internal.jobs.ThreadJob.waitEnd:(Lorg/eclipse/core/internal/jobs/ThreadJob;ZLorg/eclipse/core/runtime/IProgressMonitor;)V
        24: .line 351
            iload 14 /* canStopWaiting */
            ifeq 27
        25: .line 352
            iload 6 /* waiting */
            ifeq 27
        26: .line 353
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            getfield org.eclipse.core.internal.jobs.JobManager.implicitJobs:Lorg/eclipse/core/internal/jobs/ImplicitJobs;
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.ImplicitJobs.removeWaiting:(Lorg/eclipse/core/internal/jobs/ThreadJob;)V
        27: .line 355
      StackMap locals:
      StackMap stack:
            iload 3 /* canBlock */
            ifeq 29
        28: .line 357
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.JobManager.endMonitoring:(Lorg/eclipse/core/internal/jobs/ThreadJob;)V
        end local 15 // boolean updateLockState
        end local 14 // boolean canStopWaiting
        29: .line 286
      StackMap locals:
      StackMap stack:
            aload 13
            areturn
        30: .line 288
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int java.lang.Thread
      StackMap stack:
            aload 2 /* blockingJob */
            invokevirtual org.eclipse.core.internal.jobs.InternalJob.getThread:()Ljava/lang/Thread;
            astore 9 /* blocker */
        start local 9 // java.lang.Thread blocker
        31: .line 290
            aload 9 /* blocker */
            aload 8 /* currentThread */
            if_acmpne 50
            aload 2 /* blockingJob */
            instanceof org.eclipse.core.internal.jobs.ThreadJob
            ifeq 50
        32: .line 292
            aload 2 /* blockingJob */
            checkcast org.eclipse.core.internal.jobs.ThreadJob
            astore 4 /* result */
        33: .line 294
            aload 4 /* result */
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.getRule:()Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.push:(Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
        34: .line 296
            iconst_1
            istore 7 /* ruleCompatibleAndTransferred */
        35: .line 297
            aload 4 /* result */
            aload 0 /* threadJob */
            getfield org.eclipse.core.internal.jobs.ThreadJob.isBlocked:Z
            putfield org.eclipse.core.internal.jobs.ThreadJob.isBlocked:Z
        36: .line 299
            aload 4 /* result */
            astore 13
        37: .line 337
            aload 0 /* threadJob */
            aload 4 /* result */
            if_acmpeq 41
        38: .line 341
            iload 7 /* ruleCompatibleAndTransferred */
            istore 14 /* canStopWaiting */
        start local 14 // boolean canStopWaiting
        39: .line 343
            iconst_0
            istore 15 /* updateLockState */
        start local 15 // boolean updateLockState
        40: .line 344
            goto 43
        end local 15 // boolean updateLockState
        end local 14 // boolean canStopWaiting
        41: .line 346
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int java.lang.Thread java.lang.Thread top top top org.eclipse.core.internal.jobs.ThreadJob
      StackMap stack:
            iconst_1
            istore 14 /* canStopWaiting */
        start local 14 // boolean canStopWaiting
        42: .line 348
            iconst_1
            istore 15 /* updateLockState */
        start local 15 // boolean updateLockState
        43: .line 350
      StackMap locals: int int
      StackMap stack:
            aload 0 /* threadJob */
            iload 15 /* updateLockState */
            aload 1 /* monitor */
            invokestatic org.eclipse.core.internal.jobs.ThreadJob.waitEnd:(Lorg/eclipse/core/internal/jobs/ThreadJob;ZLorg/eclipse/core/runtime/IProgressMonitor;)V
        44: .line 351
            iload 14 /* canStopWaiting */
            ifeq 47
        45: .line 352
            iload 6 /* waiting */
            ifeq 47
        46: .line 353
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            getfield org.eclipse.core.internal.jobs.JobManager.implicitJobs:Lorg/eclipse/core/internal/jobs/ImplicitJobs;
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.ImplicitJobs.removeWaiting:(Lorg/eclipse/core/internal/jobs/ThreadJob;)V
        47: .line 355
      StackMap locals:
      StackMap stack:
            iload 3 /* canBlock */
            ifeq 49
        48: .line 357
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.JobManager.endMonitoring:(Lorg/eclipse/core/internal/jobs/ThreadJob;)V
        end local 15 // boolean updateLockState
        end local 14 // boolean canStopWaiting
        49: .line 299
      StackMap locals:
      StackMap stack:
            aload 13
            areturn
        50: .line 302
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int java.lang.Thread java.lang.Thread
      StackMap stack:
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            invokevirtual org.eclipse.core.internal.jobs.JobManager.getLockManager:()Lorg/eclipse/core/internal/jobs/LockManager;
            aload 9 /* blocker */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.aboutToWait:(Ljava/lang/Thread;)Z
            ifeq 65
        51: .line 304
            aload 0 /* threadJob */
            astore 13
        52: .line 337
            aload 0 /* threadJob */
            aload 4 /* result */
            if_acmpeq 56
        53: .line 341
            iload 7 /* ruleCompatibleAndTransferred */
            istore 14 /* canStopWaiting */
        start local 14 // boolean canStopWaiting
        54: .line 343
            iconst_0
            istore 15 /* updateLockState */
        start local 15 // boolean updateLockState
        55: .line 344
            goto 58
        end local 15 // boolean updateLockState
        end local 14 // boolean canStopWaiting
        56: .line 346
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int java.lang.Thread java.lang.Thread top top top org.eclipse.core.internal.jobs.ThreadJob
      StackMap stack:
            iconst_1
            istore 14 /* canStopWaiting */
        start local 14 // boolean canStopWaiting
        57: .line 348
            iconst_1
            istore 15 /* updateLockState */
        start local 15 // boolean updateLockState
        58: .line 350
      StackMap locals: int int
      StackMap stack:
            aload 0 /* threadJob */
            iload 15 /* updateLockState */
            aload 1 /* monitor */
            invokestatic org.eclipse.core.internal.jobs.ThreadJob.waitEnd:(Lorg/eclipse/core/internal/jobs/ThreadJob;ZLorg/eclipse/core/runtime/IProgressMonitor;)V
        59: .line 351
            iload 14 /* canStopWaiting */
            ifeq 62
        60: .line 352
            iload 6 /* waiting */
            ifeq 62
        61: .line 353
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            getfield org.eclipse.core.internal.jobs.JobManager.implicitJobs:Lorg/eclipse/core/internal/jobs/ImplicitJobs;
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.ImplicitJobs.removeWaiting:(Lorg/eclipse/core/internal/jobs/ThreadJob;)V
        62: .line 355
      StackMap locals:
      StackMap stack:
            iload 3 /* canBlock */
            ifeq 64
        63: .line 357
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.JobManager.endMonitoring:(Lorg/eclipse/core/internal/jobs/ThreadJob;)V
        end local 15 // boolean updateLockState
        end local 14 // boolean canStopWaiting
        64: .line 304
      StackMap locals:
      StackMap stack:
            aload 13
            areturn
        65: .line 307
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int java.lang.Thread java.lang.Thread
      StackMap stack:
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            invokevirtual org.eclipse.core.internal.jobs.JobManager.getLockManager:()Lorg/eclipse/core/internal/jobs/LockManager;
            aload 8 /* currentThread */
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.getRule:()Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            invokevirtual org.eclipse.core.internal.jobs.LockManager.addLockWaitThread:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
        66: .line 308
            aload 2 /* blockingJob */
            getfield org.eclipse.core.internal.jobs.InternalJob.jobStateLock:Ljava/lang/Object;
            dup
            astore 10
            monitorenter
        67: .line 313
            aload 2 /* blockingJob */
            invokevirtual org.eclipse.core.internal.jobs.InternalJob.getState:()I
            istore 11 /* state */
        start local 11 // int state
        68: .line 315
            iload 11 /* state */
            iconst_4
            if_icmpne 70
            iload 3 /* canBlock */
            ifeq 70
        69: .line 316
            aload 2 /* blockingJob */
            getfield org.eclipse.core.internal.jobs.InternalJob.jobStateLock:Ljava/lang/Object;
            invokevirtual java.lang.Object.wait:()V
            goto 75
        70: .line 317
      StackMap locals: java.lang.Object int
      StackMap stack:
            iload 11 /* state */
            ifeq 75
        71: .line 318
            aload 2 /* blockingJob */
            getfield org.eclipse.core.internal.jobs.InternalJob.jobStateLock:Ljava/lang/Object;
            ldc 250
            invokevirtual java.lang.Object.wait:(J)V
        end local 11 // int state
        72: .line 319
            goto 75
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int java.lang.Thread java.lang.Thread java.lang.Object
      StackMap stack: java.lang.InterruptedException
        73: pop
        74: .line 327
            iconst_1
            istore 5 /* interrupted */
        75: .line 308
      StackMap locals:
      StackMap stack:
            aload 10
            monitorexit
        76: goto 79
      StackMap locals:
      StackMap stack: java.lang.Throwable
        77: aload 10
            monitorexit
        78: athrow
        79: .line 332
      StackMap locals:
      StackMap stack:
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            invokevirtual org.eclipse.core.internal.jobs.JobManager.getLockManager:()Lorg/eclipse/core/internal/jobs/LockManager;
            aload 8 /* currentThread */
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.getRule:()Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            invokevirtual org.eclipse.core.internal.jobs.LockManager.removeLockWaitThread:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
        end local 9 // java.lang.Thread blocker
        80: .line 274
            goto 11
        end local 8 // java.lang.Thread currentThread
        81: .line 334
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int
      StackMap stack: java.lang.Throwable
            astore 12
        82: .line 337
            aload 0 /* threadJob */
            aload 4 /* result */
            if_acmpeq 86
        83: .line 341
            iload 7 /* ruleCompatibleAndTransferred */
            istore 14 /* canStopWaiting */
        start local 14 // boolean canStopWaiting
        84: .line 343
            iconst_0
            istore 15 /* updateLockState */
        start local 15 // boolean updateLockState
        85: .line 344
            goto 88
        end local 15 // boolean updateLockState
        end local 14 // boolean canStopWaiting
        86: .line 346
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int top top top top java.lang.Throwable
      StackMap stack:
            iconst_1
            istore 14 /* canStopWaiting */
        start local 14 // boolean canStopWaiting
        87: .line 348
            iconst_1
            istore 15 /* updateLockState */
        start local 15 // boolean updateLockState
        88: .line 350
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int top top top top java.lang.Throwable top int int
      StackMap stack:
            aload 0 /* threadJob */
            iload 15 /* updateLockState */
            aload 1 /* monitor */
            invokestatic org.eclipse.core.internal.jobs.ThreadJob.waitEnd:(Lorg/eclipse/core/internal/jobs/ThreadJob;ZLorg/eclipse/core/runtime/IProgressMonitor;)V
        89: .line 351
            iload 14 /* canStopWaiting */
            ifeq 92
        90: .line 352
            iload 6 /* waiting */
            ifeq 92
        91: .line 353
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            getfield org.eclipse.core.internal.jobs.JobManager.implicitJobs:Lorg/eclipse/core/internal/jobs/ImplicitJobs;
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.ImplicitJobs.removeWaiting:(Lorg/eclipse/core/internal/jobs/ThreadJob;)V
        92: .line 355
      StackMap locals:
      StackMap stack:
            iload 3 /* canBlock */
            ifeq 94
        93: .line 357
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.JobManager.endMonitoring:(Lorg/eclipse/core/internal/jobs/ThreadJob;)V
        end local 15 // boolean updateLockState
        end local 14 // boolean canStopWaiting
        94: .line 359
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.InternalJob int org.eclipse.core.internal.jobs.ThreadJob int int int top top top top java.lang.Throwable
      StackMap stack:
            aload 12
            athrow
        end local 7 // boolean ruleCompatibleAndTransferred
        end local 6 // boolean waiting
        end local 5 // boolean interrupted
        end local 4 // org.eclipse.core.internal.jobs.ThreadJob result
        end local 3 // boolean canBlock
        end local 2 // org.eclipse.core.internal.jobs.InternalJob blockingJob
        end local 1 // org.eclipse.core.runtime.IProgressMonitor monitor
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob threadJob
      LocalVariableTable:
        Start  End  Slot                          Name  Signature
            0   95     0                     threadJob  Lorg/eclipse/core/internal/jobs/ThreadJob;
            0   95     1                       monitor  Lorg/eclipse/core/runtime/IProgressMonitor;
            0   95     2                   blockingJob  Lorg/eclipse/core/internal/jobs/InternalJob;
            1   95     3                      canBlock  Z
            2   95     4                        result  Lorg/eclipse/core/internal/jobs/ThreadJob;
            3   95     5                   interrupted  Z
            4   95     6                       waiting  Z
            5   95     7  ruleCompatibleAndTransferred  Z
           11   81     8                 currentThread  Ljava/lang/Thread;
           31   80     9                       blocker  Ljava/lang/Thread;
           68   72    11                         state  I
           19   21    14                canStopWaiting  Z
           22   29    14                canStopWaiting  Z
           39   41    14                canStopWaiting  Z
           42   49    14                canStopWaiting  Z
           54   56    14                canStopWaiting  Z
           57   64    14                canStopWaiting  Z
           84   86    14                canStopWaiting  Z
           87   94    14                canStopWaiting  Z
           20   21    15               updateLockState  Z
           23   29    15               updateLockState  Z
           40   41    15               updateLockState  Z
           43   49    15               updateLockState  Z
           55   56    15               updateLockState  Z
           58   64    15               updateLockState  Z
           85   86    15               updateLockState  Z
           88   94    15               updateLockState  Z
      Exception table:
        from    to  target  type
          67    72      73  Class java.lang.InterruptedException
          67    76      77  any
          77    78      77  any
           5    17      81  any
          30    37      81  any
          50    52      81  any
          65    81      81  any
    MethodParameters:
             Name  Flags
      threadJob    final
      monitor      
      blockingJob  

  boolean pop(org.eclipse.core.runtime.jobs.ISchedulingRule);
    descriptor: (Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)Z
    flags: (0x0000) 
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
        start local 1 // org.eclipse.core.runtime.jobs.ISchedulingRule rule
         0: .line 368
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            iflt 1
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            aaload
            aload 1 /* rule */
            if_acmpeq 2
         1: .line 369
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* rule */
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.illegalPop:(Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
         2: .line 370
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            aload 0 /* this */
            dup
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            dup_x1
            iconst_1
            isub
            putfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            aconst_null
            aastore
         3: .line 371
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            ifge 4
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         4: iconst_0
            ireturn
        end local 1 // org.eclipse.core.runtime.jobs.ISchedulingRule rule
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/eclipse/core/internal/jobs/ThreadJob;
            0    5     1  rule  Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
    MethodParameters:
      Name  Flags
      rule  

  void push(org.eclipse.core.runtime.jobs.ISchedulingRule);
    descriptor: (Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
        start local 1 // org.eclipse.core.runtime.jobs.ISchedulingRule rule
         0: .line 381
            aload 0 /* this */
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.getRule:()Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            astore 2 /* baseRule */
        start local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule baseRule
         1: .line 382
            aload 0 /* this */
            dup
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            iconst_1
            iadd
            dup_x1
            putfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            arraylength
            if_icmplt 5
         2: .line 383
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            arraylength
            iconst_2
            imul
            anewarray org.eclipse.core.runtime.jobs.ISchedulingRule
            astore 3 /* newStack */
        start local 3 // org.eclipse.core.runtime.jobs.ISchedulingRule[] newStack
         3: .line 384
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            iconst_0
            aload 3 /* newStack */
            iconst_0
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            arraylength
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         4: .line 385
            aload 0 /* this */
            aload 3 /* newStack */
            putfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
        end local 3 // org.eclipse.core.runtime.jobs.ISchedulingRule[] newStack
         5: .line 387
      StackMap locals: org.eclipse.core.runtime.jobs.ISchedulingRule
      StackMap stack:
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            aload 1 /* rule */
            aastore
         6: .line 388
            getstatic org.eclipse.core.internal.jobs.JobManager.DEBUG_BEGIN_END:Z
            ifeq 8
         7: .line 389
            aload 0 /* this */
            new java.lang.RuntimeException
            dup
            invokespecial java.lang.RuntimeException.<init>:()V
            invokevirtual java.lang.RuntimeException.fillInStackTrace:()Ljava/lang/Throwable;
            checkcast java.lang.RuntimeException
            putfield org.eclipse.core.internal.jobs.ThreadJob.lastPush:Ljava/lang/RuntimeException;
         8: .line 391
      StackMap locals:
      StackMap stack:
            aload 2 /* baseRule */
            ifnull 10
            aload 1 /* rule */
            ifnull 10
            aload 2 /* baseRule */
            aload 1 /* rule */
            invokeinterface org.eclipse.core.runtime.jobs.ISchedulingRule.contains:(Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)Z
            ifeq 9
            aload 2 /* baseRule */
            aload 1 /* rule */
            invokeinterface org.eclipse.core.runtime.jobs.ISchedulingRule.isConflicting:(Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)Z
            ifne 10
         9: .line 392
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* rule */
            aload 2 /* baseRule */
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.illegalPush:(Lorg/eclipse/core/runtime/jobs/ISchedulingRule;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
        10: .line 393
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.eclipse.core.runtime.jobs.ISchedulingRule baseRule
        end local 1 // org.eclipse.core.runtime.jobs.ISchedulingRule rule
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   11     0      this  Lorg/eclipse/core/internal/jobs/ThreadJob;
            0   11     1      rule  Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            1   11     2  baseRule  Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            3    5     3  newStack  [Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
    MethodParameters:
      Name  Flags
      rule  final

  boolean recycle();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=6, locals=1, args_size=1
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
         0: .line 402
            aload 0 /* this */
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.getState:()I
            ifeq 2
         1: .line 403
            iconst_0
            ireturn
         2: .line 405
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            aload 0 /* this */
            iconst_0
            dup_x1
            putfield org.eclipse.core.internal.jobs.ThreadJob.isBlocked:Z
            dup_x1
            putfield org.eclipse.core.internal.jobs.ThreadJob.isRunning:Z
            putfield org.eclipse.core.internal.jobs.ThreadJob.acquireRule:Z
         3: .line 406
            aload 0 /* this */
            aconst_null
            putfield org.eclipse.core.internal.jobs.ThreadJob.realJob:Lorg/eclipse/core/runtime/jobs/Job;
         4: .line 407
            aload 0 /* this */
            aconst_null
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.setRule:(Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
         5: .line 408
            aload 0 /* this */
            aconst_null
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.setThread:(Ljava/lang/Thread;)V
         6: .line 409
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            arraylength
            iconst_2
            if_icmpeq 8
         7: .line 410
            aload 0 /* this */
            iconst_2
            anewarray org.eclipse.core.runtime.jobs.ISchedulingRule
            putfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            goto 9
         8: .line 412
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            iconst_0
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            iconst_1
            aconst_null
            dup_x2
            aastore
            aastore
         9: .line 413
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_m1
            putfield org.eclipse.core.internal.jobs.ThreadJob.top:I
        10: .line 414
            iconst_1
            ireturn
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lorg/eclipse/core/internal/jobs/ThreadJob;

  public org.eclipse.core.runtime.IStatus run(org.eclipse.core.runtime.IProgressMonitor);
    descriptor: (Lorg/eclipse/core/runtime/IProgressMonitor;)Lorg/eclipse/core/runtime/IStatus;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
        start local 1 // org.eclipse.core.runtime.IProgressMonitor monitor
         0: .line 422
            aload 0 /* this */
            dup
            astore 2
            monitorenter
         1: .line 423
            aload 0 /* this */
            iconst_1
            putfield org.eclipse.core.internal.jobs.ThreadJob.isRunning:Z
         2: .line 422
            aload 2
            monitorexit
         3: goto 6
      StackMap locals: org.eclipse.core.internal.jobs.ThreadJob org.eclipse.core.runtime.IProgressMonitor org.eclipse.core.internal.jobs.ThreadJob
      StackMap stack: java.lang.Throwable
         4: aload 2
            monitorexit
         5: athrow
         6: .line 425
      StackMap locals:
      StackMap stack:
            getstatic org.eclipse.core.internal.jobs.ThreadJob.ASYNC_FINISH:Lorg/eclipse/core/runtime/IStatus;
            areturn
        end local 1 // org.eclipse.core.runtime.IProgressMonitor monitor
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lorg/eclipse/core/internal/jobs/ThreadJob;
            0    7     1  monitor  Lorg/eclipse/core/runtime/IProgressMonitor;
      Exception table:
        from    to  target  type
           1     3       4  any
           4     5       4  any
    MethodParameters:
         Name  Flags
      monitor  

  void setRealJob(org.eclipse.core.runtime.jobs.Job);
    descriptor: (Lorg/eclipse/core/runtime/jobs/Job;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
        start local 1 // org.eclipse.core.runtime.jobs.Job realJob
         0: .line 434
            aload 0 /* this */
            aload 1 /* realJob */
            putfield org.eclipse.core.internal.jobs.ThreadJob.realJob:Lorg/eclipse/core/runtime/jobs/Job;
         1: .line 435
            return
        end local 1 // org.eclipse.core.runtime.jobs.Job realJob
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/eclipse/core/internal/jobs/ThreadJob;
            0    2     1  realJob  Lorg/eclipse/core/runtime/jobs/Job;
    MethodParameters:
         Name  Flags
      realJob  

  boolean shouldInterrupt();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
         0: .line 443
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.realJob:Lorg/eclipse/core/runtime/jobs/Job;
            ifnonnull 1
            iconst_1
            goto 3
      StackMap locals:
      StackMap stack:
         1: aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.realJob:Lorg/eclipse/core/runtime/jobs/Job;
            invokevirtual org.eclipse.core.runtime.jobs.Job.isSystem:()Z
            ifeq 2
            iconst_0
            goto 3
      StackMap locals:
      StackMap stack:
         2: iconst_1
      StackMap locals:
      StackMap stack: int
         3: ireturn
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/eclipse/core/internal/jobs/ThreadJob;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
         0: .line 451
            new java.lang.StringBuilder
            dup
            ldc "ThreadJob"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            astore 1 /* buf */
        start local 1 // java.lang.StringBuilder buf
         1: .line 452
            aload 1 /* buf */
            bipush 40
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.realJob:Lorg/eclipse/core/runtime/jobs/Job;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            bipush 44
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            aload 0 /* this */
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.getRuleStack:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 41
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         2: .line 453
            aload 1 /* buf */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuilder buf
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/eclipse/core/internal/jobs/ThreadJob;
            1    3     1   buf  Ljava/lang/StringBuilder;

  java.lang.String getRuleStack();
    descriptor: ()Ljava/lang/String;
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
         0: .line 457
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 1 /* buf */
        start local 1 // java.lang.StringBuilder buf
         1: .line 458
            aload 1 /* buf */
            bipush 91
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         2: .line 459
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         3: goto 8
         4: .line 460
      StackMap locals: java.lang.StringBuilder int
      StackMap stack:
            aload 1 /* buf */
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            iload 2 /* i */
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            pop
         5: .line 461
            iload 2 /* i */
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            if_icmpeq 7
         6: .line 462
            aload 1 /* buf */
            bipush 44
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         7: .line 459
      StackMap locals:
      StackMap stack:
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: iload 2 /* i */
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.top:I
            if_icmpgt 9
            iload 2 /* i */
            aload 0 /* this */
            getfield org.eclipse.core.internal.jobs.ThreadJob.ruleStack:[Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            arraylength
            if_icmplt 4
        end local 2 // int i
         9: .line 464
      StackMap locals:
      StackMap stack:
            aload 1 /* buf */
            bipush 93
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        10: .line 465
            aload 1 /* buf */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuilder buf
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lorg/eclipse/core/internal/jobs/ThreadJob;
            1   11     1   buf  Ljava/lang/StringBuilder;
            3    9     2     i  I

  private static void waitEnd(org.eclipse.core.internal.jobs.ThreadJob, boolean, org.eclipse.core.runtime.IProgressMonitor);
    descriptor: (Lorg/eclipse/core/internal/jobs/ThreadJob;ZLorg/eclipse/core/runtime/IProgressMonitor;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob threadJob
        start local 1 // boolean updateLockManager
        start local 2 // org.eclipse.core.runtime.IProgressMonitor monitor
         0: .line 474
            iload 1 /* updateLockManager */
            ifeq 8
         1: .line 475
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            invokevirtual org.eclipse.core.internal.jobs.JobManager.getLockManager:()Lorg/eclipse/core/internal/jobs/LockManager;
            astore 3 /* lockManager */
        start local 3 // org.eclipse.core.internal.jobs.LockManager lockManager
         2: .line 476
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            astore 4 /* currentThread */
        start local 4 // java.lang.Thread currentThread
         3: .line 477
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.isRunning:()Z
            ifeq 7
         4: .line 478
            aload 3 /* lockManager */
            aload 4 /* currentThread */
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.getRule:()Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            invokevirtual org.eclipse.core.internal.jobs.LockManager.addLockThread:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
         5: .line 480
            aload 3 /* lockManager */
            aload 4 /* currentThread */
            invokevirtual org.eclipse.core.internal.jobs.LockManager.resumeSuspendedLocks:(Ljava/lang/Thread;)V
         6: .line 481
            goto 8
         7: .line 483
      StackMap locals: org.eclipse.core.internal.jobs.LockManager java.lang.Thread
      StackMap stack:
            aload 3 /* lockManager */
            aload 4 /* currentThread */
            aload 0 /* threadJob */
            invokevirtual org.eclipse.core.internal.jobs.ThreadJob.getRule:()Lorg/eclipse/core/runtime/jobs/ISchedulingRule;
            invokevirtual org.eclipse.core.internal.jobs.LockManager.removeLockWaitThread:(Ljava/lang/Thread;Lorg/eclipse/core/runtime/jobs/ISchedulingRule;)V
        end local 4 // java.lang.Thread currentThread
        end local 3 // org.eclipse.core.internal.jobs.LockManager lockManager
         8: .line 486
      StackMap locals:
      StackMap stack:
            aload 0 /* threadJob */
            getfield org.eclipse.core.internal.jobs.ThreadJob.isBlocked:Z
            ifeq 11
         9: .line 487
            aload 0 /* threadJob */
            iconst_0
            putfield org.eclipse.core.internal.jobs.ThreadJob.isBlocked:Z
        10: .line 488
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            aload 2 /* monitor */
            invokevirtual org.eclipse.core.internal.jobs.JobManager.reportUnblocked:(Lorg/eclipse/core/runtime/IProgressMonitor;)V
        11: .line 490
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.eclipse.core.runtime.IProgressMonitor monitor
        end local 1 // boolean updateLockManager
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob threadJob
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   12     0          threadJob  Lorg/eclipse/core/internal/jobs/ThreadJob;
            0   12     1  updateLockManager  Z
            0   12     2            monitor  Lorg/eclipse/core/runtime/IProgressMonitor;
            2    8     3        lockManager  Lorg/eclipse/core/internal/jobs/LockManager;
            3    8     4      currentThread  Ljava/lang/Thread;
    MethodParameters:
                   Name  Flags
      threadJob          
      updateLockManager  
      monitor            

  private static void waitStart(org.eclipse.core.internal.jobs.ThreadJob, org.eclipse.core.runtime.IProgressMonitor, org.eclipse.core.internal.jobs.InternalJob);
    descriptor: (Lorg/eclipse/core/internal/jobs/ThreadJob;Lorg/eclipse/core/runtime/IProgressMonitor;Lorg/eclipse/core/internal/jobs/InternalJob;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob threadJob
        start local 1 // org.eclipse.core.runtime.IProgressMonitor monitor
        start local 2 // org.eclipse.core.internal.jobs.InternalJob blockingJob
         0: .line 499
            aload 0 /* threadJob */
            iconst_1
            putfield org.eclipse.core.internal.jobs.ThreadJob.isBlocked:Z
         1: .line 500
            getstatic org.eclipse.core.internal.jobs.ThreadJob.manager:Lorg/eclipse/core/internal/jobs/JobManager;
            aload 1 /* monitor */
            aload 2 /* blockingJob */
            invokevirtual org.eclipse.core.internal.jobs.JobManager.reportBlocked:(Lorg/eclipse/core/runtime/IProgressMonitor;Lorg/eclipse/core/internal/jobs/InternalJob;)V
         2: .line 501
            return
        end local 2 // org.eclipse.core.internal.jobs.InternalJob blockingJob
        end local 1 // org.eclipse.core.runtime.IProgressMonitor monitor
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob threadJob
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    3     0    threadJob  Lorg/eclipse/core/internal/jobs/ThreadJob;
            0    3     1      monitor  Lorg/eclipse/core/runtime/IProgressMonitor;
            0    3     2  blockingJob  Lorg/eclipse/core/internal/jobs/InternalJob;
    MethodParameters:
             Name  Flags
      threadJob    
      monitor      
      blockingJob  

  public boolean shouldSchedule();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.eclipse.core.internal.jobs.ThreadJob this
         0: .line 508
            iconst_0
            ireturn
        end local 0 // org.eclipse.core.internal.jobs.ThreadJob this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/eclipse/core/internal/jobs/ThreadJob;
}
SourceFile: "ThreadJob.java"