final class org.apache.lucene.index.DocumentsWriterPerThread implements org.apache.lucene.util.Accountable
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: org.apache.lucene.index.DocumentsWriterPerThread
  super_class: java.lang.Object
{
  private java.lang.Throwable abortingException;
    descriptor: Ljava/lang/Throwable;
    flags: (0x0002) ACC_PRIVATE

  static final org.apache.lucene.index.DocumentsWriterPerThread$IndexingChain defaultIndexingChain;
    descriptor: Lorg/apache/lucene/index/DocumentsWriterPerThread$IndexingChain;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  private static final boolean INFO_VERBOSE;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  final org.apache.lucene.codecs.Codec codec;
    descriptor: Lorg/apache/lucene/codecs/Codec;
    flags: (0x0010) ACC_FINAL

  final org.apache.lucene.store.TrackingDirectoryWrapper directory;
    descriptor: Lorg/apache/lucene/store/TrackingDirectoryWrapper;
    flags: (0x0010) ACC_FINAL

  private final org.apache.lucene.index.DocConsumer consumer;
    descriptor: Lorg/apache/lucene/index/DocConsumer;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.apache.lucene.index.BufferedUpdates pendingUpdates;
    descriptor: Lorg/apache/lucene/index/BufferedUpdates;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.apache.lucene.index.SegmentInfo segmentInfo;
    descriptor: Lorg/apache/lucene/index/SegmentInfo;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

  private org.apache.lucene.util.SetOnce<java.lang.Boolean> flushPending;
    descriptor: Lorg/apache/lucene/util/SetOnce;
    flags: (0x0002) ACC_PRIVATE
    Signature: Lorg/apache/lucene/util/SetOnce<Ljava/lang/Boolean;>;

  private volatile long lastCommittedBytesUsed;
    descriptor: J
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private org.apache.lucene.util.SetOnce<java.lang.Boolean> hasFlushed;
    descriptor: Lorg/apache/lucene/util/SetOnce;
    flags: (0x0002) ACC_PRIVATE
    Signature: Lorg/apache/lucene/util/SetOnce<Ljava/lang/Boolean;>;

  private final org.apache.lucene.index.FieldInfos$Builder fieldInfos;
    descriptor: Lorg/apache/lucene/index/FieldInfos$Builder;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.apache.lucene.util.InfoStream infoStream;
    descriptor: Lorg/apache/lucene/util/InfoStream;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

  final org.apache.lucene.index.DocumentsWriterDeleteQueue deleteQueue;
    descriptor: Lorg/apache/lucene/index/DocumentsWriterDeleteQueue;
    flags: (0x0010) ACC_FINAL

  private final org.apache.lucene.index.DocumentsWriterDeleteQueue$DeleteSlice deleteSlice;
    descriptor: Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.text.NumberFormat nf;
    descriptor: Ljava/text/NumberFormat;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.AtomicLong pendingNumDocs;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.apache.lucene.index.LiveIndexWriterConfig indexWriterConfig;
    descriptor: Lorg/apache/lucene/index/LiveIndexWriterConfig;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final boolean enableTestPoints;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.locks.ReentrantLock lock;
    descriptor: Ljava/util/concurrent/locks/ReentrantLock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private int[] deleteDocIDs;
    descriptor: [I
    flags: (0x0002) ACC_PRIVATE

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

  private final java.util.Set<java.lang.String> filesToDelete;
    descriptor: Ljava/util/Set;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Set<Ljava/lang/String;>;

  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=2, locals=0, args_size=0
         0: .line 48
            ldc Lorg/apache/lucene/index/DocumentsWriterPerThread;
            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.DocumentsWriterPerThread.$assertionsDisabled:Z
         3: .line 73
            new org.apache.lucene.index.DocumentsWriterPerThread$1
            dup
            invokespecial org.apache.lucene.index.DocumentsWriterPerThread$1.<init>:()V
            putstatic org.apache.lucene.index.DocumentsWriterPerThread.defaultIndexingChain:Lorg/apache/lucene/index/DocumentsWriterPerThread$IndexingChain;
         4: .line 124
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void onAbortingException(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
        start local 1 // java.lang.Throwable throwable
         0: .line 64
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 1
            aload 1 /* throwable */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            ldc "aborting exception must not be null"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 65
      StackMap locals:
      StackMap stack:
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 2
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.abortingException:Ljava/lang/Throwable;
            ifnull 2
            new java.lang.AssertionError
            dup
            ldc "aborting exception has already been set"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         2: .line 66
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* throwable */
            putfield org.apache.lucene.index.DocumentsWriterPerThread.abortingException:Ljava/lang/Throwable;
         3: .line 67
            return
        end local 1 // java.lang.Throwable throwable
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0       this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            0    4     1  throwable  Ljava/lang/Throwable;
    MethodParameters:
           Name  Flags
      throwable  

  final boolean isAborted();
    descriptor: ()Z
    flags: (0x0010) ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 70
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.aborted:Z
            ireturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  void abort();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 107
            aload 0 /* this */
            iconst_1
            putfield org.apache.lucene.index.DocumentsWriterPerThread.aborted:Z
         1: .line 108
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingNumDocs:Ljava/util/concurrent/atomic/AtomicLong;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            ineg
            i2l
            invokevirtual java.util.concurrent.atomic.AtomicLong.addAndGet:(J)J
            pop2
         2: .line 110
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifeq 4
         3: .line 111
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            ldc "now abort"
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
         4: .line 114
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.consumer:Lorg/apache/lucene/index/DocConsumer;
            invokevirtual org.apache.lucene.index.DocConsumer.abort:()V
         5: .line 115
            goto 9
      StackMap locals:
      StackMap stack: java.lang.Throwable
         6: astore 1
         7: .line 116
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            invokevirtual org.apache.lucene.index.BufferedUpdates.clear:()V
         8: .line 117
            aload 1
            athrow
         9: .line 116
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            invokevirtual org.apache.lucene.index.BufferedUpdates.clear:()V
        10: .line 118
            goto 15
      StackMap locals:
      StackMap stack: java.lang.Throwable
        11: astore 2
        12: .line 119
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifeq 14
        13: .line 120
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            ldc "done abort"
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        14: .line 122
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread top java.lang.Throwable
      StackMap stack:
            aload 2
            athrow
        15: .line 119
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifeq 17
        16: .line 120
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            ldc "done abort"
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        17: .line 123
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   18     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
      Exception table:
        from    to  target  type
           4     6       6  any
           2    11      11  any
    Exceptions:
      throws java.io.IOException

  void <init>(int, java.lang.String, org.apache.lucene.store.Directory, org.apache.lucene.store.Directory, org.apache.lucene.index.LiveIndexWriterConfig, org.apache.lucene.index.DocumentsWriterDeleteQueue, org.apache.lucene.index.FieldInfos$Builder, java.util.concurrent.atomic.AtomicLong, boolean);
    descriptor: (ILjava/lang/String;Lorg/apache/lucene/store/Directory;Lorg/apache/lucene/store/Directory;Lorg/apache/lucene/index/LiveIndexWriterConfig;Lorg/apache/lucene/index/DocumentsWriterDeleteQueue;Lorg/apache/lucene/index/FieldInfos$Builder;Ljava/util/concurrent/atomic/AtomicLong;Z)V
    flags: (0x0000) 
    Code:
      stack=14, locals=10, args_size=10
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
        start local 1 // int indexVersionCreated
        start local 2 // java.lang.String segmentName
        start local 3 // org.apache.lucene.store.Directory directoryOrig
        start local 4 // org.apache.lucene.store.Directory directory
        start local 5 // org.apache.lucene.index.LiveIndexWriterConfig indexWriterConfig
        start local 6 // org.apache.lucene.index.DocumentsWriterDeleteQueue deleteQueue
        start local 7 // org.apache.lucene.index.FieldInfos$Builder fieldInfos
        start local 8 // java.util.concurrent.atomic.AtomicLong pendingNumDocs
        start local 9 // boolean enableTestPoints
         0: .line 150
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 132
            aload 0 /* this */
            iconst_0
            putfield org.apache.lucene.index.DocumentsWriterPerThread.aborted:Z
         2: .line 133
            aload 0 /* this */
            new org.apache.lucene.util.SetOnce
            dup
            invokespecial org.apache.lucene.util.SetOnce.<init>:()V
            putfield org.apache.lucene.index.DocumentsWriterPerThread.flushPending:Lorg/apache/lucene/util/SetOnce;
         3: .line 135
            aload 0 /* this */
            new org.apache.lucene.util.SetOnce
            dup
            invokespecial org.apache.lucene.util.SetOnce.<init>:()V
            putfield org.apache.lucene.index.DocumentsWriterPerThread.hasFlushed:Lorg/apache/lucene/util/SetOnce;
         4: .line 142
            aload 0 /* this */
            getstatic java.util.Locale.ROOT:Ljava/util/Locale;
            invokestatic java.text.NumberFormat.getInstance:(Ljava/util/Locale;)Ljava/text/NumberFormat;
            putfield org.apache.lucene.index.DocumentsWriterPerThread.nf:Ljava/text/NumberFormat;
         5: .line 146
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
            putfield org.apache.lucene.index.DocumentsWriterPerThread.lock:Ljava/util/concurrent/locks/ReentrantLock;
         6: .line 147
            aload 0 /* this */
            iconst_0
            newarray 10
            putfield org.apache.lucene.index.DocumentsWriterPerThread.deleteDocIDs:[I
         7: .line 148
            aload 0 /* this */
            iconst_0
            putfield org.apache.lucene.index.DocumentsWriterPerThread.numDeletedDocIds:I
         8: .line 421
            aload 0 /* this */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield org.apache.lucene.index.DocumentsWriterPerThread.filesToDelete:Ljava/util/Set;
         9: .line 153
            aload 0 /* this */
            new org.apache.lucene.store.TrackingDirectoryWrapper
            dup
            aload 4 /* directory */
            invokespecial org.apache.lucene.store.TrackingDirectoryWrapper.<init>:(Lorg/apache/lucene/store/Directory;)V
            putfield org.apache.lucene.index.DocumentsWriterPerThread.directory:Lorg/apache/lucene/store/TrackingDirectoryWrapper;
        10: .line 154
            aload 0 /* this */
            aload 7 /* fieldInfos */
            putfield org.apache.lucene.index.DocumentsWriterPerThread.fieldInfos:Lorg/apache/lucene/index/FieldInfos$Builder;
        11: .line 155
            aload 0 /* this */
            aload 5 /* indexWriterConfig */
            putfield org.apache.lucene.index.DocumentsWriterPerThread.indexWriterConfig:Lorg/apache/lucene/index/LiveIndexWriterConfig;
        12: .line 156
            aload 0 /* this */
            aload 5 /* indexWriterConfig */
            invokevirtual org.apache.lucene.index.LiveIndexWriterConfig.getInfoStream:()Lorg/apache/lucene/util/InfoStream;
            putfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
        13: .line 157
            aload 0 /* this */
            aload 5 /* indexWriterConfig */
            invokevirtual org.apache.lucene.index.LiveIndexWriterConfig.getCodec:()Lorg/apache/lucene/codecs/Codec;
            putfield org.apache.lucene.index.DocumentsWriterPerThread.codec:Lorg/apache/lucene/codecs/Codec;
        14: .line 158
            aload 0 /* this */
            aload 8 /* pendingNumDocs */
            putfield org.apache.lucene.index.DocumentsWriterPerThread.pendingNumDocs:Ljava/util/concurrent/atomic/AtomicLong;
        15: .line 159
            aload 0 /* this */
            new org.apache.lucene.index.BufferedUpdates
            dup
            aload 2 /* segmentName */
            invokespecial org.apache.lucene.index.BufferedUpdates.<init>:(Ljava/lang/String;)V
            putfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
        16: .line 160
            aload 0 /* this */
            aload 6 /* deleteQueue */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.lucene.index.DocumentsWriterDeleteQueue
            putfield org.apache.lucene.index.DocumentsWriterPerThread.deleteQueue:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue;
        17: .line 161
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 18
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            ifeq 18
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "num docs "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        18: .line 162
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread int java.lang.String org.apache.lucene.store.Directory org.apache.lucene.store.Directory org.apache.lucene.index.LiveIndexWriterConfig org.apache.lucene.index.DocumentsWriterDeleteQueue org.apache.lucene.index.FieldInfos$Builder java.util.concurrent.atomic.AtomicLong int
      StackMap stack:
            aload 0 /* this */
            aload 6 /* deleteQueue */
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue.newSlice:()Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            putfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
        19: .line 164
            aload 0 /* this */
            new org.apache.lucene.index.SegmentInfo
            dup
            aload 3 /* directoryOrig */
            getstatic org.apache.lucene.util.Version.LATEST:Lorg/apache/lucene/util/Version;
            getstatic org.apache.lucene.util.Version.LATEST:Lorg/apache/lucene/util/Version;
            aload 2 /* segmentName */
            iconst_m1
            iconst_0
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.codec:Lorg/apache/lucene/codecs/Codec;
            invokestatic java.util.Collections.emptyMap:()Ljava/util/Map;
            invokestatic org.apache.lucene.util.StringHelper.randomId:()[B
            invokestatic java.util.Collections.emptyMap:()Ljava/util/Map;
            aload 5 /* indexWriterConfig */
            invokevirtual org.apache.lucene.index.LiveIndexWriterConfig.getIndexSort:()Lorg/apache/lucene/search/Sort;
            invokespecial org.apache.lucene.index.SegmentInfo.<init>:(Lorg/apache/lucene/store/Directory;Lorg/apache/lucene/util/Version;Lorg/apache/lucene/util/Version;Ljava/lang/String;IZLorg/apache/lucene/codecs/Codec;Ljava/util/Map;[BLjava/util/Map;Lorg/apache/lucene/search/Sort;)V
            putfield org.apache.lucene.index.DocumentsWriterPerThread.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
        20: .line 165
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 21
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            ifeq 21
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        21: .line 169
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 9 /* enableTestPoints */
            putfield org.apache.lucene.index.DocumentsWriterPerThread.enableTestPoints:Z
        22: .line 170
            aload 0 /* this */
            aload 5 /* indexWriterConfig */
            invokevirtual org.apache.lucene.index.LiveIndexWriterConfig.getIndexingChain:()Lorg/apache/lucene/index/DocumentsWriterPerThread$IndexingChain;
            iload 1 /* indexVersionCreated */
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.directory:Lorg/apache/lucene/store/TrackingDirectoryWrapper;
            aload 7 /* fieldInfos */
            aload 5 /* indexWriterConfig */
            aload 0 /* this */
            invokedynamic accept(Lorg/apache/lucene/index/DocumentsWriterPerThread;)Ljava/util/function/Consumer;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)V
                  org/apache/lucene/index/DocumentsWriterPerThread.onAbortingException(Ljava/lang/Throwable;)V (7)
                  (Ljava/lang/Throwable;)V
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread$IndexingChain.getChain:(ILorg/apache/lucene/index/SegmentInfo;Lorg/apache/lucene/store/Directory;Lorg/apache/lucene/index/FieldInfos$Builder;Lorg/apache/lucene/index/LiveIndexWriterConfig;Ljava/util/function/Consumer;)Lorg/apache/lucene/index/DocConsumer;
            putfield org.apache.lucene.index.DocumentsWriterPerThread.consumer:Lorg/apache/lucene/index/DocConsumer;
        23: .line 171
            return
        end local 9 // boolean enableTestPoints
        end local 8 // java.util.concurrent.atomic.AtomicLong pendingNumDocs
        end local 7 // org.apache.lucene.index.FieldInfos$Builder fieldInfos
        end local 6 // org.apache.lucene.index.DocumentsWriterDeleteQueue deleteQueue
        end local 5 // org.apache.lucene.index.LiveIndexWriterConfig indexWriterConfig
        end local 4 // org.apache.lucene.store.Directory directory
        end local 3 // org.apache.lucene.store.Directory directoryOrig
        end local 2 // java.lang.String segmentName
        end local 1 // int indexVersionCreated
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   24     0                 this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            0   24     1  indexVersionCreated  I
            0   24     2          segmentName  Ljava/lang/String;
            0   24     3        directoryOrig  Lorg/apache/lucene/store/Directory;
            0   24     4            directory  Lorg/apache/lucene/store/Directory;
            0   24     5    indexWriterConfig  Lorg/apache/lucene/index/LiveIndexWriterConfig;
            0   24     6          deleteQueue  Lorg/apache/lucene/index/DocumentsWriterDeleteQueue;
            0   24     7           fieldInfos  Lorg/apache/lucene/index/FieldInfos$Builder;
            0   24     8       pendingNumDocs  Ljava/util/concurrent/atomic/AtomicLong;
            0   24     9     enableTestPoints  Z
    MethodParameters:
                     Name  Flags
      indexVersionCreated  
      segmentName          
      directoryOrig        
      directory            
      indexWriterConfig    
      deleteQueue          
      fieldInfos           
      pendingNumDocs       
      enableTestPoints     

  final void testPoint(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0010) ACC_FINAL
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
        start local 1 // java.lang.String message
         0: .line 174
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.enableTestPoints:Z
            ifeq 3
         1: .line 175
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 2
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "TP"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifne 2
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 176
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "TP"
            aload 1 /* message */
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
         3: .line 178
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String message
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    4     0     this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            0    4     1  message  Ljava/lang/String;
    MethodParameters:
         Name  Flags
      message  

  private void reserveOneDoc();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 183
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingNumDocs:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.incrementAndGet:()J
            invokestatic org.apache.lucene.index.IndexWriter.getActualMaxDocs:()I
            i2l
            lcmp
            ifle 3
         1: .line 185
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingNumDocs:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.decrementAndGet:()J
            pop2
         2: .line 186
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "number of documents in the index cannot exceed "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            invokestatic org.apache.lucene.index.IndexWriter.getActualMaxDocs:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 188
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  long updateDocuments(java.lang.Iterable<? extends java.lang.Iterable<? extends org.apache.lucene.index.IndexableField>>, org.apache.lucene.index.DocumentsWriterDeleteQueue$Node<?>, org.apache.lucene.index.DocumentsWriter$FlushNotifications);
    descriptor: (Ljava/lang/Iterable;Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$Node;Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;)J
    flags: (0x0000) 
    Code:
      stack=5, locals=12, args_size=4
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
        start local 1 // java.lang.Iterable docs
        start local 2 // org.apache.lucene.index.DocumentsWriterDeleteQueue$Node deleteNode
        start local 3 // org.apache.lucene.index.DocumentsWriter$FlushNotifications flushNotifications
         0: .line 192
            aload 0 /* this */
            ldc "DocumentsWriterPerThread addDocuments start"
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.testPoint:(Ljava/lang/String;)V
         1: .line 193
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 2
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.abortingException:Ljava/lang/Throwable;
            ifnull 2
            new java.lang.AssertionError
            dup
            ldc "DWPT has hit aborting exception but is still indexing"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         2: .line 197
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            istore 4 /* docsInRamBefore */
        start local 4 // int docsInRamBefore
         3: .line 198
            iconst_0
            istore 5 /* allDocsIndexed */
        start local 5 // boolean allDocsIndexed
         4: .line 200
            aload 1 /* docs */
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 7
            goto 8
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread java.lang.Iterable org.apache.lucene.index.DocumentsWriterDeleteQueue$Node org.apache.lucene.index.DocumentsWriter$FlushNotifications int int top java.util.Iterator
      StackMap stack:
         5: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Iterable
            astore 6 /* doc */
        start local 6 // java.lang.Iterable doc
         6: .line 207
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.reserveOneDoc:()V
         7: .line 208
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.consumer:Lorg/apache/lucene/index/DocConsumer;
            aload 0 /* this */
            dup
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            dup_x1
            iconst_1
            iadd
            putfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            aload 6 /* doc */
            invokevirtual org.apache.lucene.index.DocConsumer.processDocument:(ILjava/lang/Iterable;)V
        end local 6 // java.lang.Iterable doc
         8: .line 200
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         9: .line 210
            iconst_1
            istore 5 /* allDocsIndexed */
        10: .line 211
            aload 0 /* this */
            aload 2 /* deleteNode */
            iload 4 /* docsInRamBefore */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.finishDocuments:(Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$Node;I)J
            lstore 9
        11: .line 213
            iload 5 /* allDocsIndexed */
            ifne 13
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.aborted:Z
            ifne 13
        12: .line 216
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            iload 4 /* docsInRamBefore */
            isub
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.deleteLastDocs:(I)V
        13: .line 220
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread java.lang.Iterable org.apache.lucene.index.DocumentsWriterDeleteQueue$Node org.apache.lucene.index.DocumentsWriter$FlushNotifications int int top top top long
      StackMap stack:
            aload 0 /* this */
            ldc "updateDocuments"
            aload 3 /* flushNotifications */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.maybeAbort:(Ljava/lang/String;Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;)V
        14: .line 211
            lload 9
            lreturn
        15: .line 212
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread java.lang.Iterable org.apache.lucene.index.DocumentsWriterDeleteQueue$Node org.apache.lucene.index.DocumentsWriter$FlushNotifications int int
      StackMap stack: java.lang.Throwable
            astore 8
        16: .line 213
            iload 5 /* allDocsIndexed */
            ifne 18
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.aborted:Z
            ifne 18
        17: .line 216
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            iload 4 /* docsInRamBefore */
            isub
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.deleteLastDocs:(I)V
        18: .line 218
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread java.lang.Iterable org.apache.lucene.index.DocumentsWriterDeleteQueue$Node org.apache.lucene.index.DocumentsWriter$FlushNotifications int int top top java.lang.Throwable
      StackMap stack:
            aload 8
            athrow
        end local 5 // boolean allDocsIndexed
        end local 4 // int docsInRamBefore
        19: .line 219
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread java.lang.Iterable org.apache.lucene.index.DocumentsWriterDeleteQueue$Node org.apache.lucene.index.DocumentsWriter$FlushNotifications
      StackMap stack: java.lang.Throwable
            astore 11
        20: .line 220
            aload 0 /* this */
            ldc "updateDocuments"
            aload 3 /* flushNotifications */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.maybeAbort:(Ljava/lang/String;Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;)V
        21: .line 221
            aload 11
            athrow
        end local 3 // org.apache.lucene.index.DocumentsWriter$FlushNotifications flushNotifications
        end local 2 // org.apache.lucene.index.DocumentsWriterDeleteQueue$Node deleteNode
        end local 1 // java.lang.Iterable docs
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   22     0                this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            0   22     1                docs  Ljava/lang/Iterable<+Ljava/lang/Iterable<+Lorg/apache/lucene/index/IndexableField;>;>;
            0   22     2          deleteNode  Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$Node<*>;
            0   22     3  flushNotifications  Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;
            3   19     4     docsInRamBefore  I
            4   19     5      allDocsIndexed  Z
            6    8     6                 doc  Ljava/lang/Iterable<+Lorg/apache/lucene/index/IndexableField;>;
      Exception table:
        from    to  target  type
           4    11      15  any
           0    13      19  any
          15    19      19  any
    Exceptions:
      throws java.io.IOException
    Signature: (Ljava/lang/Iterable<+Ljava/lang/Iterable<+Lorg/apache/lucene/index/IndexableField;>;>;Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$Node<*>;Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;)J
    MethodParameters:
                    Name  Flags
      docs                
      deleteNode          
      flushNotifications  

  private long finishDocuments(org.apache.lucene.index.DocumentsWriterDeleteQueue$Node<?>, );
    descriptor: (Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$Node;I)J
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=5, args_size=3
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
        start local 1 // org.apache.lucene.index.DocumentsWriterDeleteQueue$Node deleteNode
        start local 2 // int docIdUpTo
         0: .line 237
            aload 1 /* deleteNode */
            ifnull 5
         1: .line 238
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteQueue:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue;
            aload 1 /* deleteNode */
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue.add:(Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$Node;Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;)J
            lstore 3 /* seqNo */
        start local 3 // long seqNo
         2: .line 239
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 3
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            aload 1 /* deleteNode */
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue$DeleteSlice.isTail:(Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$Node;)Z
            ifne 3
            new java.lang.AssertionError
            dup
            ldc "expected the delete term as the tail item"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         3: .line 240
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            iload 2 /* docIdUpTo */
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue$DeleteSlice.apply:(Lorg/apache/lucene/index/BufferedUpdates;I)V
         4: .line 241
            lload 3 /* seqNo */
            lreturn
        end local 3 // long seqNo
         5: .line 243
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteQueue:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue.updateSlice:(Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;)J
            lstore 3 /* seqNo */
        start local 3 // long seqNo
         6: .line 244
            lload 3 /* seqNo */
            lconst_0
            lcmp
            ifge 10
         7: .line 245
            lload 3 /* seqNo */
            lneg
            lstore 3 /* seqNo */
         8: .line 246
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            iload 2 /* docIdUpTo */
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue$DeleteSlice.apply:(Lorg/apache/lucene/index/BufferedUpdates;I)V
         9: .line 247
            goto 11
        10: .line 248
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue$DeleteSlice.reset:()V
        11: .line 252
      StackMap locals:
      StackMap stack:
            lload 3 /* seqNo */
            lreturn
        end local 3 // long seqNo
        end local 2 // int docIdUpTo
        end local 1 // org.apache.lucene.index.DocumentsWriterDeleteQueue$Node deleteNode
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   12     0        this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            0   12     1  deleteNode  Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$Node<*>;
            0   12     2   docIdUpTo  I
            2    5     3       seqNo  J
            6   12     3       seqNo  J
    Signature: (Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$Node<*>;I)J
    MethodParameters:
            Name  Flags
      deleteNode  
      docIdUpTo   

  private void deleteLastDocs(int);
    descriptor: (I)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
        start local 1 // int docCount
         0: .line 263
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            iload 1 /* docCount */
            isub
            istore 2 /* from */
        start local 2 // int from
         1: .line 264
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            istore 3 /* to */
        start local 3 // int to
         2: .line 265
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteDocIDs:[I
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDeletedDocIds:I
            iload 3 /* to */
            iload 2 /* from */
            isub
            iadd
            invokestatic org.apache.lucene.util.ArrayUtil.grow:([II)[I
            putfield org.apache.lucene.index.DocumentsWriterPerThread.deleteDocIDs:[I
         3: .line 266
            iload 2 /* from */
            istore 4 /* docId */
        start local 4 // int docId
         4: goto 7
         5: .line 267
      StackMap locals: int int int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteDocIDs:[I
            aload 0 /* this */
            dup
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDeletedDocIds:I
            dup_x1
            iconst_1
            iadd
            putfield org.apache.lucene.index.DocumentsWriterPerThread.numDeletedDocIds:I
            iload 4 /* docId */
            iastore
         6: .line 266
            iinc 4 /* docId */ 1
      StackMap locals:
      StackMap stack:
         7: iload 4 /* docId */
            iload 3 /* to */
            if_icmplt 5
        end local 4 // int docId
         8: .line 278
            return
        end local 3 // int to
        end local 2 // int from
        end local 1 // int docCount
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    9     0      this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            0    9     1  docCount  I
            1    9     2      from  I
            2    9     3        to  I
            4    8     4     docId  I
    MethodParameters:
          Name  Flags
      docCount  

  public int getNumDocsInRAM();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 285
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            ireturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  org.apache.lucene.index.FrozenBufferedUpdates prepareFlush();
    descriptor: ()Lorg/apache/lucene/index/FrozenBufferedUpdates;
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 294
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            ifgt 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 295
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteQueue:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue.freezeGlobalBuffer:(Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;)Lorg/apache/lucene/index/FrozenBufferedUpdates;
            astore 1 /* globalUpdates */
        start local 1 // org.apache.lucene.index.FrozenBufferedUpdates globalUpdates
         2: .line 298
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            ifnull 6
         3: .line 300
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue$DeleteSlice.apply:(Lorg/apache/lucene/index/BufferedUpdates;I)V
         4: .line 301
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 5
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue$DeleteSlice.isEmpty:()Z
            ifne 5
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         5: .line 302
      StackMap locals: org.apache.lucene.index.FrozenBufferedUpdates
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue$DeleteSlice.reset:()V
         6: .line 304
      StackMap locals:
      StackMap stack:
            aload 1 /* globalUpdates */
            areturn
        end local 1 // org.apache.lucene.index.FrozenBufferedUpdates globalUpdates
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    7     0           this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            2    7     1  globalUpdates  Lorg/apache/lucene/index/FrozenBufferedUpdates;

  org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment flush(org.apache.lucene.index.DocumentsWriter$FlushNotifications);
    descriptor: (Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;)Lorg/apache/lucene/index/DocumentsWriterPerThread$FlushedSegment;
    flags: (0x0000) 
    Code:
      stack=14, locals=15, args_size=2
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
        start local 1 // org.apache.lucene.index.DocumentsWriter$FlushNotifications flushNotifications
         0: .line 309
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.flushPending:Lorg/apache/lucene/util/SetOnce;
            invokevirtual org.apache.lucene.util.SetOnce.get:()Ljava/lang/Object;
            getstatic java.lang.Boolean.TRUE:Ljava/lang/Boolean;
            if_acmpeq 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 310
      StackMap locals:
      StackMap stack:
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 2
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            ifgt 2
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 311
      StackMap locals:
      StackMap stack:
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 3
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteSlice:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue$DeleteSlice;
            invokevirtual org.apache.lucene.index.DocumentsWriterDeleteQueue$DeleteSlice.isEmpty:()Z
            ifne 3
            new java.lang.AssertionError
            dup
            ldc "all deletes must be applied in prepareFlush"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         3: .line 312
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            invokevirtual org.apache.lucene.index.SegmentInfo.setMaxDoc:(I)V
         4: .line 313
            new org.apache.lucene.index.SegmentWriteState
            dup
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.directory:Lorg/apache/lucene/store/TrackingDirectoryWrapper;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.fieldInfos:Lorg/apache/lucene/index/FieldInfos$Builder;
            invokevirtual org.apache.lucene.index.FieldInfos$Builder.finish:()Lorg/apache/lucene/index/FieldInfos;
         5: .line 314
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            new org.apache.lucene.store.IOContext
            dup
            new org.apache.lucene.store.FlushInfo
            dup
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.lastCommittedBytesUsed:J
            invokespecial org.apache.lucene.store.FlushInfo.<init>:(IJ)V
            invokespecial org.apache.lucene.store.IOContext.<init>:(Lorg/apache/lucene/store/FlushInfo;)V
         6: .line 313
            invokespecial org.apache.lucene.index.SegmentWriteState.<init>:(Lorg/apache/lucene/util/InfoStream;Lorg/apache/lucene/store/Directory;Lorg/apache/lucene/index/SegmentInfo;Lorg/apache/lucene/index/FieldInfos;Lorg/apache/lucene/index/BufferedUpdates;Lorg/apache/lucene/store/IOContext;)V
            astore 2 /* flushState */
        start local 2 // org.apache.lucene.index.SegmentWriteState flushState
         7: .line 315
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.lastCommittedBytesUsed:J
            l2d
            ldc 1024.0
            ddiv
            ldc 1024.0
            ddiv
            dstore 3 /* startMBUsed */
        start local 3 // double startMBUsed
         8: .line 320
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDeletedDocIds:I
            ifle 18
         9: .line 321
            aload 2 /* flushState */
            new org.apache.lucene.util.FixedBitSet
            dup
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            invokespecial org.apache.lucene.util.FixedBitSet.<init>:(I)V
            putfield org.apache.lucene.index.SegmentWriteState.liveDocs:Lorg/apache/lucene/util/FixedBitSet;
        10: .line 322
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.liveDocs:Lorg/apache/lucene/util/FixedBitSet;
            iconst_0
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            invokevirtual org.apache.lucene.util.FixedBitSet.set:(II)V
        11: .line 323
            iconst_0
            istore 5 /* i */
        start local 5 // int i
        12: goto 15
        13: .line 324
      StackMap locals: org.apache.lucene.index.SegmentWriteState double int
      StackMap stack:
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.liveDocs:Lorg/apache/lucene/util/FixedBitSet;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteDocIDs:[I
            iload 5 /* i */
            iaload
            invokevirtual org.apache.lucene.util.FixedBitSet.clear:(I)V
        14: .line 323
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
        15: iload 5 /* i */
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDeletedDocIds:I
            if_icmplt 13
        end local 5 // int i
        16: .line 326
            aload 2 /* flushState */
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDeletedDocIds:I
            putfield org.apache.lucene.index.SegmentWriteState.delCountOnFlush:I
        17: .line 327
            aload 0 /* this */
            iconst_0
            newarray 10
            putfield org.apache.lucene.index.DocumentsWriterPerThread.deleteDocIDs:[I
        18: .line 330
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.aborted:Z
            ifeq 22
        19: .line 331
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifeq 21
        20: .line 332
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            ldc "flush: skip because aborting is set"
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        21: .line 334
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        22: .line 337
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.nanoTime:()J
            lstore 5 /* t0 */
        start local 5 // long t0
        23: .line 339
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifeq 25
        24: .line 340
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            new java.lang.StringBuilder
            dup
            ldc "flush postings as segment "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            getfield org.apache.lucene.index.SegmentInfo.name:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " numDocs="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        25: .line 345
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.indexWriterConfig:Lorg/apache/lucene/index/LiveIndexWriterConfig;
            invokevirtual org.apache.lucene.index.LiveIndexWriterConfig.getSoftDeletesField:()Ljava/lang/String;
            ifnull 28
        26: .line 346
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.consumer:Lorg/apache/lucene/index/DocConsumer;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.indexWriterConfig:Lorg/apache/lucene/index/LiveIndexWriterConfig;
            invokevirtual org.apache.lucene.index.LiveIndexWriterConfig.getSoftDeletesField:()Ljava/lang/String;
            invokevirtual org.apache.lucene.index.DocConsumer.getHasDocValues:(Ljava/lang/String;)Lorg/apache/lucene/search/DocIdSetIterator;
            astore 8 /* softDeletedDocs */
        start local 8 // org.apache.lucene.search.DocIdSetIterator softDeletedDocs
        27: .line 347
            goto 29
        end local 8 // org.apache.lucene.search.DocIdSetIterator softDeletedDocs
        28: .line 348
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 8 /* softDeletedDocs */
        start local 8 // org.apache.lucene.search.DocIdSetIterator softDeletedDocs
        29: .line 350
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long top org.apache.lucene.search.DocIdSetIterator
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.consumer:Lorg/apache/lucene/index/DocConsumer;
            aload 2 /* flushState */
            invokevirtual org.apache.lucene.index.DocConsumer.flush:(Lorg/apache/lucene/index/SegmentWriteState;)Lorg/apache/lucene/index/Sorter$DocMap;
            astore 7 /* sortMap */
        start local 7 // org.apache.lucene.index.Sorter$DocMap sortMap
        30: .line 351
            aload 8 /* softDeletedDocs */
            ifnonnull 33
        31: .line 352
            aload 2 /* flushState */
            iconst_0
            putfield org.apache.lucene.index.SegmentWriteState.softDelCountOnFlush:I
        32: .line 353
            goto 35
        33: .line 354
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator
      StackMap stack:
            aload 2 /* flushState */
            aload 8 /* softDeletedDocs */
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.liveDocs:Lorg/apache/lucene/util/FixedBitSet;
            invokestatic org.apache.lucene.index.PendingSoftDeletes.countSoftDeletes:(Lorg/apache/lucene/search/DocIdSetIterator;Lorg/apache/lucene/util/Bits;)I
            putfield org.apache.lucene.index.SegmentWriteState.softDelCountOnFlush:I
        34: .line 355
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 35
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            invokevirtual org.apache.lucene.index.SegmentInfo.maxDoc:()I
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.softDelCountOnFlush:I
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.delCountOnFlush:I
            iadd
            if_icmpge 35
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        35: .line 358
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            invokevirtual org.apache.lucene.index.BufferedUpdates.clearDeleteTerms:()V
        36: .line 359
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            new java.util.HashSet
            dup
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.directory:Lorg/apache/lucene/store/TrackingDirectoryWrapper;
            invokevirtual org.apache.lucene.store.TrackingDirectoryWrapper.getCreatedFiles:()Ljava/util/Set;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            invokevirtual org.apache.lucene.index.SegmentInfo.setFiles:(Ljava/util/Collection;)V
        37: .line 361
            new org.apache.lucene.index.SegmentCommitInfo
            dup
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            iconst_0
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.softDelCountOnFlush:I
            ldc -1
            ldc -1
            ldc -1
            invokestatic org.apache.lucene.util.StringHelper.randomId:()[B
            invokespecial org.apache.lucene.index.SegmentCommitInfo.<init>:(Lorg/apache/lucene/index/SegmentInfo;IIJJJ[B)V
            astore 9 /* segmentInfoPerCommit */
        start local 9 // org.apache.lucene.index.SegmentCommitInfo segmentInfoPerCommit
        38: .line 362
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifeq 62
        39: .line 363
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            new java.lang.StringBuilder
            dup
            ldc "new segment has "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.liveDocs:Lorg/apache/lucene/util/FixedBitSet;
            ifnonnull 40
            iconst_0
            goto 41
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder
        40: aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.delCountOnFlush:I
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder int
        41: invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " deleted docs"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        42: .line 364
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            new java.lang.StringBuilder
            dup
            ldc "new segment has "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.softDelCountOnFlush:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " soft-deleted docs"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        43: .line 365
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            new java.lang.StringBuilder
            dup
            ldc "new segment has "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        44: .line 366
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.fieldInfos:Lorg/apache/lucene/index/FieldInfos;
            invokevirtual org.apache.lucene.index.FieldInfos.hasVectors:()Z
            ifeq 45
            ldc "vectors"
            goto 46
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder
        45: ldc "no vectors"
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder java.lang.String
        46: invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "; "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        47: .line 367
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.fieldInfos:Lorg/apache/lucene/index/FieldInfos;
            invokevirtual org.apache.lucene.index.FieldInfos.hasNorms:()Z
            ifeq 48
            ldc "norms"
            goto 49
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder
        48: ldc "no norms"
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder java.lang.String
        49: invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "; "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        50: .line 368
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.fieldInfos:Lorg/apache/lucene/index/FieldInfos;
            invokevirtual org.apache.lucene.index.FieldInfos.hasDocValues:()Z
            ifeq 51
            ldc "docValues"
            goto 52
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder
        51: ldc "no docValues"
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder java.lang.String
        52: invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "; "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        53: .line 369
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.fieldInfos:Lorg/apache/lucene/index/FieldInfos;
            invokevirtual org.apache.lucene.index.FieldInfos.hasProx:()Z
            ifeq 54
            ldc "prox"
            goto 55
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder
        54: ldc "no prox"
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder java.lang.String
        55: invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "; "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        56: .line 370
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.fieldInfos:Lorg/apache/lucene/index/FieldInfos;
            invokevirtual org.apache.lucene.index.FieldInfos.hasFreq:()Z
            ifeq 57
            ldc "freqs"
            goto 58
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder
        57: ldc "no freqs"
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long org.apache.lucene.index.Sorter$DocMap org.apache.lucene.search.DocIdSetIterator org.apache.lucene.index.SegmentCommitInfo
      StackMap stack: org.apache.lucene.util.InfoStream java.lang.String java.lang.StringBuilder java.lang.String
        58: invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        59: .line 365
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        60: .line 371
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            new java.lang.StringBuilder
            dup
            ldc "flushedFiles="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 9 /* segmentInfoPerCommit */
            invokevirtual org.apache.lucene.index.SegmentCommitInfo.files:()Ljava/util/Collection;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        61: .line 372
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            new java.lang.StringBuilder
            dup
            ldc "flushed codec="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.codec:Lorg/apache/lucene/codecs/Codec;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        62: .line 376
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            getfield org.apache.lucene.index.BufferedUpdates.deleteQueries:Ljava/util/Map;
            invokeinterface java.util.Map.isEmpty:()Z
            ifeq 66
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            getfield org.apache.lucene.index.BufferedUpdates.numFieldUpdates:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            ifne 66
        63: .line 377
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            invokevirtual org.apache.lucene.index.BufferedUpdates.clear:()V
        64: .line 378
            aconst_null
            astore 10 /* segmentDeletes */
        start local 10 // org.apache.lucene.index.BufferedUpdates segmentDeletes
        65: .line 379
            goto 67
        end local 10 // org.apache.lucene.index.BufferedUpdates segmentDeletes
        66: .line 380
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            astore 10 /* segmentDeletes */
        start local 10 // org.apache.lucene.index.BufferedUpdates segmentDeletes
        67: .line 383
      StackMap locals: org.apache.lucene.index.BufferedUpdates
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifeq 74
        68: .line 384
            aload 9 /* segmentInfoPerCommit */
            invokevirtual org.apache.lucene.index.SegmentCommitInfo.sizeInBytes:()J
            l2d
            ldc 1024.0
            ddiv
            ldc 1024.0
            ddiv
            dstore 11 /* newSegmentSize */
        start local 11 // double newSegmentSize
        69: .line 385
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            new java.lang.StringBuilder
            dup
            ldc "flushed: segment="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            getfield org.apache.lucene.index.SegmentInfo.name:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        70: .line 386
            ldc " ramUsed="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.nf:Ljava/text/NumberFormat;
            dload 3 /* startMBUsed */
            invokevirtual java.text.NumberFormat.format:(D)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " MB"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        71: .line 387
            ldc " newFlushedSize="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.nf:Ljava/text/NumberFormat;
            dload 11 /* newSegmentSize */
            invokevirtual java.text.NumberFormat.format:(D)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " MB"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        72: .line 388
            ldc " docs/MB="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.nf:Ljava/text/NumberFormat;
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            invokevirtual org.apache.lucene.index.SegmentInfo.maxDoc:()I
            i2d
            dload 11 /* newSegmentSize */
            ddiv
            invokevirtual java.text.NumberFormat.format:(D)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        73: .line 385
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        end local 11 // double newSegmentSize
        74: .line 391
      StackMap locals:
      StackMap stack:
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 75
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            ifnonnull 75
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        75: .line 393
      StackMap locals:
      StackMap stack:
            new org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment
            dup
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            aload 9 /* segmentInfoPerCommit */
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.fieldInfos:Lorg/apache/lucene/index/FieldInfos;
        76: .line 394
            aload 10 /* segmentDeletes */
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.liveDocs:Lorg/apache/lucene/util/FixedBitSet;
            aload 2 /* flushState */
            getfield org.apache.lucene.index.SegmentWriteState.delCountOnFlush:I
            aload 7 /* sortMap */
        77: .line 393
            invokespecial org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment.<init>:(Lorg/apache/lucene/util/InfoStream;Lorg/apache/lucene/index/SegmentCommitInfo;Lorg/apache/lucene/index/FieldInfos;Lorg/apache/lucene/index/BufferedUpdates;Lorg/apache/lucene/util/FixedBitSet;ILorg/apache/lucene/index/Sorter$DocMap;)V
            astore 11 /* fs */
        start local 11 // org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment fs
        78: .line 395
            aload 0 /* this */
            aload 11 /* fs */
            aload 7 /* sortMap */
            aload 1 /* flushNotifications */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.sealFlushedSegment:(Lorg/apache/lucene/index/DocumentsWriterPerThread$FlushedSegment;Lorg/apache/lucene/index/Sorter$DocMap;Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;)V
        79: .line 396
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifeq 81
        80: .line 397
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            new java.lang.StringBuilder
            dup
            ldc "flush time "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            invokestatic java.lang.System.nanoTime:()J
            lload 5 /* t0 */
            lsub
            l2d
            ldc 1000000.0
            ddiv
            invokevirtual java.lang.StringBuilder.append:(D)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.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        81: .line 399
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment
      StackMap stack:
            aload 11 /* fs */
            astore 14
        82: .line 404
            aload 0 /* this */
            ldc "flush"
            aload 1 /* flushNotifications */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.maybeAbort:(Ljava/lang/String;Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;)V
        83: .line 405
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.hasFlushed:Lorg/apache/lucene/util/SetOnce;
            getstatic java.lang.Boolean.TRUE:Ljava/lang/Boolean;
            invokevirtual org.apache.lucene.util.SetOnce.set:(Ljava/lang/Object;)V
        84: .line 399
            aload 14
            areturn
        end local 11 // org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment fs
        end local 10 // org.apache.lucene.index.BufferedUpdates segmentDeletes
        end local 9 // org.apache.lucene.index.SegmentCommitInfo segmentInfoPerCommit
        end local 8 // org.apache.lucene.search.DocIdSetIterator softDeletedDocs
        end local 7 // org.apache.lucene.index.Sorter$DocMap sortMap
        85: .line 400
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentWriteState double long
      StackMap stack: java.lang.Throwable
            astore 8 /* t */
        start local 8 // java.lang.Throwable t
        86: .line 401
            aload 0 /* this */
            aload 8 /* t */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.onAbortingException:(Ljava/lang/Throwable;)V
        87: .line 402
            aload 8 /* t */
            athrow
        end local 8 // java.lang.Throwable t
        88: .line 403
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 13
        89: .line 404
            aload 0 /* this */
            ldc "flush"
            aload 1 /* flushNotifications */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.maybeAbort:(Ljava/lang/String;Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;)V
        90: .line 405
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.hasFlushed:Lorg/apache/lucene/util/SetOnce;
            getstatic java.lang.Boolean.TRUE:Ljava/lang/Boolean;
            invokevirtual org.apache.lucene.util.SetOnce.set:(Ljava/lang/Object;)V
        91: .line 406
            aload 13
            athrow
        end local 5 // long t0
        end local 3 // double startMBUsed
        end local 2 // org.apache.lucene.index.SegmentWriteState flushState
        end local 1 // org.apache.lucene.index.DocumentsWriter$FlushNotifications flushNotifications
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   92     0                  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            0   92     1    flushNotifications  Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;
            7   92     2            flushState  Lorg/apache/lucene/index/SegmentWriteState;
            8   92     3           startMBUsed  D
           12   16     5                     i  I
           23   92     5                    t0  J
           30   85     7               sortMap  Lorg/apache/lucene/index/Sorter$DocMap;
           27   28     8       softDeletedDocs  Lorg/apache/lucene/search/DocIdSetIterator;
           29   85     8       softDeletedDocs  Lorg/apache/lucene/search/DocIdSetIterator;
           38   85     9  segmentInfoPerCommit  Lorg/apache/lucene/index/SegmentCommitInfo;
           65   66    10        segmentDeletes  Lorg/apache/lucene/index/BufferedUpdates;
           67   85    10        segmentDeletes  Lorg/apache/lucene/index/BufferedUpdates;
           69   74    11        newSegmentSize  D
           78   85    11                    fs  Lorg/apache/lucene/index/DocumentsWriterPerThread$FlushedSegment;
           86   88     8                     t  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
          25    82      85  Class java.lang.Throwable
          25    82      88  any
          85    88      88  any
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                    Name  Flags
      flushNotifications  

  private void maybeAbort(java.lang.String, org.apache.lucene.index.DocumentsWriter$FlushNotifications);
    descriptor: (Ljava/lang/String;Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
        start local 1 // java.lang.String location
        start local 2 // org.apache.lucene.index.DocumentsWriter$FlushNotifications flushNotifications
         0: .line 410
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.abortingException:Ljava/lang/Throwable;
            ifnull 7
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.aborted:Z
            ifne 7
         1: .line 413
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.abort:()V
         2: .line 414
            goto 6
      StackMap locals:
      StackMap stack: java.lang.Throwable
         3: astore 3
         4: .line 416
            aload 2 /* flushNotifications */
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.abortingException:Ljava/lang/Throwable;
            aload 1 /* location */
            invokeinterface org.apache.lucene.index.DocumentsWriter$FlushNotifications.onTragicEvent:(Ljava/lang/Throwable;Ljava/lang/String;)V
         5: .line 417
            aload 3
            athrow
         6: .line 416
      StackMap locals:
      StackMap stack:
            aload 2 /* flushNotifications */
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.abortingException:Ljava/lang/Throwable;
            aload 1 /* location */
            invokeinterface org.apache.lucene.index.DocumentsWriter$FlushNotifications.onTragicEvent:(Ljava/lang/Throwable;Ljava/lang/String;)V
         7: .line 419
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.apache.lucene.index.DocumentsWriter$FlushNotifications flushNotifications
        end local 1 // java.lang.String location
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    8     0                this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            0    8     1            location  Ljava/lang/String;
            0    8     2  flushNotifications  Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;
      Exception table:
        from    to  target  type
           1     3       3  any
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                    Name  Flags
      location            
      flushNotifications  

  java.util.Set<java.lang.String> pendingFilesToDelete();
    descriptor: ()Ljava/util/Set;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 424
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.filesToDelete:Ljava/util/Set;
            areturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
    Signature: ()Ljava/util/Set<Ljava/lang/String;>;

  private org.apache.lucene.util.FixedBitSet sortLiveDocs(org.apache.lucene.util.Bits, org.apache.lucene.index.Sorter$DocMap);
    descriptor: (Lorg/apache/lucene/util/Bits;Lorg/apache/lucene/index/Sorter$DocMap;)Lorg/apache/lucene/util/FixedBitSet;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
        start local 1 // org.apache.lucene.util.Bits liveDocs
        start local 2 // org.apache.lucene.index.Sorter$DocMap sortMap
         0: .line 428
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 2
            aload 1 /* liveDocs */
            ifnull 1
            aload 2 /* sortMap */
            ifnonnull 2
      StackMap locals:
      StackMap stack:
         1: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 429
      StackMap locals:
      StackMap stack:
            new org.apache.lucene.util.FixedBitSet
            dup
            aload 1 /* liveDocs */
            invokeinterface org.apache.lucene.util.Bits.length:()I
            invokespecial org.apache.lucene.util.FixedBitSet.<init>:(I)V
            astore 3 /* sortedLiveDocs */
        start local 3 // org.apache.lucene.util.FixedBitSet sortedLiveDocs
         3: .line 430
            aload 3 /* sortedLiveDocs */
            iconst_0
            aload 1 /* liveDocs */
            invokeinterface org.apache.lucene.util.Bits.length:()I
            invokevirtual org.apache.lucene.util.FixedBitSet.set:(II)V
         4: .line 431
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         5: goto 9
         6: .line 432
      StackMap locals: org.apache.lucene.util.FixedBitSet int
      StackMap stack:
            aload 1 /* liveDocs */
            iload 4 /* i */
            invokeinterface org.apache.lucene.util.Bits.get:(I)Z
            ifne 8
         7: .line 433
            aload 3 /* sortedLiveDocs */
            aload 2 /* sortMap */
            iload 4 /* i */
            invokevirtual org.apache.lucene.index.Sorter$DocMap.oldToNew:(I)I
            invokevirtual org.apache.lucene.util.FixedBitSet.clear:(I)V
         8: .line 431
      StackMap locals:
      StackMap stack:
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
         9: iload 4 /* i */
            aload 1 /* liveDocs */
            invokeinterface org.apache.lucene.util.Bits.length:()I
            if_icmplt 6
        end local 4 // int i
        10: .line 436
            aload 3 /* sortedLiveDocs */
            areturn
        end local 3 // org.apache.lucene.util.FixedBitSet sortedLiveDocs
        end local 2 // org.apache.lucene.index.Sorter$DocMap sortMap
        end local 1 // org.apache.lucene.util.Bits liveDocs
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   11     0            this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            0   11     1        liveDocs  Lorg/apache/lucene/util/Bits;
            0   11     2         sortMap  Lorg/apache/lucene/index/Sorter$DocMap;
            3   11     3  sortedLiveDocs  Lorg/apache/lucene/util/FixedBitSet;
            5   10     4               i  I
    MethodParameters:
          Name  Flags
      liveDocs  
      sortMap   

  void sealFlushedSegment(org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment, org.apache.lucene.index.Sorter$DocMap, org.apache.lucene.index.DocumentsWriter$FlushNotifications);
    descriptor: (Lorg/apache/lucene/index/DocumentsWriterPerThread$FlushedSegment;Lorg/apache/lucene/index/Sorter$DocMap;Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;)V
    flags: (0x0000) 
    Code:
      stack=7, locals=12, args_size=4
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
        start local 1 // org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment flushedSegment
        start local 2 // org.apache.lucene.index.Sorter$DocMap sortMap
        start local 3 // org.apache.lucene.index.DocumentsWriter$FlushNotifications flushNotifications
         0: .line 444
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 1
            aload 1 /* flushedSegment */
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 445
      StackMap locals:
      StackMap stack:
            aload 1 /* flushedSegment */
            getfield org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment.segmentInfo:Lorg/apache/lucene/index/SegmentCommitInfo;
            astore 4 /* newSegment */
        start local 4 // org.apache.lucene.index.SegmentCommitInfo newSegment
         2: .line 447
            aload 4 /* newSegment */
            getfield org.apache.lucene.index.SegmentCommitInfo.info:Lorg/apache/lucene/index/SegmentInfo;
            ldc "flush"
            invokestatic org.apache.lucene.index.IndexWriter.setDiagnostics:(Lorg/apache/lucene/index/SegmentInfo;Ljava/lang/String;)V
         3: .line 449
            new org.apache.lucene.store.IOContext
            dup
            new org.apache.lucene.store.FlushInfo
            dup
            aload 4 /* newSegment */
            getfield org.apache.lucene.index.SegmentCommitInfo.info:Lorg/apache/lucene/index/SegmentInfo;
            invokevirtual org.apache.lucene.index.SegmentInfo.maxDoc:()I
            aload 4 /* newSegment */
            invokevirtual org.apache.lucene.index.SegmentCommitInfo.sizeInBytes:()J
            invokespecial org.apache.lucene.store.FlushInfo.<init>:(IJ)V
            invokespecial org.apache.lucene.store.IOContext.<init>:(Lorg/apache/lucene/store/FlushInfo;)V
            astore 5 /* context */
        start local 5 // org.apache.lucene.store.IOContext context
         4: .line 451
            iconst_0
            istore 6 /* success */
        start local 6 // boolean success
         5: .line 454
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.indexWriterConfig:Lorg/apache/lucene/index/LiveIndexWriterConfig;
            invokevirtual org.apache.lucene.index.LiveIndexWriterConfig.getUseCompoundFile:()Z
            ifeq 10
         6: .line 455
            aload 4 /* newSegment */
            getfield org.apache.lucene.index.SegmentCommitInfo.info:Lorg/apache/lucene/index/SegmentInfo;
            invokevirtual org.apache.lucene.index.SegmentInfo.files:()Ljava/util/Set;
            astore 7 /* originalFiles */
        start local 7 // java.util.Set originalFiles
         7: .line 457
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            new org.apache.lucene.store.TrackingDirectoryWrapper
            dup
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.directory:Lorg/apache/lucene/store/TrackingDirectoryWrapper;
            invokespecial org.apache.lucene.store.TrackingDirectoryWrapper.<init>:(Lorg/apache/lucene/store/Directory;)V
            aload 4 /* newSegment */
            getfield org.apache.lucene.index.SegmentCommitInfo.info:Lorg/apache/lucene/index/SegmentInfo;
            aload 5 /* context */
            aload 3 /* flushNotifications */
            dup
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            pop
            invokedynamic accept(Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;)Lorg/apache/lucene/util/IOUtils$IOConsumer;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)V
                  org/apache/lucene/index/DocumentsWriter$FlushNotifications.deleteUnusedFiles(Ljava/util/Collection;)V (9 itf)
                  (Ljava/util/Collection;)V
            invokestatic org.apache.lucene.index.IndexWriter.createCompoundFile:(Lorg/apache/lucene/util/InfoStream;Lorg/apache/lucene/store/TrackingDirectoryWrapper;Lorg/apache/lucene/index/SegmentInfo;Lorg/apache/lucene/store/IOContext;Lorg/apache/lucene/util/IOUtils$IOConsumer;)V
         8: .line 458
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.filesToDelete:Ljava/util/Set;
            aload 7 /* originalFiles */
            invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
            pop
         9: .line 459
            aload 4 /* newSegment */
            getfield org.apache.lucene.index.SegmentCommitInfo.info:Lorg/apache/lucene/index/SegmentInfo;
            iconst_1
            invokevirtual org.apache.lucene.index.SegmentInfo.setUseCompoundFile:(Z)V
        end local 7 // java.util.Set originalFiles
        10: .line 466
      StackMap locals: org.apache.lucene.index.SegmentCommitInfo org.apache.lucene.store.IOContext int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.codec:Lorg/apache/lucene/codecs/Codec;
            invokevirtual org.apache.lucene.codecs.Codec.segmentInfoFormat:()Lorg/apache/lucene/codecs/SegmentInfoFormat;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.directory:Lorg/apache/lucene/store/TrackingDirectoryWrapper;
            aload 4 /* newSegment */
            getfield org.apache.lucene.index.SegmentCommitInfo.info:Lorg/apache/lucene/index/SegmentInfo;
            aload 5 /* context */
            invokevirtual org.apache.lucene.codecs.SegmentInfoFormat.write:(Lorg/apache/lucene/store/Directory;Lorg/apache/lucene/index/SegmentInfo;Lorg/apache/lucene/store/IOContext;)V
        11: .line 474
            aload 1 /* flushedSegment */
            getfield org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment.liveDocs:Lorg/apache/lucene/util/FixedBitSet;
            ifnull 25
        12: .line 475
            aload 1 /* flushedSegment */
            getfield org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment.delCount:I
            istore 7 /* delCount */
        start local 7 // int delCount
        13: .line 476
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 14
            iload 7 /* delCount */
            ifgt 14
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        14: .line 477
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifeq 16
        15: .line 478
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            new java.lang.StringBuilder
            dup
            ldc "flush: write "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 7 /* delCount */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " deletes gen="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* flushedSegment */
            getfield org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment.segmentInfo:Lorg/apache/lucene/index/SegmentCommitInfo;
            invokevirtual org.apache.lucene.index.SegmentCommitInfo.getDelGen:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        16: .line 490
      StackMap locals:
      StackMap stack:
            aload 1 /* flushedSegment */
            getfield org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment.segmentInfo:Lorg/apache/lucene/index/SegmentCommitInfo;
            astore 8 /* info */
        start local 8 // org.apache.lucene.index.SegmentCommitInfo info
        17: .line 491
            aload 8 /* info */
            getfield org.apache.lucene.index.SegmentCommitInfo.info:Lorg/apache/lucene/index/SegmentInfo;
            invokevirtual org.apache.lucene.index.SegmentInfo.getCodec:()Lorg/apache/lucene/codecs/Codec;
            astore 9 /* codec */
        start local 9 // org.apache.lucene.codecs.Codec codec
        18: .line 493
            aload 2 /* sortMap */
            ifnonnull 21
        19: .line 494
            aload 1 /* flushedSegment */
            getfield org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment.liveDocs:Lorg/apache/lucene/util/FixedBitSet;
            astore 10 /* bits */
        start local 10 // org.apache.lucene.util.FixedBitSet bits
        20: .line 495
            goto 22
        end local 10 // org.apache.lucene.util.FixedBitSet bits
        21: .line 496
      StackMap locals: org.apache.lucene.index.SegmentCommitInfo org.apache.lucene.codecs.Codec
      StackMap stack:
            aload 0 /* this */
            aload 1 /* flushedSegment */
            getfield org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment.liveDocs:Lorg/apache/lucene/util/FixedBitSet;
            aload 2 /* sortMap */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.sortLiveDocs:(Lorg/apache/lucene/util/Bits;Lorg/apache/lucene/index/Sorter$DocMap;)Lorg/apache/lucene/util/FixedBitSet;
            astore 10 /* bits */
        start local 10 // org.apache.lucene.util.FixedBitSet bits
        22: .line 498
      StackMap locals: org.apache.lucene.util.FixedBitSet
      StackMap stack:
            aload 9 /* codec */
            invokevirtual org.apache.lucene.codecs.Codec.liveDocsFormat:()Lorg/apache/lucene/codecs/LiveDocsFormat;
            aload 10 /* bits */
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.directory:Lorg/apache/lucene/store/TrackingDirectoryWrapper;
            aload 8 /* info */
            iload 7 /* delCount */
            aload 5 /* context */
            invokevirtual org.apache.lucene.codecs.LiveDocsFormat.writeLiveDocs:(Lorg/apache/lucene/util/Bits;Lorg/apache/lucene/store/Directory;Lorg/apache/lucene/index/SegmentCommitInfo;ILorg/apache/lucene/store/IOContext;)V
        23: .line 499
            aload 4 /* newSegment */
            iload 7 /* delCount */
            invokevirtual org.apache.lucene.index.SegmentCommitInfo.setDelCount:(I)V
        24: .line 500
            aload 4 /* newSegment */
            invokevirtual org.apache.lucene.index.SegmentCommitInfo.advanceDelGen:()V
        end local 10 // org.apache.lucene.util.FixedBitSet bits
        end local 9 // org.apache.lucene.codecs.Codec codec
        end local 8 // org.apache.lucene.index.SegmentCommitInfo info
        end local 7 // int delCount
        25: .line 503
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment org.apache.lucene.index.Sorter$DocMap org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentCommitInfo org.apache.lucene.store.IOContext int
      StackMap stack:
            iconst_1
            istore 6 /* success */
        26: .line 504
            goto 34
      StackMap locals:
      StackMap stack: java.lang.Throwable
        27: astore 11
        28: .line 505
            iload 6 /* success */
            ifne 33
        29: .line 506
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifeq 33
        30: .line 507
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
        31: .line 508
            new java.lang.StringBuilder
            dup
            ldc "hit exception creating compound file for newly flushed segment "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* newSegment */
            getfield org.apache.lucene.index.SegmentCommitInfo.info:Lorg/apache/lucene/index/SegmentInfo;
            getfield org.apache.lucene.index.SegmentInfo.name:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        32: .line 507
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        33: .line 511
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment org.apache.lucene.index.Sorter$DocMap org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentCommitInfo org.apache.lucene.store.IOContext int top top top top java.lang.Throwable
      StackMap stack:
            aload 11
            athrow
        34: .line 505
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment org.apache.lucene.index.Sorter$DocMap org.apache.lucene.index.DocumentsWriter$FlushNotifications org.apache.lucene.index.SegmentCommitInfo org.apache.lucene.store.IOContext int
      StackMap stack:
            iload 6 /* success */
            ifne 39
        35: .line 506
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
            invokevirtual org.apache.lucene.util.InfoStream.isEnabled:(Ljava/lang/String;)Z
            ifeq 39
        36: .line 507
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.infoStream:Lorg/apache/lucene/util/InfoStream;
            ldc "DWPT"
        37: .line 508
            new java.lang.StringBuilder
            dup
            ldc "hit exception creating compound file for newly flushed segment "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* newSegment */
            getfield org.apache.lucene.index.SegmentCommitInfo.info:Lorg/apache/lucene/index/SegmentInfo;
            getfield org.apache.lucene.index.SegmentInfo.name:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        38: .line 507
            invokevirtual org.apache.lucene.util.InfoStream.message:(Ljava/lang/String;Ljava/lang/String;)V
        39: .line 512
      StackMap locals:
      StackMap stack:
            return
        end local 6 // boolean success
        end local 5 // org.apache.lucene.store.IOContext context
        end local 4 // org.apache.lucene.index.SegmentCommitInfo newSegment
        end local 3 // org.apache.lucene.index.DocumentsWriter$FlushNotifications flushNotifications
        end local 2 // org.apache.lucene.index.Sorter$DocMap sortMap
        end local 1 // org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment flushedSegment
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   40     0                this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            0   40     1      flushedSegment  Lorg/apache/lucene/index/DocumentsWriterPerThread$FlushedSegment;
            0   40     2             sortMap  Lorg/apache/lucene/index/Sorter$DocMap;
            0   40     3  flushNotifications  Lorg/apache/lucene/index/DocumentsWriter$FlushNotifications;
            2   40     4          newSegment  Lorg/apache/lucene/index/SegmentCommitInfo;
            4   40     5             context  Lorg/apache/lucene/store/IOContext;
            5   40     6             success  Z
            7   10     7       originalFiles  Ljava/util/Set<Ljava/lang/String;>;
           13   25     7            delCount  I
           17   25     8                info  Lorg/apache/lucene/index/SegmentCommitInfo;
           18   25     9               codec  Lorg/apache/lucene/codecs/Codec;
           20   21    10                bits  Lorg/apache/lucene/util/FixedBitSet;
           22   25    10                bits  Lorg/apache/lucene/util/FixedBitSet;
      Exception table:
        from    to  target  type
           5    27      27  any
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                    Name  Flags
      flushedSegment      
      sortMap             
      flushNotifications  

  org.apache.lucene.index.SegmentInfo getSegmentInfo();
    descriptor: ()Lorg/apache/lucene/index/SegmentInfo;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 516
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            areturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  public long ramBytesUsed();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 521
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.isHeldByCurrentThread:()Z
            ifne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 522
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteDocIDs:[I
            arraylength
            iconst_4
            imul
            i2l
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            invokevirtual org.apache.lucene.index.BufferedUpdates.ramBytesUsed:()J
            ladd
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.consumer:Lorg/apache/lucene/index/DocConsumer;
            invokevirtual org.apache.lucene.index.DocConsumer.ramBytesUsed:()J
            ladd
            lreturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  public java.util.Collection<org.apache.lucene.util.Accountable> getChildResources();
    descriptor: ()Ljava/util/Collection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 527
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.isHeldByCurrentThread:()Z
            ifne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 528
      StackMap locals:
      StackMap stack:
            iconst_2
            anewarray org.apache.lucene.util.Accountable
            dup
            iconst_0
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            aastore
            dup
            iconst_1
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.consumer:Lorg/apache/lucene/index/DocConsumer;
            aastore
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            invokestatic java.util.Collections.unmodifiableList:(Ljava/util/List;)Ljava/util/List;
            areturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
    Signature: ()Ljava/util/Collection<Lorg/apache/lucene/util/Accountable;>;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 533
            new java.lang.StringBuilder
            dup
            ldc "DocumentsWriterPerThread [pendingDeletes="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.pendingUpdates:Lorg/apache/lucene/index/BufferedUpdates;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         1: .line 534
            ldc ", segment="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            ifnull 2
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.segmentInfo:Lorg/apache/lucene/index/SegmentInfo;
            getfield org.apache.lucene.index.SegmentInfo.name:Ljava/lang/String;
            goto 3
      StackMap locals:
      StackMap stack: java.lang.StringBuilder
         2: ldc "null"
      StackMap locals: org.apache.lucene.index.DocumentsWriterPerThread
      StackMap stack: java.lang.StringBuilder java.lang.String
         3: invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ", aborted="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.aborted:Z
            invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
            ldc ", numDocsInRAM="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         4: .line 535
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDocsInRAM:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ", deleteQueue="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.deleteQueue:Lorg/apache/lucene/index/DocumentsWriterDeleteQueue;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc ", "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.numDeletedDocIds:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " deleted docIds"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         5: .line 533
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  boolean isFlushPending();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 543
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.flushPending:Lorg/apache/lucene/util/SetOnce;
            invokevirtual org.apache.lucene.util.SetOnce.get:()Ljava/lang/Object;
            getstatic java.lang.Boolean.TRUE:Ljava/lang/Boolean;
            if_acmpne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  void setFlushPending();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 550
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.flushPending:Lorg/apache/lucene/util/SetOnce;
            getstatic java.lang.Boolean.TRUE:Ljava/lang/Boolean;
            invokevirtual org.apache.lucene.util.SetOnce.set:(Ljava/lang/Object;)V
         1: .line 551
            return
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  long getLastCommittedBytesUsed();
    descriptor: ()J
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 559
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.lastCommittedBytesUsed:J
            lreturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  long commitLastBytesUsed();
    descriptor: ()J
    flags: (0x0000) 
    Code:
      stack=5, locals=3, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 568
            getstatic org.apache.lucene.index.DocumentsWriterPerThread.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.isHeldByCurrentThread:()Z
            ifne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 569
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.lucene.index.DocumentsWriterPerThread.ramBytesUsed:()J
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.lastCommittedBytesUsed:J
            lsub
            lstore 1 /* delta */
        start local 1 // long delta
         2: .line 570
            aload 0 /* this */
            dup
            getfield org.apache.lucene.index.DocumentsWriterPerThread.lastCommittedBytesUsed:J
            lload 1 /* delta */
            ladd
            putfield org.apache.lucene.index.DocumentsWriterPerThread.lastCommittedBytesUsed:J
         3: .line 571
            lload 1 /* delta */
            lreturn
        end local 1 // long delta
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
            2    4     1  delta  J

  void lock();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 579
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         1: .line 580
            return
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  boolean tryLock();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 589
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.tryLock:()Z
            ireturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  boolean isHeldByCurrentThread();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 597
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.isHeldByCurrentThread:()Z
            ireturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  void unlock();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 605
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         1: .line 606
            return
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;

  boolean hasFlushed();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
         0: .line 612
            aload 0 /* this */
            getfield org.apache.lucene.index.DocumentsWriterPerThread.hasFlushed:Lorg/apache/lucene/util/SetOnce;
            invokevirtual org.apache.lucene.util.SetOnce.get:()Ljava/lang/Object;
            getstatic java.lang.Boolean.TRUE:Ljava/lang/Boolean;
            if_acmpne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.apache.lucene.index.DocumentsWriterPerThread this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/lucene/index/DocumentsWriterPerThread;
}
SourceFile: "DocumentsWriterPerThread.java"
NestMembers:
  org.apache.lucene.index.DocumentsWriterPerThread$1  org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment  org.apache.lucene.index.DocumentsWriterPerThread$IndexingChain
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  abstract FlushNotifications = org.apache.lucene.index.DocumentsWriter$FlushNotifications of org.apache.lucene.index.DocumentsWriter
  DeleteSlice = org.apache.lucene.index.DocumentsWriterDeleteQueue$DeleteSlice of org.apache.lucene.index.DocumentsWriterDeleteQueue
  Node = org.apache.lucene.index.DocumentsWriterDeleteQueue$Node of org.apache.lucene.index.DocumentsWriterDeleteQueue
  org.apache.lucene.index.DocumentsWriterPerThread$1
  final FlushedSegment = org.apache.lucene.index.DocumentsWriterPerThread$FlushedSegment of org.apache.lucene.index.DocumentsWriterPerThread
  abstract IndexingChain = org.apache.lucene.index.DocumentsWriterPerThread$IndexingChain of org.apache.lucene.index.DocumentsWriterPerThread
  final Builder = org.apache.lucene.index.FieldInfos$Builder of org.apache.lucene.index.FieldInfos
  abstract DocMap = org.apache.lucene.index.Sorter$DocMap of org.apache.lucene.index.Sorter
  public abstract IOConsumer = org.apache.lucene.util.IOUtils$IOConsumer of org.apache.lucene.util.IOUtils