final class jdk.jfr.internal.RepositoryChunk
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: jdk.jfr.internal.RepositoryChunk
  super_class: java.lang.Object
{
  private static final int MAX_CHUNK_NAMES;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 100

  private static final java.lang.String FILE_EXTENSION;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: ".jfr"

  static final java.util.Comparator<jdk.jfr.internal.RepositoryChunk> END_TIME_COMPARATOR;
    descriptor: Ljava/util/Comparator;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Comparator<Ljdk/jfr/internal/RepositoryChunk;>;

  private final jdk.jfr.internal.SecuritySupport$SafePath chunkFile;
    descriptor: Ljdk/jfr/internal/SecuritySupport$SafePath;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.time.Instant startTime;
    descriptor: Ljava/time/Instant;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.io.RandomAccessFile unFinishedRAF;
    descriptor: Ljava/io/RandomAccessFile;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private java.time.Instant endTime;
    descriptor: Ljava/time/Instant;
    flags: (0x0002) ACC_PRIVATE

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

  private long size;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 43
            new jdk.jfr.internal.RepositoryChunk$1
            dup
            invokespecial jdk.jfr.internal.RepositoryChunk$1.<init>:()V
            putstatic jdk.jfr.internal.RepositoryChunk.END_TIME_COMPARATOR:Ljava/util/Comparator;
         1: .line 48
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(jdk.jfr.internal.SecuritySupport$SafePath, java.time.Instant);
    descriptor: (Ljdk/jfr/internal/SecuritySupport$SafePath;Ljava/time/Instant;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // jdk.jfr.internal.RepositoryChunk this
        start local 1 // jdk.jfr.internal.SecuritySupport$SafePath path
        start local 2 // java.time.Instant startTime
         0: .line 58
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 54
            aload 0 /* this */
            aconst_null
            putfield jdk.jfr.internal.RepositoryChunk.endTime:Ljava/time/Instant;
         2: .line 55
            aload 0 /* this */
            iconst_0
            putfield jdk.jfr.internal.RepositoryChunk.refCount:I
         3: .line 59
            aload 0 /* this */
            aload 2 /* startTime */
            putfield jdk.jfr.internal.RepositoryChunk.startTime:Ljava/time/Instant;
         4: .line 60
            aload 0 /* this */
            aload 1 /* path */
            putfield jdk.jfr.internal.RepositoryChunk.chunkFile:Ljdk/jfr/internal/SecuritySupport$SafePath;
         5: .line 61
            aload 0 /* this */
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.chunkFile:Ljdk/jfr/internal/SecuritySupport$SafePath;
            invokestatic jdk.jfr.internal.SecuritySupport.createRandomAccessFile:(Ljdk/jfr/internal/SecuritySupport$SafePath;)Ljava/io/RandomAccessFile;
            putfield jdk.jfr.internal.RepositoryChunk.unFinishedRAF:Ljava/io/RandomAccessFile;
         6: .line 62
            return
        end local 2 // java.time.Instant startTime
        end local 1 // jdk.jfr.internal.SecuritySupport$SafePath path
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0       this  Ljdk/jfr/internal/RepositoryChunk;
            0    7     1       path  Ljdk/jfr/internal/SecuritySupport$SafePath;
            0    7     2  startTime  Ljava/time/Instant;
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
           Name  Flags
      path       
      startTime  

  void finish(java.time.Instant);
    descriptor: (Ljava/time/Instant;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // jdk.jfr.internal.RepositoryChunk this
        start local 1 // java.time.Instant endTime
         0: .line 66
            aload 0 /* this */
            aload 1 /* endTime */
            invokevirtual jdk.jfr.internal.RepositoryChunk.finishWithException:(Ljava/time/Instant;)V
         1: .line 67
            goto 4
      StackMap locals:
      StackMap stack: java.io.IOException
         2: astore 2 /* e */
        start local 2 // java.io.IOException e
         3: .line 68
            getstatic jdk.jfr.internal.LogTag.JFR:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.ERROR:Ljdk/jfr/internal/LogLevel;
            new java.lang.StringBuilder
            dup
            ldc "Could not finish chunk. "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* e */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* e */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic jdk.jfr.internal.Logger.log:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;Ljava/lang/String;)V
        end local 2 // java.io.IOException e
         4: .line 70
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.time.Instant endTime
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Ljdk/jfr/internal/RepositoryChunk;
            0    5     1  endTime  Ljava/time/Instant;
            3    4     2        e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           0     1       2  Class java.io.IOException
    MethodParameters:
         Name  Flags
      endTime  

  private void finishWithException(java.time.Instant);
    descriptor: (Ljava/time/Instant;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // jdk.jfr.internal.RepositoryChunk this
        start local 1 // java.time.Instant endTime
         0: .line 73
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.unFinishedRAF:Ljava/io/RandomAccessFile;
            invokevirtual java.io.RandomAccessFile.close:()V
         1: .line 74
            aload 0 /* this */
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.chunkFile:Ljdk/jfr/internal/SecuritySupport$SafePath;
            invokestatic jdk.jfr.internal.SecuritySupport.getFileSize:(Ljdk/jfr/internal/SecuritySupport$SafePath;)J
            putfield jdk.jfr.internal.RepositoryChunk.size:J
         2: .line 75
            aload 0 /* this */
            aload 1 /* endTime */
            putfield jdk.jfr.internal.RepositoryChunk.endTime:Ljava/time/Instant;
         3: .line 76
            getstatic jdk.jfr.internal.LogTag.JFR_SYSTEM:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.DEBUG:Ljdk/jfr/internal/LogLevel;
            invokestatic jdk.jfr.internal.Logger.shouldLog:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;)Z
            ifeq 5
         4: .line 77
            getstatic jdk.jfr.internal.LogTag.JFR_SYSTEM:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.DEBUG:Ljdk/jfr/internal/LogLevel;
            new java.lang.StringBuilder
            dup
            ldc "Chunk finished: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.chunkFile:Ljdk/jfr/internal/SecuritySupport$SafePath;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic jdk.jfr.internal.Logger.log:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;Ljava/lang/String;)V
         5: .line 79
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.time.Instant endTime
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0     this  Ljdk/jfr/internal/RepositoryChunk;
            0    6     1  endTime  Ljava/time/Instant;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      endTime  

  public java.time.Instant getStartTime();
    descriptor: ()Ljava/time/Instant;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // jdk.jfr.internal.RepositoryChunk this
         0: .line 82
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.startTime:Ljava/time/Instant;
            areturn
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljdk/jfr/internal/RepositoryChunk;

  public java.time.Instant getEndTime();
    descriptor: ()Ljava/time/Instant;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // jdk.jfr.internal.RepositoryChunk this
         0: .line 86
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.endTime:Ljava/time/Instant;
            areturn
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljdk/jfr/internal/RepositoryChunk;

  private void delete(jdk.jfr.internal.SecuritySupport$SafePath);
    descriptor: (Ljdk/jfr/internal/SecuritySupport$SafePath;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // jdk.jfr.internal.RepositoryChunk this
        start local 1 // jdk.jfr.internal.SecuritySupport$SafePath f
         0: .line 91
            aload 1 /* f */
            invokestatic jdk.jfr.internal.SecuritySupport.delete:(Ljdk/jfr/internal/SecuritySupport$SafePath;)V
         1: .line 92
            getstatic jdk.jfr.internal.LogTag.JFR:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.DEBUG:Ljdk/jfr/internal/LogLevel;
            invokestatic jdk.jfr.internal.Logger.shouldLog:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;)Z
            ifeq 9
         2: .line 93
            getstatic jdk.jfr.internal.LogTag.JFR:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.DEBUG:Ljdk/jfr/internal/LogLevel;
            new java.lang.StringBuilder
            dup
            ldc "Repository chunk "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* f */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " deleted"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic jdk.jfr.internal.Logger.log:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;Ljava/lang/String;)V
         3: .line 95
            goto 9
      StackMap locals:
      StackMap stack: java.io.IOException
         4: astore 2 /* e */
        start local 2 // java.io.IOException e
         5: .line 98
            getstatic jdk.jfr.internal.LogTag.JFR:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.DEBUG:Ljdk/jfr/internal/LogLevel;
            invokestatic jdk.jfr.internal.Logger.shouldLog:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;)Z
            ifeq 7
         6: .line 99
            getstatic jdk.jfr.internal.LogTag.JFR:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.DEBUG:Ljdk/jfr/internal/LogLevel;
            new java.lang.StringBuilder
            dup
            ldc "Repository chunk "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* f */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " could not be deleted: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* e */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic jdk.jfr.internal.Logger.log:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;Ljava/lang/String;)V
         7: .line 101
      StackMap locals: java.io.IOException
      StackMap stack:
            aload 1 /* f */
            ifnull 9
         8: .line 102
            aload 1 /* f */
            invokestatic jdk.jfr.internal.FilePurger.add:(Ljdk/jfr/internal/SecuritySupport$SafePath;)V
        end local 2 // java.io.IOException e
         9: .line 105
      StackMap locals:
      StackMap stack:
            return
        end local 1 // jdk.jfr.internal.SecuritySupport$SafePath f
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Ljdk/jfr/internal/RepositoryChunk;
            0   10     1     f  Ljdk/jfr/internal/SecuritySupport$SafePath;
            5    9     2     e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           0     3       4  Class java.io.IOException
    MethodParameters:
      Name  Flags
      f     

  private void destroy();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // jdk.jfr.internal.RepositoryChunk this
         0: .line 108
            aload 0 /* this */
            invokevirtual jdk.jfr.internal.RepositoryChunk.isFinished:()Z
            ifne 2
         1: .line 109
            aload 0 /* this */
            getstatic java.time.Instant.MIN:Ljava/time/Instant;
            invokevirtual jdk.jfr.internal.RepositoryChunk.finish:(Ljava/time/Instant;)V
         2: .line 111
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.chunkFile:Ljdk/jfr/internal/SecuritySupport$SafePath;
            invokevirtual jdk.jfr.internal.RepositoryChunk.delete:(Ljdk/jfr/internal/SecuritySupport$SafePath;)V
         3: .line 113
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.unFinishedRAF:Ljava/io/RandomAccessFile;
            invokevirtual java.io.RandomAccessFile.close:()V
         4: .line 114
            goto 8
      StackMap locals:
      StackMap stack: java.io.IOException
         5: astore 1 /* e */
        start local 1 // java.io.IOException e
         6: .line 115
            getstatic jdk.jfr.internal.LogTag.JFR:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.ERROR:Ljdk/jfr/internal/LogLevel;
            invokestatic jdk.jfr.internal.Logger.shouldLog:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;)Z
            ifeq 8
         7: .line 116
            getstatic jdk.jfr.internal.LogTag.JFR:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.ERROR:Ljdk/jfr/internal/LogLevel;
            new java.lang.StringBuilder
            dup
            ldc "Could not close random access file: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.chunkFile:Ljdk/jfr/internal/SecuritySupport$SafePath;
            invokevirtual jdk.jfr.internal.SecuritySupport$SafePath.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ". File will not be deleted due to: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* e */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic jdk.jfr.internal.Logger.log:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;Ljava/lang/String;)V
        end local 1 // java.io.IOException e
         8: .line 119
      StackMap locals:
      StackMap stack:
            return
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Ljdk/jfr/internal/RepositoryChunk;
            6    8     1     e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           3     4       5  Class java.io.IOException

  public synchronized void use();
    descriptor: ()V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // jdk.jfr.internal.RepositoryChunk this
         0: .line 122
            aload 0 /* this */
            dup
            getfield jdk.jfr.internal.RepositoryChunk.refCount:I
            iconst_1
            iadd
            putfield jdk.jfr.internal.RepositoryChunk.refCount:I
         1: .line 123
            getstatic jdk.jfr.internal.LogTag.JFR_SYSTEM:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.DEBUG:Ljdk/jfr/internal/LogLevel;
            invokestatic jdk.jfr.internal.Logger.shouldLog:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;)Z
            ifeq 3
         2: .line 124
            getstatic jdk.jfr.internal.LogTag.JFR_SYSTEM:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.DEBUG:Ljdk/jfr/internal/LogLevel;
            new java.lang.StringBuilder
            dup
            ldc "Use chunk "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            invokevirtual jdk.jfr.internal.RepositoryChunk.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " ref count now "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.refCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic jdk.jfr.internal.Logger.log:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;Ljava/lang/String;)V
         3: .line 126
      StackMap locals:
      StackMap stack:
            return
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljdk/jfr/internal/RepositoryChunk;

  public synchronized void release();
    descriptor: ()V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // jdk.jfr.internal.RepositoryChunk this
         0: .line 129
            aload 0 /* this */
            dup
            getfield jdk.jfr.internal.RepositoryChunk.refCount:I
            iconst_1
            isub
            putfield jdk.jfr.internal.RepositoryChunk.refCount:I
         1: .line 130
            getstatic jdk.jfr.internal.LogTag.JFR_SYSTEM:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.DEBUG:Ljdk/jfr/internal/LogLevel;
            invokestatic jdk.jfr.internal.Logger.shouldLog:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;)Z
            ifeq 3
         2: .line 131
            getstatic jdk.jfr.internal.LogTag.JFR_SYSTEM:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.DEBUG:Ljdk/jfr/internal/LogLevel;
            new java.lang.StringBuilder
            dup
            ldc "Release chunk "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            invokevirtual jdk.jfr.internal.RepositoryChunk.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " ref count now "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.refCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic jdk.jfr.internal.Logger.log:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;Ljava/lang/String;)V
         3: .line 133
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.refCount:I
            ifne 5
         4: .line 134
            aload 0 /* this */
            invokevirtual jdk.jfr.internal.RepositoryChunk.destroy:()V
         5: .line 136
      StackMap locals:
      StackMap stack:
            return
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Ljdk/jfr/internal/RepositoryChunk;

  protected void finalize();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=3, args_size=1
        start local 0 // jdk.jfr.internal.RepositoryChunk this
         0: .line 141
            iconst_0
            istore 1 /* destroy */
        start local 1 // boolean destroy
         1: .line 142
            aload 0 /* this */
            dup
            astore 2
            monitorenter
         2: .line 143
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.refCount:I
            ifle 4
         3: .line 144
            iconst_1
            istore 1 /* destroy */
         4: .line 142
      StackMap locals: int jdk.jfr.internal.RepositoryChunk
      StackMap stack:
            aload 2
            monitorexit
         5: goto 8
      StackMap locals:
      StackMap stack: java.lang.Throwable
         6: aload 2
            monitorexit
         7: athrow
         8: .line 147
      StackMap locals:
      StackMap stack:
            iload 1 /* destroy */
            ifeq 10
         9: .line 148
            aload 0 /* this */
            invokevirtual jdk.jfr.internal.RepositoryChunk.destroy:()V
        10: .line 150
      StackMap locals:
      StackMap stack:
            return
        end local 1 // boolean destroy
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   11     0     this  Ljdk/jfr/internal/RepositoryChunk;
            1   11     1  destroy  Z
      Exception table:
        from    to  target  type
           2     5       6  any
           6     7       6  any

  public long getSize();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // jdk.jfr.internal.RepositoryChunk this
         0: .line 153
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.size:J
            lreturn
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljdk/jfr/internal/RepositoryChunk;

  public boolean isFinished();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // jdk.jfr.internal.RepositoryChunk this
         0: .line 157
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.endTime:Ljava/time/Instant;
            ifnull 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljdk/jfr/internal/RepositoryChunk;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // jdk.jfr.internal.RepositoryChunk this
         0: .line 162
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.chunkFile:Ljdk/jfr/internal/SecuritySupport$SafePath;
            invokevirtual jdk.jfr.internal.SecuritySupport$SafePath.toString:()Ljava/lang/String;
            areturn
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljdk/jfr/internal/RepositoryChunk;

  java.nio.channels.ReadableByteChannel newChannel();
    descriptor: ()Ljava/nio/channels/ReadableByteChannel;
    flags: (0x0000) 
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // jdk.jfr.internal.RepositoryChunk this
         0: .line 166
            aload 0 /* this */
            invokevirtual jdk.jfr.internal.RepositoryChunk.isFinished:()Z
            ifne 2
         1: .line 167
            new java.io.IOException
            dup
            ldc "Chunk not finished"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 169
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.chunkFile:Ljdk/jfr/internal/SecuritySupport$SafePath;
            invokestatic jdk.jfr.internal.SecuritySupport.newFileChannelToRead:(Ljdk/jfr/internal/SecuritySupport$SafePath;)Ljava/nio/channels/ReadableByteChannel;
            areturn
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljdk/jfr/internal/RepositoryChunk;
    Exceptions:
      throws java.io.IOException

  public boolean inInterval(java.time.Instant, java.time.Instant);
    descriptor: (Ljava/time/Instant;Ljava/time/Instant;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // jdk.jfr.internal.RepositoryChunk this
        start local 1 // java.time.Instant startTime
        start local 2 // java.time.Instant endTime
         0: .line 173
            aload 1 /* startTime */
            ifnull 2
            aload 0 /* this */
            invokevirtual jdk.jfr.internal.RepositoryChunk.getEndTime:()Ljava/time/Instant;
            aload 1 /* startTime */
            invokevirtual java.time.Instant.isBefore:(Ljava/time/Instant;)Z
            ifeq 2
         1: .line 174
            iconst_0
            ireturn
         2: .line 176
      StackMap locals:
      StackMap stack:
            aload 2 /* endTime */
            ifnull 4
            aload 0 /* this */
            invokevirtual jdk.jfr.internal.RepositoryChunk.getStartTime:()Ljava/time/Instant;
            aload 2 /* endTime */
            invokevirtual java.time.Instant.isAfter:(Ljava/time/Instant;)Z
            ifeq 4
         3: .line 177
            iconst_0
            ireturn
         4: .line 179
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 2 // java.time.Instant endTime
        end local 1 // java.time.Instant startTime
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    5     0       this  Ljdk/jfr/internal/RepositoryChunk;
            0    5     1  startTime  Ljava/time/Instant;
            0    5     2    endTime  Ljava/time/Instant;
    MethodParameters:
           Name  Flags
      startTime  
      endTime    

  public jdk.jfr.internal.SecuritySupport$SafePath getFile();
    descriptor: ()Ljdk/jfr/internal/SecuritySupport$SafePath;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // jdk.jfr.internal.RepositoryChunk this
         0: .line 183
            aload 0 /* this */
            getfield jdk.jfr.internal.RepositoryChunk.chunkFile:Ljdk/jfr/internal/SecuritySupport$SafePath;
            areturn
        end local 0 // jdk.jfr.internal.RepositoryChunk this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljdk/jfr/internal/RepositoryChunk;
}
SourceFile: "RepositoryChunk.java"
NestMembers:
  jdk.jfr.internal.RepositoryChunk$1
InnerClasses:
  jdk.jfr.internal.RepositoryChunk$1
  public final SafePath = jdk.jfr.internal.SecuritySupport$SafePath of jdk.jfr.internal.SecuritySupport