public class org.apache.lucene.index.ConcurrentMergeScheduler extends org.apache.lucene.index.MergeScheduler
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.lucene.index.ConcurrentMergeScheduler
  super_class: org.apache.lucene.index.MergeScheduler
{
  public static final int AUTO_DETECT_MERGES_AND_THREADS;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: -1

  public static final java.lang.String DEFAULT_CPU_CORE_COUNT_PROPERTY;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: "lucene.cms.override_core_count"

  public static final java.lang.String DEFAULT_SPINS_PROPERTY;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: "lucene.cms.override_spins"

  protected final java.util.List<org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread> mergeThreads;
    descriptor: Ljava/util/List;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Signature: Ljava/util/List<Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;>;

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

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

  protected int mergeThreadCount;
    descriptor: I
    flags: (0x0004) ACC_PROTECTED

  private static final double MIN_MERGE_MB_PER_SEC;
    descriptor: D
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 5.0

  private static final double MAX_MERGE_MB_PER_SEC;
    descriptor: D
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 10240.0

  private static final double START_MB_PER_SEC;
    descriptor: D
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 20.0

  private static final double MIN_BIG_MERGE_MB;
    descriptor: D
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 50.0

  protected double targetMBPerSec;
    descriptor: D
    flags: (0x0004) ACC_PROTECTED

  private boolean doAutoIOThrottle;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private double forceMergeMBPerSec;
    descriptor: D
    flags: (0x0002) ACC_PRIVATE

  private boolean suppressExceptions;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 66
            ldc Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic org.apache.lucene.index.ConcurrentMergeScheduler.$assertionsDisabled:Z
         3: .line 115
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 127
            aload 0 /* this */
            invokespecial org.apache.lucene.index.MergeScheduler.<init>:()V
         1: .line 87
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
         2: .line 95
            aload 0 /* this */
            iconst_m1
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
         3: .line 99
            aload 0 /* this */
            iconst_m1
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.maxMergeCount:I
         4: .line 118
            aload 0 /* this */
            ldc 20.0
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
         5: .line 121
            aload 0 /* this */
            iconst_1
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.doAutoIOThrottle:Z
         6: .line 123
            aload 0 /* this */
            ldc Infinity
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.forceMergeMBPerSec:D
         7: .line 128
            return
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  public synchronized void setMaxMergesAndThreads(int, int);
    descriptor: (II)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // int maxMergeCount
        start local 2 // int maxThreadCount
         0: .line 144
            iload 1 /* maxMergeCount */
            iconst_m1
            if_icmpne 4
            iload 2 /* maxThreadCount */
            iconst_m1
            if_icmpne 4
         1: .line 146
            aload 0 /* this */
            iconst_m1
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.maxMergeCount:I
         2: .line 147
            aload 0 /* this */
            iconst_m1
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
         3: .line 148
            goto 16
      StackMap locals:
      StackMap stack:
         4: iload 1 /* maxMergeCount */
            iconst_m1
            if_icmpne 6
         5: .line 149
            new java.lang.IllegalArgumentException
            dup
            ldc "both maxMergeCount and maxThreadCount must be AUTO_DETECT_MERGES_AND_THREADS"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 150
      StackMap locals:
      StackMap stack:
            iload 2 /* maxThreadCount */
            iconst_m1
            if_icmpne 8
         7: .line 151
            new java.lang.IllegalArgumentException
            dup
            ldc "both maxMergeCount and maxThreadCount must be AUTO_DETECT_MERGES_AND_THREADS"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 153
      StackMap locals:
      StackMap stack:
            iload 2 /* maxThreadCount */
            iconst_1
            if_icmpge 10
         9: .line 154
            new java.lang.IllegalArgumentException
            dup
            ldc "maxThreadCount should be at least 1"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 156
      StackMap locals:
      StackMap stack:
            iload 1 /* maxMergeCount */
            iconst_1
            if_icmpge 12
        11: .line 157
            new java.lang.IllegalArgumentException
            dup
            ldc "maxMergeCount should be at least 1"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 159
      StackMap locals:
      StackMap stack:
            iload 2 /* maxThreadCount */
            iload 1 /* maxMergeCount */
            if_icmple 14
        13: .line 160
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "maxThreadCount should be <= maxMergeCount (= "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 1 /* maxMergeCount */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 162
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 2 /* maxThreadCount */
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
        15: .line 163
            aload 0 /* this */
            iload 1 /* maxMergeCount */
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.maxMergeCount:I
        16: .line 165
      StackMap locals:
      StackMap stack:
            return
        end local 2 // int maxThreadCount
        end local 1 // int maxMergeCount
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   17     0            this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0   17     1   maxMergeCount  I
            0   17     2  maxThreadCount  I
    MethodParameters:
                Name  Flags
      maxMergeCount   
      maxThreadCount  

  public synchronized void setDefaultMaxMergesAndThreads(boolean);
    descriptor: (Z)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // boolean spins
         0: .line 174
            iload 1 /* spins */
            ifeq 4
         1: .line 175
            aload 0 /* this */
            iconst_1
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
         2: .line 176
            aload 0 /* this */
            bipush 6
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.maxMergeCount:I
         3: .line 177
            goto 12
         4: .line 178
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.Runtime.getRuntime:()Ljava/lang/Runtime;
            invokevirtual java.lang.Runtime.availableProcessors:()I
            istore 2 /* coreCount */
        start local 2 // int coreCount
         5: .line 183
            ldc "lucene.cms.override_core_count"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 3 /* value */
        start local 3 // java.lang.String value
         6: .line 184
            aload 3 /* value */
            ifnull 10
         7: .line 185
            aload 3 /* value */
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            istore 2 /* coreCount */
        end local 3 // java.lang.String value
         8: .line 187
            goto 10
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler int int
      StackMap stack: java.lang.Throwable
         9: pop
        10: .line 190
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            iconst_4
            iload 2 /* coreCount */
            iconst_2
            idiv
            invokestatic java.lang.Math.min:(II)I
            invokestatic java.lang.Math.max:(II)I
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
        11: .line 191
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
            iconst_5
            iadd
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.maxMergeCount:I
        end local 2 // int coreCount
        12: .line 193
      StackMap locals:
      StackMap stack:
            return
        end local 1 // boolean spins
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   13     0       this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0   13     1      spins  Z
            5   12     2  coreCount  I
            6    8     3      value  Ljava/lang/String;
      Exception table:
        from    to  target  type
           5     8       9  Class java.lang.Throwable
    MethodParameters:
       Name  Flags
      spins  

  public synchronized void setForceMergeMBPerSec(double);
    descriptor: (D)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // double v
         0: .line 197
            aload 0 /* this */
            dload 1 /* v */
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.forceMergeMBPerSec:D
         1: .line 198
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.updateMergeThreads:()V
         2: .line 199
            return
        end local 1 // double v
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0    3     1     v  D
    MethodParameters:
      Name  Flags
      v     

  public synchronized double getForceMergeMBPerSec();
    descriptor: ()D
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 203
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.forceMergeMBPerSec:D
            dreturn
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  public synchronized void enableAutoIOThrottle();
    descriptor: ()V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 210
            aload 0 /* this */
            iconst_1
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.doAutoIOThrottle:Z
         1: .line 211
            aload 0 /* this */
            ldc 20.0
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
         2: .line 212
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.updateMergeThreads:()V
         3: .line 213
            return
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  public synchronized void disableAutoIOThrottle();
    descriptor: ()V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 219
            aload 0 /* this */
            iconst_0
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.doAutoIOThrottle:Z
         1: .line 220
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.updateMergeThreads:()V
         2: .line 221
            return
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  public synchronized boolean getAutoIOThrottle();
    descriptor: ()Z
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 225
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.doAutoIOThrottle:Z
            ireturn
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  public synchronized double getIORateLimitMBPerSec();
    descriptor: ()D
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 231
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.doAutoIOThrottle:Z
            ifeq 2
         1: .line 232
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            dreturn
         2: .line 234
      StackMap locals:
      StackMap stack:
            ldc Infinity
            dreturn
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  public synchronized int getMaxThreadCount();
    descriptor: ()I
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 242
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
            ireturn
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  public synchronized int getMaxMergeCount();
    descriptor: ()I
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 247
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.maxMergeCount:I
            ireturn
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  synchronized void removeMergeThread();
    descriptor: ()V
    flags: (0x0020) ACC_SYNCHRONIZED
    Code:
      stack=5, locals=3, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 252
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            astore 1 /* currentThread */
        start local 1 // java.lang.Thread currentThread
         1: .line 254
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         2: goto 7
         3: .line 255
      StackMap locals: java.lang.Thread int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            iload 2 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            aload 1 /* currentThread */
            if_acmpne 6
         4: .line 256
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            iload 2 /* i */
            invokeinterface java.util.List.remove:(I)Ljava/lang/Object;
            pop
         5: .line 257
            return
         6: .line 254
      StackMap locals:
      StackMap stack:
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         7: iload 2 /* i */
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            if_icmplt 3
        end local 2 // int i
         8: .line 261
            getstatic org.apache.lucene.index.ConcurrentMergeScheduler.$assertionsDisabled:Z
            ifne 9
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "merge thread "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* currentThread */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " was not found"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         9: .line 262
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Thread currentThread
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   10     0           this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            1   10     1  currentThread  Ljava/lang/Thread;
            2    8     2              i  I

  public org.apache.lucene.store.Directory wrapForMerge(org.apache.lucene.index.MergePolicy$OneMerge, org.apache.lucene.store.Directory);
    descriptor: (Lorg/apache/lucene/index/MergePolicy$OneMerge;Lorg/apache/lucene/store/Directory;)Lorg/apache/lucene/store/Directory;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=5, args_size=3
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // org.apache.lucene.index.MergePolicy$OneMerge merge
        start local 2 // org.apache.lucene.store.Directory in
         0: .line 266
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            astore 3 /* mergeThread */
        start local 3 // java.lang.Thread mergeThread
         1: .line 267
            ldc Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
            aload 3 /* mergeThread */
            invokevirtual java.lang.Class.isInstance:(Ljava/lang/Object;)Z
            ifne 5
         2: .line 268
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "wrapForMerge should be called from MergeThread. Current thread: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         3: .line 269
            aload 3 /* mergeThread */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         4: .line 268
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         5: .line 273
      StackMap locals: java.lang.Thread
      StackMap stack:
            aload 3 /* mergeThread */
            checkcast org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.rateLimiter:Lorg/apache/lucene/index/MergeRateLimiter;
            astore 4 /* rateLimiter */
        start local 4 // org.apache.lucene.store.RateLimiter rateLimiter
         6: .line 274
            new org.apache.lucene.index.ConcurrentMergeScheduler$1
            dup
            aload 0 /* this */
            aload 2 /* in */
            aload 3 /* mergeThread */
            aload 4 /* rateLimiter */
            invokespecial org.apache.lucene.index.ConcurrentMergeScheduler$1.<init>:(Lorg/apache/lucene/index/ConcurrentMergeScheduler;Lorg/apache/lucene/store/Directory;Ljava/lang/Thread;Lorg/apache/lucene/store/RateLimiter;)V
            areturn
        end local 4 // org.apache.lucene.store.RateLimiter rateLimiter
        end local 3 // java.lang.Thread mergeThread
        end local 2 // org.apache.lucene.store.Directory in
        end local 1 // org.apache.lucene.index.MergePolicy$OneMerge merge
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0         this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0    7     1        merge  Lorg/apache/lucene/index/MergePolicy$OneMerge;
            0    7     2           in  Lorg/apache/lucene/store/Directory;
            1    7     3  mergeThread  Ljava/lang/Thread;
            6    7     4  rateLimiter  Lorg/apache/lucene/store/RateLimiter;
    MethodParameters:
       Name  Flags
      merge  
      in     

  protected synchronized void updateMergeThreads();
    descriptor: ()V
    flags: (0x0024) ACC_PROTECTED, ACC_SYNCHRONIZED
    Code:
      stack=10, locals=18, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 305
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 1 /* activeMerges */
        start local 1 // java.util.List activeMerges
         1: .line 307
            iconst_0
            istore 2 /* threadIdx */
        start local 2 // int threadIdx
         2: .line 308
            goto 9
         3: .line 309
      StackMap locals: java.util.List int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            iload 2 /* threadIdx */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
            astore 3 /* mergeThread */
        start local 3 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
         4: .line 310
            aload 3 /* mergeThread */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.isAlive:()Z
            ifne 7
         5: .line 312
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            iload 2 /* threadIdx */
            invokeinterface java.util.List.remove:(I)Ljava/lang/Object;
            pop
         6: .line 313
            goto 9
         7: .line 315
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
      StackMap stack:
            aload 1 /* activeMerges */
            aload 3 /* mergeThread */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         8: .line 316
            iinc 2 /* threadIdx */ 1
        end local 3 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
         9: .line 308
      StackMap locals:
      StackMap stack:
            iload 2 /* threadIdx */
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            if_icmplt 3
        10: .line 320
            aload 1 /* activeMerges */
            invokestatic org.apache.lucene.util.CollectionUtil.timSort:(Ljava/util/List;)V
        11: .line 322
            aload 1 /* activeMerges */
            invokeinterface java.util.List.size:()I
            istore 3 /* activeMergeCount */
        start local 3 // int activeMergeCount
        12: .line 324
            iconst_0
            istore 4 /* bigMergeCount */
        start local 4 // int bigMergeCount
        13: .line 326
            iload 3 /* activeMergeCount */
            iconst_1
            isub
            istore 2 /* threadIdx */
            goto 19
        14: .line 327
      StackMap locals: int int
      StackMap stack:
            aload 1 /* activeMerges */
            iload 2 /* threadIdx */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
            astore 5 /* mergeThread */
        start local 5 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
        15: .line 328
            aload 5 /* mergeThread */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.merge:Lorg/apache/lucene/index/MergePolicy$OneMerge;
            getfield org.apache.lucene.index.MergePolicy$OneMerge.estimatedMergeBytes:J
            l2d
            ldc 5.24288E7
            dcmpl
            ifle 18
        16: .line 329
            iconst_1
            iload 2 /* threadIdx */
            iadd
            istore 4 /* bigMergeCount */
        17: .line 330
            goto 20
        end local 5 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
        18: .line 326
      StackMap locals:
      StackMap stack:
            iinc 2 /* threadIdx */ -1
      StackMap locals:
      StackMap stack:
        19: iload 2 /* threadIdx */
            ifge 14
        20: .line 334
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.nanoTime:()J
            lstore 5 /* now */
        start local 5 // long now
        21: .line 337
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 25
        22: .line 338
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 7 /* message */
        start local 7 // java.lang.StringBuilder message
        23: .line 339
            aload 7 /* message */
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            ldc "updateMergeThreads ioThrottle=%s targetMBPerSec=%.1f MB/sec"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.doAutoIOThrottle:Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            aastore
            dup
            iconst_1
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        24: .line 340
            goto 26
        end local 7 // java.lang.StringBuilder message
        25: .line 341
      StackMap locals: long
      StackMap stack:
            aconst_null
            astore 7 /* message */
        start local 7 // java.lang.StringBuilder message
        26: .line 344
      StackMap locals: java.lang.StringBuilder
      StackMap stack:
            iconst_0
            istore 2 /* threadIdx */
            goto 79
        27: .line 345
      StackMap locals:
      StackMap stack:
            aload 1 /* activeMerges */
            iload 2 /* threadIdx */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
            astore 8 /* mergeThread */
        start local 8 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
        28: .line 347
            aload 8 /* mergeThread */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.merge:Lorg/apache/lucene/index/MergePolicy$OneMerge;
            astore 9 /* merge */
        start local 9 // org.apache.lucene.index.MergePolicy$OneMerge merge
        29: .line 350
            iload 2 /* threadIdx */
            iload 4 /* bigMergeCount */
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
            isub
            if_icmpge 30
            iconst_1
            goto 31
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread org.apache.lucene.index.MergePolicy$OneMerge
      StackMap stack:
        30: iconst_0
      StackMap locals:
      StackMap stack: int
        31: istore 10 /* doPause */
        start local 10 // boolean doPause
        32: .line 353
            iload 10 /* doPause */
            ifeq 35
        33: .line 354
            dconst_0
            dstore 11 /* newMBPerSec */
        start local 11 // double newMBPerSec
        34: .line 355
            goto 45
        end local 11 // double newMBPerSec
      StackMap locals: int
      StackMap stack:
        35: aload 9 /* merge */
            getfield org.apache.lucene.index.MergePolicy$OneMerge.maxNumSegments:I
            iconst_m1
            if_icmpeq 38
        36: .line 356
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.forceMergeMBPerSec:D
            dstore 11 /* newMBPerSec */
        start local 11 // double newMBPerSec
        37: .line 357
            goto 45
        end local 11 // double newMBPerSec
      StackMap locals:
      StackMap stack:
        38: aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.doAutoIOThrottle:Z
            ifne 41
        39: .line 358
            ldc Infinity
            dstore 11 /* newMBPerSec */
        start local 11 // double newMBPerSec
        40: .line 359
            goto 45
        end local 11 // double newMBPerSec
      StackMap locals:
      StackMap stack:
        41: aload 9 /* merge */
            getfield org.apache.lucene.index.MergePolicy$OneMerge.estimatedMergeBytes:J
            l2d
            ldc 5.24288E7
            dcmpg
            ifge 44
        42: .line 361
            ldc Infinity
            dstore 11 /* newMBPerSec */
        start local 11 // double newMBPerSec
        43: .line 362
            goto 45
        end local 11 // double newMBPerSec
        44: .line 363
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            dstore 11 /* newMBPerSec */
        start local 11 // double newMBPerSec
        45: .line 366
      StackMap locals: double
      StackMap stack:
            aload 8 /* mergeThread */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.rateLimiter:Lorg/apache/lucene/index/MergeRateLimiter;
            astore 13 /* rateLimiter */
        start local 13 // org.apache.lucene.index.MergeRateLimiter rateLimiter
        46: .line 367
            aload 13 /* rateLimiter */
            invokevirtual org.apache.lucene.index.MergeRateLimiter.getMBPerSec:()D
            dstore 14 /* curMBPerSec */
        start local 14 // double curMBPerSec
        47: .line 369
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 77
        48: .line 370
            aload 9 /* merge */
            getfield org.apache.lucene.index.MergePolicy$OneMerge.mergeStartNS:J
            lstore 16 /* mergeStartNS */
        start local 16 // long mergeStartNS
        49: .line 371
            lload 16 /* mergeStartNS */
            ldc -1
            lcmp
            ifne 51
        50: .line 373
            lload 5 /* now */
            lstore 16 /* mergeStartNS */
        51: .line 375
      StackMap locals: org.apache.lucene.index.MergeRateLimiter double long
      StackMap stack:
            aload 7 /* message */
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        52: .line 376
            aload 7 /* message */
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            ldc "merge thread %s estSize=%.1f MB (written=%.1f MB) runTime=%.1fs (stopped=%.1fs, paused=%.1fs) rate=%s\n"
            bipush 7
            anewarray java.lang.Object
            dup
            iconst_0
        53: .line 377
            aload 8 /* mergeThread */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.getName:()Ljava/lang/String;
            aastore
            dup
            iconst_1
        54: .line 378
            aload 9 /* merge */
            getfield org.apache.lucene.index.MergePolicy$OneMerge.estimatedMergeBytes:J
            invokestatic org.apache.lucene.index.ConcurrentMergeScheduler.bytesToMB:(J)D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            dup
            iconst_2
        55: .line 379
            aload 13 /* rateLimiter */
            invokevirtual org.apache.lucene.index.MergeRateLimiter.getTotalBytesWritten:()J
            invokestatic org.apache.lucene.index.ConcurrentMergeScheduler.bytesToMB:(J)D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            dup
            iconst_3
        56: .line 380
            lload 5 /* now */
            lload 16 /* mergeStartNS */
            lsub
            invokestatic org.apache.lucene.index.ConcurrentMergeScheduler.nsToSec:(J)D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            dup
            iconst_4
        57: .line 381
            aload 13 /* rateLimiter */
            invokevirtual org.apache.lucene.index.MergeRateLimiter.getTotalStoppedNS:()J
            invokestatic org.apache.lucene.index.ConcurrentMergeScheduler.nsToSec:(J)D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            dup
            iconst_5
        58: .line 382
            aload 13 /* rateLimiter */
            invokevirtual org.apache.lucene.index.MergeRateLimiter.getTotalPausedNS:()J
            invokestatic org.apache.lucene.index.ConcurrentMergeScheduler.nsToSec:(J)D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            dup
            bipush 6
        59: .line 383
            aload 13 /* rateLimiter */
            invokevirtual org.apache.lucene.index.MergeRateLimiter.getMBPerSec:()D
            invokestatic org.apache.lucene.index.ConcurrentMergeScheduler.rateToString:(D)Ljava/lang/String;
            aastore
        60: .line 376
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        61: .line 385
            dload 11 /* newMBPerSec */
            dload 14 /* curMBPerSec */
            dcmpl
            ifeq 73
        62: .line 386
            dload 11 /* newMBPerSec */
            dconst_0
            dcmpl
            ifne 65
        63: .line 387
            aload 7 /* message */
            ldc "  now stop"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        64: .line 388
            goto 77
      StackMap locals:
      StackMap stack:
        65: dload 14 /* curMBPerSec */
            dconst_0
            dcmpl
            ifne 71
        66: .line 389
            dload 11 /* newMBPerSec */
            ldc Infinity
            dcmpl
            ifne 69
        67: .line 390
            aload 7 /* message */
            ldc "  now resume"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        68: .line 391
            goto 77
        69: .line 392
      StackMap locals:
      StackMap stack:
            aload 7 /* message */
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            ldc "  now resume to %.1f MB/sec"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            dload 11 /* newMBPerSec */
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        70: .line 394
            goto 77
        71: .line 395
      StackMap locals:
      StackMap stack:
            aload 7 /* message */
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            ldc "  now change from %.1f MB/sec to %.1f MB/sec"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            dload 14 /* curMBPerSec */
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            dup
            iconst_1
            dload 11 /* newMBPerSec */
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        72: .line 397
            goto 77
      StackMap locals:
      StackMap stack:
        73: dload 14 /* curMBPerSec */
            dconst_0
            dcmpl
            ifne 76
        74: .line 398
            aload 7 /* message */
            ldc "  leave stopped"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        75: .line 399
            goto 77
        76: .line 400
      StackMap locals:
      StackMap stack:
            aload 7 /* message */
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            ldc "  leave running at %.1f MB/sec"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            dload 14 /* curMBPerSec */
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 16 // long mergeStartNS
        77: .line 404
      StackMap locals:
      StackMap stack:
            aload 13 /* rateLimiter */
            dload 11 /* newMBPerSec */
            invokevirtual org.apache.lucene.index.MergeRateLimiter.setMBPerSec:(D)V
        end local 14 // double curMBPerSec
        end local 13 // org.apache.lucene.index.MergeRateLimiter rateLimiter
        end local 11 // double newMBPerSec
        end local 10 // boolean doPause
        end local 9 // org.apache.lucene.index.MergePolicy$OneMerge merge
        end local 8 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
        78: .line 344
            iinc 2 /* threadIdx */ 1
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler java.util.List int int int long java.lang.StringBuilder
      StackMap stack:
        79: iload 2 /* threadIdx */
            iload 3 /* activeMergeCount */
            if_icmplt 27
        80: .line 406
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 82
        81: .line 407
            aload 0 /* this */
            aload 7 /* message */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
        82: .line 409
      StackMap locals:
      StackMap stack:
            return
        end local 7 // java.lang.StringBuilder message
        end local 5 // long now
        end local 4 // int bigMergeCount
        end local 3 // int activeMergeCount
        end local 2 // int threadIdx
        end local 1 // java.util.List activeMerges
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   83     0              this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            1   83     1      activeMerges  Ljava/util/List<Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;>;
            2   83     2         threadIdx  I
            4    9     3       mergeThread  Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
           12   83     3  activeMergeCount  I
           13   83     4     bigMergeCount  I
           15   18     5       mergeThread  Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
           21   83     5               now  J
           23   25     7           message  Ljava/lang/StringBuilder;
           26   83     7           message  Ljava/lang/StringBuilder;
           28   78     8       mergeThread  Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
           29   78     9             merge  Lorg/apache/lucene/index/MergePolicy$OneMerge;
           32   78    10           doPause  Z
           34   35    11       newMBPerSec  D
           37   38    11       newMBPerSec  D
           40   41    11       newMBPerSec  D
           43   44    11       newMBPerSec  D
           45   78    11       newMBPerSec  D
           46   78    13       rateLimiter  Lorg/apache/lucene/index/MergeRateLimiter;
           47   78    14       curMBPerSec  D
           49   77    16      mergeStartNS  J

  private synchronized void initDynamicDefaults(org.apache.lucene.store.Directory);
    descriptor: (Lorg/apache/lucene/store/Directory;)V
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // org.apache.lucene.store.Directory directory
         0: .line 412
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
            iconst_m1
            if_icmpne 10
         1: .line 413
            aload 1 /* directory */
            invokestatic org.apache.lucene.util.IOUtils.spins:(Lorg/apache/lucene/store/Directory;)Z
            istore 2 /* spins */
        start local 2 // boolean spins
         2: .line 418
            ldc "lucene.cms.override_spins"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 3 /* value */
        start local 3 // java.lang.String value
         3: .line 419
            aload 3 /* value */
            ifnull 7
         4: .line 420
            aload 3 /* value */
            invokestatic java.lang.Boolean.parseBoolean:(Ljava/lang/String;)Z
            istore 2 /* spins */
        end local 3 // java.lang.String value
         5: .line 422
            goto 7
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler org.apache.lucene.store.Directory int
      StackMap stack: java.lang.Exception
         6: pop
         7: .line 425
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 2 /* spins */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.setDefaultMaxMergesAndThreads:(Z)V
         8: .line 426
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 10
         9: .line 427
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "initDynamicDefaults spins="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 2 /* spins */
            invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
            ldc " maxThreadCount="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " maxMergeCount="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.maxMergeCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
        end local 2 // boolean spins
        10: .line 430
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.lucene.store.Directory directory
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   11     0       this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0   11     1  directory  Lorg/apache/lucene/store/Directory;
            2   10     2      spins  Z
            3    5     3      value  Ljava/lang/String;
      Exception table:
        from    to  target  type
           2     5       6  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
           Name  Flags
      directory  

  private static java.lang.String rateToString(double);
    descriptor: (D)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=2, args_size=1
        start local 0 // double mbPerSec
         0: .line 433
            dload 0 /* mbPerSec */
            dconst_0
            dcmpl
            ifne 2
         1: .line 434
            ldc "stopped"
            areturn
         2: .line 435
      StackMap locals:
      StackMap stack:
            dload 0 /* mbPerSec */
            ldc Infinity
            dcmpl
            ifne 4
         3: .line 436
            ldc "unlimited"
            areturn
         4: .line 438
      StackMap locals:
      StackMap stack:
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            ldc "%.1f MB/sec"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            dload 0 /* mbPerSec */
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 0 // double mbPerSec
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0  mbPerSec  D
    MethodParameters:
          Name  Flags
      mbPerSec  

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 444
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.sync:()V
         1: .line 445
            return
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  public void sync();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=7, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 449
            iconst_0
            istore 1 /* interrupted */
        start local 1 // boolean interrupted
         1: .line 452
      StackMap locals: int
      StackMap stack:
            aconst_null
            astore 2 /* toSync */
        start local 2 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread toSync
         2: .line 453
            aload 0 /* this */
            dup
            astore 3
            monitorenter
         3: .line 454
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 8
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler int org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread org.apache.lucene.index.ConcurrentMergeScheduler top java.util.Iterator
      StackMap stack:
         4: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
            astore 4 /* t */
        start local 4 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread t
         5: .line 457
            aload 4 /* t */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.isAlive:()Z
            ifeq 8
            aload 4 /* t */
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            if_acmpeq 8
         6: .line 458
            aload 4 /* t */
            astore 2 /* toSync */
         7: .line 459
            goto 9
        end local 4 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread t
         8: .line 454
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         9: .line 453
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler int org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread org.apache.lucene.index.ConcurrentMergeScheduler
      StackMap stack:
            aload 3
            monitorexit
        10: goto 13
      StackMap locals:
      StackMap stack: java.lang.Throwable
        11: aload 3
            monitorexit
        12: athrow
        13: .line 463
      StackMap locals:
      StackMap stack:
            aload 2 /* toSync */
            ifnull 22
        14: .line 465
            aload 2 /* toSync */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.join:()V
        15: .line 466
            goto 1
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
        16: pop
        17: .line 468
            iconst_1
            istore 1 /* interrupted */
        end local 2 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread toSync
        18: .line 451
            goto 1
        19: .line 474
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler int
      StackMap stack: java.lang.Throwable
            astore 6
        20: .line 476
            iload 1 /* interrupted */
            ifeq 21
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
        21: .line 477
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler int top top top top java.lang.Throwable
      StackMap stack:
            aload 6
            athrow
        22: .line 476
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler int
      StackMap stack:
            iload 1 /* interrupted */
            ifeq 23
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
        23: .line 478
      StackMap locals:
      StackMap stack:
            return
        end local 1 // boolean interrupted
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   24     0         this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            1   24     1  interrupted  Z
            2   18     2       toSync  Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
            5    8     4            t  Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
      Exception table:
        from    to  target  type
           3    10      11  any
          11    12      11  any
          14    15      16  Class java.lang.InterruptedException
           1    19      19  any

  public synchronized int mergeThreadCount();
    descriptor: ()I
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=5, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 487
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            astore 1 /* currentThread */
        start local 1 // java.lang.Thread currentThread
         1: .line 488
            iconst_0
            istore 2 /* count */
        start local 2 // int count
         2: .line 489
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 6
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler java.lang.Thread int top java.util.Iterator
      StackMap stack:
         3: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
            astore 3 /* mergeThread */
        start local 3 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
         4: .line 490
            aload 1 /* currentThread */
            aload 3 /* mergeThread */
            if_acmpeq 6
            aload 3 /* mergeThread */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.isAlive:()Z
            ifeq 6
            aload 3 /* mergeThread */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.merge:Lorg/apache/lucene/index/MergePolicy$OneMerge;
            invokevirtual org.apache.lucene.index.MergePolicy$OneMerge.isAborted:()Z
            ifne 6
         5: .line 491
            iinc 2 /* count */ 1
        end local 3 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
         6: .line 489
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         7: .line 494
            iload 2 /* count */
            ireturn
        end local 2 // int count
        end local 1 // java.lang.Thread currentThread
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    8     0           this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            1    8     1  currentThread  Ljava/lang/Thread;
            2    8     2          count  I
            4    6     3    mergeThread  Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;

  void initialize(org.apache.lucene.util.InfoStream, org.apache.lucene.store.Directory);
    descriptor: (Lorg/apache/lucene/util/InfoStream;Lorg/apache/lucene/store/Directory;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // org.apache.lucene.util.InfoStream infoStream
        start local 2 // org.apache.lucene.store.Directory directory
         0: .line 499
            aload 0 /* this */
            aload 1 /* infoStream */
            aload 2 /* directory */
            invokespecial org.apache.lucene.index.MergeScheduler.initialize:(Lorg/apache/lucene/util/InfoStream;Lorg/apache/lucene/store/Directory;)V
         1: .line 500
            aload 0 /* this */
            aload 2 /* directory */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.initDynamicDefaults:(Lorg/apache/lucene/store/Directory;)V
         2: .line 502
            return
        end local 2 // org.apache.lucene.store.Directory directory
        end local 1 // org.apache.lucene.util.InfoStream infoStream
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    3     0        this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0    3     1  infoStream  Lorg/apache/lucene/util/InfoStream;
            0    3     2   directory  Lorg/apache/lucene/store/Directory;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
            Name  Flags
      infoStream  
      directory   

  public synchronized void merge(org.apache.lucene.index.MergeScheduler$MergeSource, org.apache.lucene.index.MergeTrigger);
    descriptor: (Lorg/apache/lucene/index/MergeScheduler$MergeSource;Lorg/apache/lucene/index/MergeTrigger;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=7, args_size=3
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // org.apache.lucene.index.MergeScheduler$MergeSource mergeSource
        start local 2 // org.apache.lucene.index.MergeTrigger trigger
         0: .line 507
            aload 2 /* trigger */
            getstatic org.apache.lucene.index.MergeTrigger.CLOSING:Lorg/apache/lucene/index/MergeTrigger;
            if_acmpne 3
         1: .line 509
            aload 0 /* this */
            ldc 10240.0
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
         2: .line 510
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.updateMergeThreads:()V
         3: .line 520
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 6
         4: .line 521
            aload 0 /* this */
            ldc "now merge"
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
         5: .line 522
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "  index(source): "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* mergeSource */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
         6: .line 529
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* mergeSource */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.maybeStall:(Lorg/apache/lucene/index/MergeScheduler$MergeSource;)Z
            ifne 8
         7: .line 530
            goto 30
         8: .line 533
      StackMap locals:
      StackMap stack:
            aload 1 /* mergeSource */
            invokeinterface org.apache.lucene.index.MergeScheduler$MergeSource.getNextMerge:()Lorg/apache/lucene/index/MergePolicy$OneMerge;
            astore 3 /* merge */
        start local 3 // org.apache.lucene.index.MergePolicy$OneMerge merge
         9: .line 534
            aload 3 /* merge */
            ifnonnull 13
        10: .line 535
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 12
        11: .line 536
            aload 0 /* this */
            ldc "  no more merges pending; now return"
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
        12: .line 538
      StackMap locals: org.apache.lucene.index.MergePolicy$OneMerge
      StackMap stack:
            return
        13: .line 541
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 4 /* success */
        start local 4 // boolean success
        14: .line 545
            aload 0 /* this */
            aload 1 /* mergeSource */
            aload 3 /* merge */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.getMergeThread:(Lorg/apache/lucene/index/MergeScheduler$MergeSource;Lorg/apache/lucene/index/MergePolicy$OneMerge;)Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
            astore 5 /* newMergeThread */
        start local 5 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread newMergeThread
        15: .line 546
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            aload 5 /* newMergeThread */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        16: .line 548
            aload 0 /* this */
            aload 5 /* newMergeThread */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.merge:Lorg/apache/lucene/index/MergePolicy$OneMerge;
            aload 5 /* newMergeThread */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.rateLimiter:Lorg/apache/lucene/index/MergeRateLimiter;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.updateIOThrottle:(Lorg/apache/lucene/index/MergePolicy$OneMerge;Lorg/apache/lucene/index/MergeRateLimiter;)V
        17: .line 550
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 19
        18: .line 551
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "    launch new thread ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* newMergeThread */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
        19: .line 554
      StackMap locals: int org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
      StackMap stack:
            aload 5 /* newMergeThread */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.start:()V
        20: .line 555
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.updateMergeThreads:()V
        21: .line 557
            iconst_1
            istore 4 /* success */
        end local 5 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread newMergeThread
        22: .line 558
            goto 27
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler org.apache.lucene.index.MergeScheduler$MergeSource org.apache.lucene.index.MergeTrigger org.apache.lucene.index.MergePolicy$OneMerge int
      StackMap stack: java.lang.Throwable
        23: astore 6
        24: .line 559
            iload 4 /* success */
            ifne 26
        25: .line 560
            aload 1 /* mergeSource */
            aload 3 /* merge */
            invokeinterface org.apache.lucene.index.MergeScheduler$MergeSource.onMergeFinished:(Lorg/apache/lucene/index/MergePolicy$OneMerge;)V
        26: .line 562
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler org.apache.lucene.index.MergeScheduler$MergeSource org.apache.lucene.index.MergeTrigger org.apache.lucene.index.MergePolicy$OneMerge int top java.lang.Throwable
      StackMap stack:
            aload 6
            athrow
        27: .line 559
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler org.apache.lucene.index.MergeScheduler$MergeSource org.apache.lucene.index.MergeTrigger org.apache.lucene.index.MergePolicy$OneMerge int
      StackMap stack:
            iload 4 /* success */
            ifne 6
        28: .line 560
            aload 1 /* mergeSource */
            aload 3 /* merge */
            invokeinterface org.apache.lucene.index.MergeScheduler$MergeSource.onMergeFinished:(Lorg/apache/lucene/index/MergePolicy$OneMerge;)V
        end local 4 // boolean success
        end local 3 // org.apache.lucene.index.MergePolicy$OneMerge merge
        29: .line 527
            goto 6
        30: .line 564
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.apache.lucene.index.MergeTrigger trigger
        end local 1 // org.apache.lucene.index.MergeScheduler$MergeSource mergeSource
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   31     0            this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0   31     1     mergeSource  Lorg/apache/lucene/index/MergeScheduler$MergeSource;
            0   31     2         trigger  Lorg/apache/lucene/index/MergeTrigger;
            9   29     3           merge  Lorg/apache/lucene/index/MergePolicy$OneMerge;
           14   29     4         success  Z
           15   22     5  newMergeThread  Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
      Exception table:
        from    to  target  type
          14    23      23  any
    Exceptions:
      throws java.io.IOException
    MethodParameters:
             Name  Flags
      mergeSource  
      trigger      

  protected synchronized boolean maybeStall(org.apache.lucene.index.MergeScheduler$MergeSource);
    descriptor: (Lorg/apache/lucene/index/MergeScheduler$MergeSource;)Z
    flags: (0x0024) ACC_PROTECTED, ACC_SYNCHRONIZED
    Code:
      stack=6, locals=4, args_size=2
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // org.apache.lucene.index.MergeScheduler$MergeSource mergeSource
         0: .line 578
            lconst_0
            lstore 2 /* startStallTime */
        start local 2 // long startStallTime
         1: .line 579
            goto 8
         2: .line 591
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
            ifeq 4
         3: .line 595
            iconst_0
            ireturn
         4: .line 598
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 6
            lload 2 /* startStallTime */
            lconst_0
            lcmp
            ifne 6
         5: .line 599
            aload 0 /* this */
            ldc "    too many merges; stalling..."
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
         6: .line 601
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 2 /* startStallTime */
         7: .line 602
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.doStall:()V
         8: .line 579
      StackMap locals:
      StackMap stack:
            aload 1 /* mergeSource */
            invokeinterface org.apache.lucene.index.MergeScheduler$MergeSource.hasPendingMerges:()Z
            ifeq 9
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreadCount:()I
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.maxMergeCount:I
            if_icmpge 2
         9: .line 605
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 11
            lload 2 /* startStallTime */
            lconst_0
            lcmp
            ifeq 11
        10: .line 606
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "  stalled for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            invokestatic java.lang.System.currentTimeMillis:()J
            lload 2 /* startStallTime */
            lsub
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            ldc " msec"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
        11: .line 609
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 2 // long startStallTime
        end local 1 // org.apache.lucene.index.MergeScheduler$MergeSource mergeSource
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   12     0            this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0   12     1     mergeSource  Lorg/apache/lucene/index/MergeScheduler$MergeSource;
            1   12     2  startStallTime  J
    MethodParameters:
             Name  Flags
      mergeSource  

  protected synchronized void doStall();
    descriptor: ()V
    flags: (0x0024) ACC_PROTECTED, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 616
            aload 0 /* this */
            ldc 250
            invokevirtual java.lang.Object.wait:(J)V
         1: .line 617
            goto 4
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
         2: astore 1 /* ie */
        start local 1 // java.lang.InterruptedException ie
         3: .line 618
            new org.apache.lucene.util.ThreadInterruptedException
            dup
            aload 1 /* ie */
            invokespecial org.apache.lucene.util.ThreadInterruptedException.<init>:(Ljava/lang/InterruptedException;)V
            athrow
        end local 1 // java.lang.InterruptedException ie
         4: .line 620
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            3    4     1    ie  Ljava/lang/InterruptedException;
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.InterruptedException

  protected void doMerge(org.apache.lucene.index.MergeScheduler$MergeSource, org.apache.lucene.index.MergePolicy$OneMerge);
    descriptor: (Lorg/apache/lucene/index/MergeScheduler$MergeSource;Lorg/apache/lucene/index/MergePolicy$OneMerge;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // org.apache.lucene.index.MergeScheduler$MergeSource mergeSource
        start local 2 // org.apache.lucene.index.MergePolicy$OneMerge merge
         0: .line 624
            aload 1 /* mergeSource */
            aload 2 /* merge */
            invokeinterface org.apache.lucene.index.MergeScheduler$MergeSource.merge:(Lorg/apache/lucene/index/MergePolicy$OneMerge;)V
         1: .line 625
            return
        end local 2 // org.apache.lucene.index.MergePolicy$OneMerge merge
        end local 1 // org.apache.lucene.index.MergeScheduler$MergeSource mergeSource
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    2     0         this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0    2     1  mergeSource  Lorg/apache/lucene/index/MergeScheduler$MergeSource;
            0    2     2        merge  Lorg/apache/lucene/index/MergePolicy$OneMerge;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
             Name  Flags
      mergeSource  
      merge        

  protected synchronized org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread getMergeThread(org.apache.lucene.index.MergeScheduler$MergeSource, org.apache.lucene.index.MergePolicy$OneMerge);
    descriptor: (Lorg/apache/lucene/index/MergeScheduler$MergeSource;Lorg/apache/lucene/index/MergePolicy$OneMerge;)Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
    flags: (0x0024) ACC_PROTECTED, ACC_SYNCHRONIZED
    Code:
      stack=6, locals=4, args_size=3
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // org.apache.lucene.index.MergeScheduler$MergeSource mergeSource
        start local 2 // org.apache.lucene.index.MergePolicy$OneMerge merge
         0: .line 629
            new org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
            dup
            aload 0 /* this */
            aload 1 /* mergeSource */
            aload 2 /* merge */
            invokespecial org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.<init>:(Lorg/apache/lucene/index/ConcurrentMergeScheduler;Lorg/apache/lucene/index/MergeScheduler$MergeSource;Lorg/apache/lucene/index/MergePolicy$OneMerge;)V
            astore 3 /* thread */
        start local 3 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread thread
         1: .line 630
            aload 3 /* thread */
            iconst_1
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.setDaemon:(Z)V
         2: .line 631
            aload 3 /* thread */
            new java.lang.StringBuilder
            dup
            ldc "Lucene Merge Thread #"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            dup
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreadCount:I
            dup_x1
            iconst_1
            iadd
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreadCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.setName:(Ljava/lang/String;)V
         3: .line 632
            aload 3 /* thread */
            areturn
        end local 3 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread thread
        end local 2 // org.apache.lucene.index.MergePolicy$OneMerge merge
        end local 1 // org.apache.lucene.index.MergeScheduler$MergeSource mergeSource
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    4     0         this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0    4     1  mergeSource  Lorg/apache/lucene/index/MergeScheduler$MergeSource;
            0    4     2        merge  Lorg/apache/lucene/index/MergePolicy$OneMerge;
            1    4     3       thread  Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
             Name  Flags
      mergeSource  
      merge        

  synchronized void runOnMergeFinished(org.apache.lucene.index.MergeScheduler$MergeSource);
    descriptor: (Lorg/apache/lucene/index/MergeScheduler$MergeSource;)V
    flags: (0x0020) ACC_SYNCHRONIZED
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // org.apache.lucene.index.MergeScheduler$MergeSource mergeSource
         0: .line 639
            getstatic org.apache.lucene.index.ConcurrentMergeScheduler.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
            ifne 1
            new java.lang.AssertionError
            dup
            ldc "caller is not a merge thread"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 642
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* mergeSource */
            getstatic org.apache.lucene.index.MergeTrigger.MERGE_FINISHED:Lorg/apache/lucene/index/MergeTrigger;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.merge:(Lorg/apache/lucene/index/MergeScheduler$MergeSource;Lorg/apache/lucene/index/MergeTrigger;)V
         2: .line 643
            goto 14
      StackMap locals:
      StackMap stack: org.apache.lucene.store.AlreadyClosedException
         3: pop
         4: .line 648
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.removeMergeThread:()V
         5: .line 649
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.updateMergeThreads:()V
         6: .line 652
            aload 0 /* this */
            invokevirtual java.lang.Object.notifyAll:()V
            goto 17
         7: .line 645
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 2 /* ioe */
        start local 2 // java.io.IOException ioe
         8: .line 646
            new java.io.UncheckedIOException
            dup
            aload 2 /* ioe */
            invokespecial java.io.UncheckedIOException.<init>:(Ljava/io/IOException;)V
            athrow
        end local 2 // java.io.IOException ioe
         9: .line 647
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 3
        10: .line 648
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.removeMergeThread:()V
        11: .line 649
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.updateMergeThreads:()V
        12: .line 652
            aload 0 /* this */
            invokevirtual java.lang.Object.notifyAll:()V
        13: .line 653
            aload 3
            athrow
        14: .line 648
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.removeMergeThread:()V
        15: .line 649
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.updateMergeThreads:()V
        16: .line 652
            aload 0 /* this */
            invokevirtual java.lang.Object.notifyAll:()V
        17: .line 654
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.lucene.index.MergeScheduler$MergeSource mergeSource
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   18     0         this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0   18     1  mergeSource  Lorg/apache/lucene/index/MergeScheduler$MergeSource;
            8    9     2          ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1     2       3  Class org.apache.lucene.store.AlreadyClosedException
           1     2       7  Class java.io.IOException
           1     4       9  any
           7     9       9  any
    MethodParameters:
             Name  Flags
      mergeSource  

  protected void handleMergeException(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // java.lang.Throwable exc
         0: .line 703
            new org.apache.lucene.index.MergePolicy$MergeException
            dup
            aload 1 /* exc */
            invokespecial org.apache.lucene.index.MergePolicy$MergeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.lang.Throwable exc
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0    1     1   exc  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      exc   

  void setSuppressExceptions();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 710
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 2
         1: .line 711
            aload 0 /* this */
            ldc "will suppress merge exceptions"
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
         2: .line 713
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.suppressExceptions:Z
         3: .line 714
            return
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  void clearSuppressExceptions();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 718
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 2
         1: .line 719
            aload 0 /* this */
            ldc "will not suppress merge exceptions"
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
         2: .line 721
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.suppressExceptions:Z
         3: .line 722
            return
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 726
            new java.lang.StringBuilder
            dup
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getSimpleName:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ": "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuilder sb
         1: .line 727
            aload 1 /* sb */
            ldc "maxThreadCount="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ", "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         2: .line 728
            aload 1 /* sb */
            ldc "maxMergeCount="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.maxMergeCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ", "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         3: .line 729
            aload 1 /* sb */
            ldc "ioThrottle="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.doAutoIOThrottle:Z
            invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
            pop
         4: .line 730
            aload 1 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuilder sb
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            1    5     1    sb  Ljava/lang/StringBuilder;

  private boolean isBacklog(long, org.apache.lucene.index.MergePolicy$OneMerge);
    descriptor: (JLorg/apache/lucene/index/MergePolicy$OneMerge;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=14, args_size=3
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // long now
        start local 3 // org.apache.lucene.index.MergePolicy$OneMerge merge
         0: .line 734
            aload 3 /* merge */
            getfield org.apache.lucene.index.MergePolicy$OneMerge.estimatedMergeBytes:J
            invokestatic org.apache.lucene.index.ConcurrentMergeScheduler.bytesToMB:(J)D
            dstore 4 /* mergeMB */
        start local 4 // double mergeMB
         1: .line 735
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 7
            goto 12
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler long org.apache.lucene.index.MergePolicy$OneMerge double top java.util.Iterator
      StackMap stack:
         2: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
            astore 6 /* mergeThread */
        start local 6 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
         3: .line 736
            aload 6 /* mergeThread */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.merge:Lorg/apache/lucene/index/MergePolicy$OneMerge;
            getfield org.apache.lucene.index.MergePolicy$OneMerge.mergeStartNS:J
            lstore 8 /* mergeStartNS */
        start local 8 // long mergeStartNS
         4: .line 737
            aload 6 /* mergeThread */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.isAlive:()Z
            ifeq 12
            aload 6 /* mergeThread */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.merge:Lorg/apache/lucene/index/MergePolicy$OneMerge;
            aload 3 /* merge */
            if_acmpeq 12
         5: .line 738
            lload 8 /* mergeStartNS */
            ldc -1
            lcmp
            ifeq 12
         6: .line 739
            aload 6 /* mergeThread */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.merge:Lorg/apache/lucene/index/MergePolicy$OneMerge;
            getfield org.apache.lucene.index.MergePolicy$OneMerge.estimatedMergeBytes:J
            l2d
            ldc 5.24288E7
            dcmpl
            iflt 12
         7: .line 740
            lload 1 /* now */
            lload 8 /* mergeStartNS */
            lsub
            invokestatic org.apache.lucene.index.ConcurrentMergeScheduler.nsToSec:(J)D
            ldc 3.0
            dcmpl
            ifle 12
         8: .line 741
            aload 6 /* mergeThread */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.merge:Lorg/apache/lucene/index/MergePolicy$OneMerge;
            getfield org.apache.lucene.index.MergePolicy$OneMerge.estimatedMergeBytes:J
            invokestatic org.apache.lucene.index.ConcurrentMergeScheduler.bytesToMB:(J)D
            dstore 10 /* otherMergeMB */
        start local 10 // double otherMergeMB
         9: .line 742
            dload 10 /* otherMergeMB */
            dload 4 /* mergeMB */
            ddiv
            dstore 12 /* ratio */
        start local 12 // double ratio
        10: .line 743
            dload 12 /* ratio */
            ldc 0.3
            dcmpl
            ifle 12
            dload 12 /* ratio */
            ldc 3.0
            dcmpg
            ifge 12
        11: .line 744
            iconst_1
            ireturn
        end local 12 // double ratio
        end local 10 // double otherMergeMB
        end local 8 // long mergeStartNS
        end local 6 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
        12: .line 735
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        13: .line 749
            iconst_0
            ireturn
        end local 4 // double mergeMB
        end local 3 // org.apache.lucene.index.MergePolicy$OneMerge merge
        end local 1 // long now
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   14     0          this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0   14     1           now  J
            0   14     3         merge  Lorg/apache/lucene/index/MergePolicy$OneMerge;
            1   14     4       mergeMB  D
            3   12     6   mergeThread  Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
            4   12     8  mergeStartNS  J
            9   12    10  otherMergeMB  D
           10   12    12         ratio  D
    MethodParameters:
       Name  Flags
      now    
      merge  

  private synchronized void updateIOThrottle(org.apache.lucene.index.MergePolicy$OneMerge, org.apache.lucene.index.MergeRateLimiter);
    descriptor: (Lorg/apache/lucene/index/MergePolicy$OneMerge;Lorg/apache/lucene/index/MergeRateLimiter;)V
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=8, locals=13, args_size=3
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
        start local 1 // org.apache.lucene.index.MergePolicy$OneMerge newMerge
        start local 2 // org.apache.lucene.index.MergeRateLimiter rateLimiter
         0: .line 754
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.doAutoIOThrottle:Z
            ifne 2
         1: .line 755
            return
         2: .line 758
      StackMap locals:
      StackMap stack:
            aload 1 /* newMerge */
            getfield org.apache.lucene.index.MergePolicy$OneMerge.estimatedMergeBytes:J
            invokestatic org.apache.lucene.index.ConcurrentMergeScheduler.bytesToMB:(J)D
            dstore 3 /* mergeMB */
        start local 3 // double mergeMB
         3: .line 759
            dload 3 /* mergeMB */
            ldc 50.0
            dcmpg
            ifge 5
         4: .line 762
            return
         5: .line 765
      StackMap locals: double
      StackMap stack:
            invokestatic java.lang.System.nanoTime:()J
            lstore 5 /* now */
        start local 5 // long now
         6: .line 770
            aload 0 /* this */
            lload 5 /* now */
            aload 1 /* newMerge */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.isBacklog:(JLorg/apache/lucene/index/MergePolicy$OneMerge;)Z
            istore 7 /* newBacklog */
        start local 7 // boolean newBacklog
         7: .line 772
            iconst_0
            istore 8 /* curBacklog */
        start local 8 // boolean curBacklog
         8: .line 774
            iload 7 /* newBacklog */
            ifne 18
         9: .line 775
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.maxThreadCount:I
            if_icmple 12
        10: .line 777
            iconst_1
            istore 8 /* curBacklog */
        11: .line 778
            goto 18
        12: .line 780
      StackMap locals: long int int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.mergeThreads:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 10
            goto 17
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler org.apache.lucene.index.MergePolicy$OneMerge org.apache.lucene.index.MergeRateLimiter double long int int top java.util.Iterator
      StackMap stack:
        13: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
            astore 9 /* mergeThread */
        start local 9 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
        14: .line 781
            aload 0 /* this */
            lload 5 /* now */
            aload 9 /* mergeThread */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread.merge:Lorg/apache/lucene/index/MergePolicy$OneMerge;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.isBacklog:(JLorg/apache/lucene/index/MergePolicy$OneMerge;)Z
            ifeq 17
        15: .line 782
            iconst_1
            istore 8 /* curBacklog */
        16: .line 783
            goto 18
        end local 9 // org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread mergeThread
        17: .line 780
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 13
        18: .line 789
      StackMap locals: org.apache.lucene.index.ConcurrentMergeScheduler org.apache.lucene.index.MergePolicy$OneMerge org.apache.lucene.index.MergeRateLimiter double long int int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            dstore 9 /* curMBPerSec */
        start local 9 // double curMBPerSec
        19: .line 791
            iload 7 /* newBacklog */
            ifeq 29
        20: .line 793
            aload 0 /* this */
            dup
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            ldc 1.2
            dmul
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
        21: .line 794
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            ldc 10240.0
            dcmpl
            ifle 23
        22: .line 795
            aload 0 /* this */
            ldc 10240.0
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
        23: .line 797
      StackMap locals: double
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 43
        24: .line 798
            dload 9 /* curMBPerSec */
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            dcmpl
            ifne 27
        25: .line 799
            aload 0 /* this */
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            ldc "io throttle: new merge backlog; leave IO rate at ceiling %.1f MB/sec"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
        26: .line 800
            goto 43
        27: .line 801
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            ldc "io throttle: new merge backlog; increase IO rate to %.1f MB/sec"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
        28: .line 804
            goto 43
      StackMap locals:
      StackMap stack:
        29: iload 8 /* curBacklog */
            ifeq 35
        30: .line 806
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 43
        31: .line 807
            aload 0 /* this */
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            ldc "io throttle: current merge backlog; leave IO rate at %.1f MB/sec"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
        32: .line 808
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
        33: .line 807
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
        34: .line 810
            goto 43
        35: .line 812
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            ldc 1.1
            ddiv
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
        36: .line 813
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            ldc 5.0
            dcmpg
            ifge 38
        37: .line 814
            aload 0 /* this */
            ldc 5.0
            putfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
        38: .line 816
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.verbose:()Z
            ifeq 43
        39: .line 817
            dload 9 /* curMBPerSec */
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            dcmpl
            ifne 42
        40: .line 818
            aload 0 /* this */
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            ldc "io throttle: no merge backlog; leave IO rate at floor %.1f MB/sec"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
        41: .line 819
            goto 43
        42: .line 820
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            ldc "io throttle: no merge backlog; decrease IO rate to %.1f MB/sec"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.message:(Ljava/lang/String;)V
        43: .line 827
      StackMap locals:
      StackMap stack:
            aload 1 /* newMerge */
            getfield org.apache.lucene.index.MergePolicy$OneMerge.maxNumSegments:I
            iconst_m1
            if_icmpeq 46
        44: .line 828
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.forceMergeMBPerSec:D
            dstore 11 /* rate */
        start local 11 // double rate
        45: .line 829
            goto 47
        end local 11 // double rate
        46: .line 830
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSec:D
            dstore 11 /* rate */
        start local 11 // double rate
        47: .line 832
      StackMap locals: double
      StackMap stack:
            aload 2 /* rateLimiter */
            dload 11 /* rate */
            invokevirtual org.apache.lucene.index.MergeRateLimiter.setMBPerSec:(D)V
        48: .line 833
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.ConcurrentMergeScheduler.targetMBPerSecChanged:()V
        49: .line 834
            return
        end local 11 // double rate
        end local 9 // double curMBPerSec
        end local 8 // boolean curBacklog
        end local 7 // boolean newBacklog
        end local 5 // long now
        end local 3 // double mergeMB
        end local 2 // org.apache.lucene.index.MergeRateLimiter rateLimiter
        end local 1 // org.apache.lucene.index.MergePolicy$OneMerge newMerge
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   50     0         this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;
            0   50     1     newMerge  Lorg/apache/lucene/index/MergePolicy$OneMerge;
            0   50     2  rateLimiter  Lorg/apache/lucene/index/MergeRateLimiter;
            3   50     3      mergeMB  D
            6   50     5          now  J
            7   50     7   newBacklog  Z
            8   50     8   curBacklog  Z
           14   17     9  mergeThread  Lorg/apache/lucene/index/ConcurrentMergeScheduler$MergeThread;
           19   50     9  curMBPerSec  D
           45   46    11         rate  D
           47   50    11         rate  D
    Exceptions:
      throws java.io.IOException
    MethodParameters:
             Name  Flags
      newMerge     
      rateLimiter  

  protected void targetMBPerSecChanged();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=0, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
         0: .line 838
            return
        end local 0 // org.apache.lucene.index.ConcurrentMergeScheduler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/ConcurrentMergeScheduler;

  private static double nsToSec(long);
    descriptor: (J)D
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // long ns
         0: .line 841
            lload 0 /* ns */
            l2d
            ldc 1.0E9
            ddiv
            dreturn
        end local 0 // long ns
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0    ns  J
    MethodParameters:
      Name  Flags
      ns    

  private static double bytesToMB(long);
    descriptor: (J)D
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // long bytes
         0: .line 845
            lload 0 /* bytes */
            l2d
            ldc 1024.0
            ddiv
            ldc 1024.0
            ddiv
            dreturn
        end local 0 // long bytes
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0  bytes  J
    MethodParameters:
       Name  Flags
      bytes  
}
SourceFile: "ConcurrentMergeScheduler.java"
NestMembers:
  org.apache.lucene.index.ConcurrentMergeScheduler$1  org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread
InnerClasses:
  org.apache.lucene.index.ConcurrentMergeScheduler$1
  protected MergeThread = org.apache.lucene.index.ConcurrentMergeScheduler$MergeThread of org.apache.lucene.index.ConcurrentMergeScheduler
  public MergeException = org.apache.lucene.index.MergePolicy$MergeException of org.apache.lucene.index.MergePolicy
  public OneMerge = org.apache.lucene.index.MergePolicy$OneMerge of org.apache.lucene.index.MergePolicy
  public abstract MergeSource = org.apache.lucene.index.MergeScheduler$MergeSource of org.apache.lucene.index.MergeScheduler