final class jdk.jfr.internal.dcmd.DCmdDump extends jdk.jfr.internal.dcmd.AbstractDCmd
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: jdk.jfr.internal.dcmd.DCmdDump
  super_class: jdk.jfr.internal.dcmd.AbstractDCmd
{
  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // jdk.jfr.internal.dcmd.DCmdDump this
         0: .line 55
            aload 0 /* this */
            invokespecial jdk.jfr.internal.dcmd.AbstractDCmd.<init>:()V
            return
        end local 0 // jdk.jfr.internal.dcmd.DCmdDump this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljdk/jfr/internal/dcmd/DCmdDump;

  public java.lang.String execute(java.lang.String, java.lang.String, java.lang.Long, java.lang.Long, java.lang.String, java.lang.String, java.lang.Boolean);
    descriptor: (Ljava/lang/String;Ljava/lang/String;Ljava/lang/Long;Ljava/lang/Long;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Boolean;)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=14, args_size=8
        start local 0 // jdk.jfr.internal.dcmd.DCmdDump this
        start local 1 // java.lang.String name
        start local 2 // java.lang.String filename
        start local 3 // java.lang.Long maxAge
        start local 4 // java.lang.Long maxSize
        start local 5 // java.lang.String begin
        start local 6 // java.lang.String end
        start local 7 // java.lang.Boolean pathToGcRoots
         0: .line 73
            getstatic jdk.jfr.internal.LogTag.JFR_DCMD: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 11
         1: .line 74
            getstatic jdk.jfr.internal.LogTag.JFR_DCMD:Ljdk/jfr/internal/LogTag;
            getstatic jdk.jfr.internal.LogLevel.DEBUG:Ljdk/jfr/internal/LogLevel;
         2: .line 75
            new java.lang.StringBuilder
            dup
            ldc "Executing DCmdDump: name="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* name */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         3: .line 76
            ldc ", filename="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* filename */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         4: .line 77
            ldc ", maxage="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* maxAge */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         5: .line 78
            ldc ", maxsize="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* maxSize */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         6: .line 79
            ldc ", begin="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 5 /* begin */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         7: .line 80
            ldc ", end"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 6 /* end */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         8: .line 81
            ldc ", path-to-gc-roots="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 7 /* pathToGcRoots */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         9: .line 75
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 74
            invokestatic jdk.jfr.internal.Logger.log:(Ljdk/jfr/internal/LogTag;Ljdk/jfr/internal/LogLevel;Ljava/lang/String;)V
        11: .line 84
      StackMap locals:
      StackMap stack:
            invokestatic jdk.jfr.FlightRecorder.getFlightRecorder:()Ljdk/jfr/FlightRecorder;
            invokevirtual jdk.jfr.FlightRecorder.getRecordings:()Ljava/util/List;
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 13
        12: .line 85
            new jdk.jfr.internal.dcmd.DCmdException
            dup
            ldc "No recordings to dump from. Use JFR.start to start a recording."
            iconst_0
            anewarray java.lang.Object
            invokespecial jdk.jfr.internal.dcmd.DCmdException.<init>:(Ljava/lang/String;[Ljava/lang/Object;)V
            athrow
        13: .line 88
      StackMap locals:
      StackMap stack:
            aload 3 /* maxAge */
            ifnull 20
        14: .line 89
            aload 6 /* end */
            ifnonnull 15
            aload 5 /* begin */
            ifnull 16
        15: .line 90
      StackMap locals:
      StackMap stack:
            new jdk.jfr.internal.dcmd.DCmdException
            dup
            ldc "Dump failed, maxage can't be combined with begin or end."
            iconst_0
            anewarray java.lang.Object
            invokespecial jdk.jfr.internal.dcmd.DCmdException.<init>:(Ljava/lang/String;[Ljava/lang/Object;)V
            athrow
        16: .line 93
      StackMap locals:
      StackMap stack:
            aload 3 /* maxAge */
            invokevirtual java.lang.Long.longValue:()J
            lconst_0
            lcmp
            ifge 18
        17: .line 94
            new jdk.jfr.internal.dcmd.DCmdException
            dup
            ldc "Dump failed, maxage can't be negative."
            iconst_0
            anewarray java.lang.Object
            invokespecial jdk.jfr.internal.dcmd.DCmdException.<init>:(Ljava/lang/String;[Ljava/lang/Object;)V
            athrow
        18: .line 96
      StackMap locals:
      StackMap stack:
            aload 3 /* maxAge */
            invokevirtual java.lang.Long.longValue:()J
            lconst_0
            lcmp
            ifne 20
        19: .line 97
            ldc 4611686018427387903
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            astore 3 /* maxAge */
        20: .line 101
      StackMap locals:
      StackMap stack:
            aload 4 /* maxSize */
            ifnull 25
        21: .line 102
            aload 4 /* maxSize */
            invokevirtual java.lang.Long.longValue:()J
            lconst_0
            lcmp
            ifge 23
        22: .line 103
            new jdk.jfr.internal.dcmd.DCmdException
            dup
            ldc "Dump failed, maxsize can't be negative."
            iconst_0
            anewarray java.lang.Object
            invokespecial jdk.jfr.internal.dcmd.DCmdException.<init>:(Ljava/lang/String;[Ljava/lang/Object;)V
            athrow
        23: .line 105
      StackMap locals:
      StackMap stack:
            aload 4 /* maxSize */
            invokevirtual java.lang.Long.longValue:()J
            lconst_0
            lcmp
            ifne 25
        24: .line 106
            ldc 4611686018427387903
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            astore 4 /* maxSize */
        25: .line 110
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 5 /* begin */
            ldc "begin"
            invokevirtual jdk.jfr.internal.dcmd.DCmdDump.parseTime:(Ljava/lang/String;Ljava/lang/String;)Ljava/time/Instant;
            astore 8 /* beginTime */
        start local 8 // java.time.Instant beginTime
        26: .line 111
            aload 0 /* this */
            aload 6 /* end */
            ldc "end"
            invokevirtual jdk.jfr.internal.dcmd.DCmdDump.parseTime:(Ljava/lang/String;Ljava/lang/String;)Ljava/time/Instant;
            astore 9 /* endTime */
        start local 9 // java.time.Instant endTime
        27: .line 113
            aload 8 /* beginTime */
            ifnull 30
            aload 9 /* endTime */
            ifnull 30
        28: .line 114
            aload 9 /* endTime */
            aload 8 /* beginTime */
            invokevirtual java.time.Instant.isBefore:(Ljava/time/Instant;)Z
            ifeq 30
        29: .line 115
            new jdk.jfr.internal.dcmd.DCmdException
            dup
            ldc "Dump failed, begin must preceed end."
            iconst_0
            anewarray java.lang.Object
            invokespecial jdk.jfr.internal.dcmd.DCmdException.<init>:(Ljava/lang/String;[Ljava/lang/Object;)V
            athrow
        30: .line 119
      StackMap locals: java.time.Instant java.time.Instant
      StackMap stack:
            aconst_null
            astore 10 /* duration */
        start local 10 // java.time.Duration duration
        31: .line 120
            aload 3 /* maxAge */
            ifnull 34
        32: .line 121
            aload 3 /* maxAge */
            invokevirtual java.lang.Long.longValue:()J
            invokestatic java.time.Duration.ofNanos:(J)Ljava/time/Duration;
            astore 10 /* duration */
        33: .line 122
            invokestatic java.time.Instant.now:()Ljava/time/Instant;
            aload 10 /* duration */
            invokevirtual java.time.Instant.minus:(Ljava/time/temporal/TemporalAmount;)Ljava/time/Instant;
            astore 8 /* beginTime */
        34: .line 124
      StackMap locals: java.time.Duration
      StackMap stack:
            aconst_null
            astore 11 /* recording */
        start local 11 // jdk.jfr.Recording recording
        35: .line 125
            aload 1 /* name */
            ifnull 37
        36: .line 126
            aload 0 /* this */
            aload 1 /* name */
            invokevirtual jdk.jfr.internal.dcmd.DCmdDump.findRecording:(Ljava/lang/String;)Ljdk/jfr/Recording;
            astore 11 /* recording */
        37: .line 128
      StackMap locals: jdk.jfr.Recording
      StackMap stack:
            invokestatic jdk.jfr.internal.PrivateAccess.getInstance:()Ljdk/jfr/internal/PrivateAccess;
            invokevirtual jdk.jfr.internal.PrivateAccess.getPlatformRecorder:()Ljdk/jfr/internal/PlatformRecorder;
            astore 12 /* recorder */
        start local 12 // jdk.jfr.internal.PlatformRecorder recorder
        38: .line 129
            aload 12 /* recorder */
            dup
            astore 13
            monitorenter
        39: .line 130
            aload 0 /* this */
            aload 12 /* recorder */
            aload 11 /* recording */
            aload 1 /* name */
            aload 2 /* filename */
            aload 4 /* maxSize */
            aload 7 /* pathToGcRoots */
            aload 8 /* beginTime */
            aload 9 /* endTime */
            invokevirtual jdk.jfr.internal.dcmd.DCmdDump.dump:(Ljdk/jfr/internal/PlatformRecorder;Ljdk/jfr/Recording;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Long;Ljava/lang/Boolean;Ljava/time/Instant;Ljava/time/Instant;)V
        40: .line 129
            aload 13
            monitorexit
        41: goto 44
      StackMap locals: jdk.jfr.internal.dcmd.DCmdDump java.lang.String java.lang.String java.lang.Long java.lang.Long java.lang.String java.lang.String java.lang.Boolean java.time.Instant java.time.Instant java.time.Duration jdk.jfr.Recording jdk.jfr.internal.PlatformRecorder jdk.jfr.internal.PlatformRecorder
      StackMap stack: java.lang.Throwable
        42: aload 13
            monitorexit
        43: athrow
        44: .line 132
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual jdk.jfr.internal.dcmd.DCmdDump.getResult:()Ljava/lang/String;
            areturn
        end local 12 // jdk.jfr.internal.PlatformRecorder recorder
        end local 11 // jdk.jfr.Recording recording
        end local 10 // java.time.Duration duration
        end local 9 // java.time.Instant endTime
        end local 8 // java.time.Instant beginTime
        end local 7 // java.lang.Boolean pathToGcRoots
        end local 6 // java.lang.String end
        end local 5 // java.lang.String begin
        end local 4 // java.lang.Long maxSize
        end local 3 // java.lang.Long maxAge
        end local 2 // java.lang.String filename
        end local 1 // java.lang.String name
        end local 0 // jdk.jfr.internal.dcmd.DCmdDump this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   45     0           this  Ljdk/jfr/internal/dcmd/DCmdDump;
            0   45     1           name  Ljava/lang/String;
            0   45     2       filename  Ljava/lang/String;
            0   45     3         maxAge  Ljava/lang/Long;
            0   45     4        maxSize  Ljava/lang/Long;
            0   45     5          begin  Ljava/lang/String;
            0   45     6            end  Ljava/lang/String;
            0   45     7  pathToGcRoots  Ljava/lang/Boolean;
           26   45     8      beginTime  Ljava/time/Instant;
           27   45     9        endTime  Ljava/time/Instant;
           31   45    10       duration  Ljava/time/Duration;
           35   45    11      recording  Ljdk/jfr/Recording;
           38   45    12       recorder  Ljdk/jfr/internal/PlatformRecorder;
      Exception table:
        from    to  target  type
          39    41      42  any
          42    43      42  any
    Exceptions:
      throws jdk.jfr.internal.dcmd.DCmdException
    MethodParameters:
               Name  Flags
      name           
      filename       
      maxAge         
      maxSize        
      begin          
      end            
      pathToGcRoots  

  public void dump(jdk.jfr.internal.PlatformRecorder, jdk.jfr.Recording, java.lang.String, java.lang.String, java.lang.Long, java.lang.Boolean, java.time.Instant, java.time.Instant);
    descriptor: (Ljdk/jfr/internal/PlatformRecorder;Ljdk/jfr/Recording;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Long;Ljava/lang/Boolean;Ljava/time/Instant;Ljava/time/Instant;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=13, args_size=9
        start local 0 // jdk.jfr.internal.dcmd.DCmdDump this
        start local 1 // jdk.jfr.internal.PlatformRecorder recorder
        start local 2 // jdk.jfr.Recording recording
        start local 3 // java.lang.String name
        start local 4 // java.lang.String filename
        start local 5 // java.lang.Long maxSize
        start local 6 // java.lang.Boolean pathToGcRoots
        start local 7 // java.time.Instant beginTime
        start local 8 // java.time.Instant endTime
         0: .line 136
            aconst_null
            astore 9
            aconst_null
            astore 10
         1: aload 0 /* this */
            aload 1 /* recorder */
            aload 2 /* recording */
            aload 6 /* pathToGcRoots */
            invokevirtual jdk.jfr.internal.dcmd.DCmdDump.newSnapShot:(Ljdk/jfr/internal/PlatformRecorder;Ljdk/jfr/Recording;Ljava/lang/Boolean;)Ljdk/jfr/internal/PlatformRecording;
            astore 11 /* r */
        start local 11 // jdk.jfr.internal.PlatformRecording r
         2: .line 137
            aload 11 /* r */
            aload 7 /* beginTime */
            aload 8 /* endTime */
            aload 5 /* maxSize */
            invokevirtual jdk.jfr.internal.PlatformRecording.filter:(Ljava/time/Instant;Ljava/time/Instant;Ljava/lang/Long;)V
         3: .line 138
            aload 11 /* r */
            invokevirtual jdk.jfr.internal.PlatformRecording.getChunks:()Ljava/util/List;
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 5
         4: .line 139
            new jdk.jfr.internal.dcmd.DCmdException
            dup
            ldc "Dump failed. No data found in the specified interval."
            iconst_0
            anewarray java.lang.Object
            invokespecial jdk.jfr.internal.dcmd.DCmdException.<init>:(Ljava/lang/String;[Ljava/lang/Object;)V
            athrow
         5: .line 141
      StackMap locals: java.lang.Throwable java.lang.Throwable jdk.jfr.internal.PlatformRecording
      StackMap stack:
            aload 0 /* this */
            aload 2 /* recording */
            aload 4 /* filename */
            invokevirtual jdk.jfr.internal.dcmd.DCmdDump.resolvePath:(Ljdk/jfr/Recording;Ljava/lang/String;)Ljdk/jfr/internal/SecuritySupport$SafePath;
            astore 12 /* dumpFile */
        start local 12 // jdk.jfr.internal.SecuritySupport$SafePath dumpFile
         6: .line 144
            aload 12 /* dumpFile */
            invokevirtual jdk.jfr.internal.SecuritySupport$SafePath.toPath:()Ljava/nio/file/Path;
            invokestatic jdk.jfr.internal.Utils.touch:(Ljava/nio/file/Path;)V
         7: .line 145
            aload 11 /* r */
            new jdk.jfr.internal.WriteableUserPath
            dup
            aload 12 /* dumpFile */
            invokevirtual jdk.jfr.internal.SecuritySupport$SafePath.toPath:()Ljava/nio/file/Path;
            invokespecial jdk.jfr.internal.WriteableUserPath.<init>:(Ljava/nio/file/Path;)V
            invokevirtual jdk.jfr.internal.PlatformRecording.dumpStopped:(Ljdk/jfr/internal/WriteableUserPath;)V
         8: .line 146
            aload 0 /* this */
            ldc "Dumped"
            aload 3 /* name */
            aload 12 /* dumpFile */
            invokevirtual jdk.jfr.internal.dcmd.DCmdDump.reportOperationComplete:(Ljava/lang/String;Ljava/lang/String;Ljdk/jfr/internal/SecuritySupport$SafePath;)V
        end local 12 // jdk.jfr.internal.SecuritySupport$SafePath dumpFile
         9: .line 147
            aload 11 /* r */
            ifnull 17
            aload 11 /* r */
            invokevirtual jdk.jfr.internal.PlatformRecording.close:()V
            goto 17
      StackMap locals:
      StackMap stack: java.lang.Throwable
        10: astore 9
            aload 11 /* r */
            ifnull 11
            aload 11 /* r */
            invokevirtual jdk.jfr.internal.PlatformRecording.close:()V
        end local 11 // jdk.jfr.internal.PlatformRecording r
      StackMap locals:
      StackMap stack:
        11: aload 9
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        12: astore 10
            aload 9
            ifnonnull 13
            aload 10
            astore 9
            goto 14
      StackMap locals:
      StackMap stack:
        13: aload 9
            aload 10
            if_acmpeq 14
            aload 9
            aload 10
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        14: aload 9
            athrow
      StackMap locals: jdk.jfr.internal.dcmd.DCmdDump jdk.jfr.internal.PlatformRecorder jdk.jfr.Recording java.lang.String java.lang.String java.lang.Long java.lang.Boolean java.time.Instant java.time.Instant
      StackMap stack: java.lang.Exception
        15: astore 9 /* e */
        start local 9 // java.lang.Exception e
        16: .line 148
            new jdk.jfr.internal.dcmd.DCmdException
            dup
            ldc "Dump failed. Could not copy recording data. %s"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 9 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            aastore
            invokespecial jdk.jfr.internal.dcmd.DCmdException.<init>:(Ljava/lang/String;[Ljava/lang/Object;)V
            athrow
        end local 9 // java.lang.Exception e
        17: .line 150
      StackMap locals:
      StackMap stack:
            return
        end local 8 // java.time.Instant endTime
        end local 7 // java.time.Instant beginTime
        end local 6 // java.lang.Boolean pathToGcRoots
        end local 5 // java.lang.Long maxSize
        end local 4 // java.lang.String filename
        end local 3 // java.lang.String name
        end local 2 // jdk.jfr.Recording recording
        end local 1 // jdk.jfr.internal.PlatformRecorder recorder
        end local 0 // jdk.jfr.internal.dcmd.DCmdDump this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   18     0           this  Ljdk/jfr/internal/dcmd/DCmdDump;
            0   18     1       recorder  Ljdk/jfr/internal/PlatformRecorder;
            0   18     2      recording  Ljdk/jfr/Recording;
            0   18     3           name  Ljava/lang/String;
            0   18     4       filename  Ljava/lang/String;
            0   18     5        maxSize  Ljava/lang/Long;
            0   18     6  pathToGcRoots  Ljava/lang/Boolean;
            0   18     7      beginTime  Ljava/time/Instant;
            0   18     8        endTime  Ljava/time/Instant;
            2   11    11              r  Ljdk/jfr/internal/PlatformRecording;
            6    9    12       dumpFile  Ljdk/jfr/internal/SecuritySupport$SafePath;
           16   17     9              e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2     9      10  any
           1    12      12  any
           0    15      15  Class java.io.IOException
           0    15      15  Class java.nio.file.InvalidPathException
    Exceptions:
      throws jdk.jfr.internal.dcmd.DCmdException
    MethodParameters:
               Name  Flags
      recorder       
      recording      
      name           
      filename       
      maxSize        
      pathToGcRoots  
      beginTime      
      endTime        

  private java.time.Instant parseTime(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)Ljava/time/Instant;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=7, args_size=3
        start local 0 // jdk.jfr.internal.dcmd.DCmdDump this
        start local 1 // java.lang.String time
        start local 2 // java.lang.String parameter
         0: .line 153
            aload 1 /* time */
            ifnonnull 2
         1: .line 154
            aconst_null
            areturn
         2: .line 157
      StackMap locals:
      StackMap stack:
            aload 1 /* time */
            invokestatic java.time.Instant.parse:(Ljava/lang/CharSequence;)Ljava/time/Instant;
         3: areturn
         4: .line 158
      StackMap locals:
      StackMap stack: java.time.format.DateTimeParseException
            pop
         5: .line 162
            aload 1 /* time */
            invokestatic java.time.LocalDateTime.parse:(Ljava/lang/CharSequence;)Ljava/time/LocalDateTime;
            astore 3 /* ldt */
        start local 3 // java.time.LocalDateTime ldt
         6: .line 163
            aload 3 /* ldt */
            invokestatic java.time.ZoneId.systemDefault:()Ljava/time/ZoneId;
            invokestatic java.time.ZonedDateTime.of:(Ljava/time/LocalDateTime;Ljava/time/ZoneId;)Ljava/time/ZonedDateTime;
            invokevirtual java.time.ZonedDateTime.toInstant:()Ljava/time/Instant;
         7: areturn
        end local 3 // java.time.LocalDateTime ldt
         8: .line 164
      StackMap locals:
      StackMap stack: java.time.format.DateTimeParseException
            pop
         9: .line 168
            aload 1 /* time */
            invokestatic java.time.LocalTime.parse:(Ljava/lang/CharSequence;)Ljava/time/LocalTime;
            astore 3 /* lt */
        start local 3 // java.time.LocalTime lt
        10: .line 169
            invokestatic java.time.LocalDate.now:()Ljava/time/LocalDate;
            astore 4 /* ld */
        start local 4 // java.time.LocalDate ld
        11: .line 170
            aload 4 /* ld */
            aload 3 /* lt */
            invokestatic java.time.ZoneId.systemDefault:()Ljava/time/ZoneId;
            invokestatic java.time.ZonedDateTime.of:(Ljava/time/LocalDate;Ljava/time/LocalTime;Ljava/time/ZoneId;)Ljava/time/ZonedDateTime;
            invokevirtual java.time.ZonedDateTime.toInstant:()Ljava/time/Instant;
            astore 5 /* instant */
        start local 5 // java.time.Instant instant
        12: .line 171
            invokestatic java.time.Instant.now:()Ljava/time/Instant;
            astore 6 /* now */
        start local 6 // java.time.Instant now
        13: .line 172
            aload 5 /* instant */
            aload 6 /* now */
            invokevirtual java.time.Instant.isAfter:(Ljava/time/Instant;)Z
            ifeq 15
            aload 5 /* instant */
            aload 6 /* now */
            ldc 3600
            invokevirtual java.time.Instant.plusSeconds:(J)Ljava/time/Instant;
            invokevirtual java.time.Instant.isBefore:(Ljava/time/Instant;)Z
            ifne 15
        14: .line 174
            aload 4 /* ld */
            lconst_1
            invokevirtual java.time.LocalDate.minusDays:(J)Ljava/time/LocalDate;
            astore 4 /* ld */
        15: .line 176
      StackMap locals: jdk.jfr.internal.dcmd.DCmdDump java.lang.String java.lang.String java.time.LocalTime java.time.LocalDate java.time.Instant java.time.Instant
      StackMap stack:
            aload 4 /* ld */
            aload 3 /* lt */
            invokestatic java.time.ZoneId.systemDefault:()Ljava/time/ZoneId;
            invokestatic java.time.ZonedDateTime.of:(Ljava/time/LocalDate;Ljava/time/LocalTime;Ljava/time/ZoneId;)Ljava/time/ZonedDateTime;
            invokevirtual java.time.ZonedDateTime.toInstant:()Ljava/time/Instant;
        16: areturn
        end local 6 // java.time.Instant now
        end local 5 // java.time.Instant instant
        end local 4 // java.time.LocalDate ld
        end local 3 // java.time.LocalTime lt
        17: .line 177
      StackMap locals: jdk.jfr.internal.dcmd.DCmdDump java.lang.String java.lang.String
      StackMap stack: java.time.format.DateTimeParseException
            pop
        18: .line 181
            aload 1 /* time */
            ldc "-"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 24
        19: .line 183
            aload 1 /* time */
            iconst_1
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            invokestatic jdk.jfr.internal.Utils.parseTimespan:(Ljava/lang/String;)J
            lstore 3 /* durationNanos */
        start local 3 // long durationNanos
        20: .line 184
            lload 3 /* durationNanos */
            invokestatic java.time.Duration.ofNanos:(J)Ljava/time/Duration;
            astore 5 /* duration */
        start local 5 // java.time.Duration duration
        21: .line 185
            invokestatic java.time.Instant.now:()Ljava/time/Instant;
            aload 5 /* duration */
            invokevirtual java.time.Instant.minus:(Ljava/time/temporal/TemporalAmount;)Ljava/time/Instant;
        22: areturn
        end local 5 // java.time.Duration duration
        end local 3 // long durationNanos
        23: .line 186
      StackMap locals:
      StackMap stack: java.lang.NumberFormatException
            pop
        24: .line 190
      StackMap locals:
      StackMap stack:
            new jdk.jfr.internal.dcmd.DCmdException
            dup
            ldc "Dump failed, not a valid %s time."
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 2 /* parameter */
            aastore
            invokespecial jdk.jfr.internal.dcmd.DCmdException.<init>:(Ljava/lang/String;[Ljava/lang/Object;)V
            athrow
        end local 2 // java.lang.String parameter
        end local 1 // java.lang.String time
        end local 0 // jdk.jfr.internal.dcmd.DCmdDump this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   25     0           this  Ljdk/jfr/internal/dcmd/DCmdDump;
            0   25     1           time  Ljava/lang/String;
            0   25     2      parameter  Ljava/lang/String;
            6    8     3            ldt  Ljava/time/LocalDateTime;
           10   17     3             lt  Ljava/time/LocalTime;
           11   17     4             ld  Ljava/time/LocalDate;
           12   17     5        instant  Ljava/time/Instant;
           13   17     6            now  Ljava/time/Instant;
           20   23     3  durationNanos  J
           21   23     5       duration  Ljava/time/Duration;
      Exception table:
        from    to  target  type
           2     3       4  Class java.time.format.DateTimeParseException
           5     7       8  Class java.time.format.DateTimeParseException
           9    16      17  Class java.time.format.DateTimeParseException
          19    22      23  Class java.lang.NumberFormatException
    Exceptions:
      throws jdk.jfr.internal.dcmd.DCmdException
    MethodParameters:
           Name  Flags
      time       
      parameter  

  private jdk.jfr.internal.PlatformRecording newSnapShot(jdk.jfr.internal.PlatformRecorder, jdk.jfr.Recording, java.lang.Boolean);
    descriptor: (Ljdk/jfr/internal/PlatformRecorder;Ljdk/jfr/Recording;Ljava/lang/Boolean;)Ljdk/jfr/internal/PlatformRecording;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=5, args_size=4
        start local 0 // jdk.jfr.internal.dcmd.DCmdDump this
        start local 1 // jdk.jfr.internal.PlatformRecorder recorder
        start local 2 // jdk.jfr.Recording recording
        start local 3 // java.lang.Boolean pathToGcRoots
         0: .line 194
            aload 2 /* recording */
            ifnonnull 4
         1: .line 196
            aload 1 /* recorder */
            invokevirtual jdk.jfr.internal.PlatformRecorder.newTemporaryRecording:()Ljdk/jfr/internal/PlatformRecording;
            astore 4 /* snapshot */
        start local 4 // jdk.jfr.internal.PlatformRecording snapshot
         2: .line 197
            aload 1 /* recorder */
            aload 4 /* snapshot */
            aload 3 /* pathToGcRoots */
            invokevirtual jdk.jfr.internal.PlatformRecorder.fillWithRecordedData:(Ljdk/jfr/internal/PlatformRecording;Ljava/lang/Boolean;)V
         3: .line 198
            aload 4 /* snapshot */
            areturn
        end local 4 // jdk.jfr.internal.PlatformRecording snapshot
         4: .line 201
      StackMap locals:
      StackMap stack:
            invokestatic jdk.jfr.internal.PrivateAccess.getInstance:()Ljdk/jfr/internal/PrivateAccess;
            aload 2 /* recording */
            invokevirtual jdk.jfr.internal.PrivateAccess.getPlatformRecording:(Ljdk/jfr/Recording;)Ljdk/jfr/internal/PlatformRecording;
            astore 4 /* pr */
        start local 4 // jdk.jfr.internal.PlatformRecording pr
         5: .line 202
            aload 4 /* pr */
            ldc "Dumped by user"
            aload 3 /* pathToGcRoots */
            invokevirtual jdk.jfr.internal.PlatformRecording.newSnapshotClone:(Ljava/lang/String;Ljava/lang/Boolean;)Ljdk/jfr/internal/PlatformRecording;
            areturn
        end local 4 // jdk.jfr.internal.PlatformRecording pr
        end local 3 // java.lang.Boolean pathToGcRoots
        end local 2 // jdk.jfr.Recording recording
        end local 1 // jdk.jfr.internal.PlatformRecorder recorder
        end local 0 // jdk.jfr.internal.dcmd.DCmdDump this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    6     0           this  Ljdk/jfr/internal/dcmd/DCmdDump;
            0    6     1       recorder  Ljdk/jfr/internal/PlatformRecorder;
            0    6     2      recording  Ljdk/jfr/Recording;
            0    6     3  pathToGcRoots  Ljava/lang/Boolean;
            2    4     4       snapshot  Ljdk/jfr/internal/PlatformRecording;
            5    6     4             pr  Ljdk/jfr/internal/PlatformRecording;
    Exceptions:
      throws jdk.jfr.internal.dcmd.DCmdException, java.io.IOException
    MethodParameters:
               Name  Flags
      recorder       
      recording      
      pathToGcRoots  
}
SourceFile: "DCmdDump.java"
InnerClasses:
  public final SafePath = jdk.jfr.internal.SecuritySupport$SafePath of jdk.jfr.internal.SecuritySupport