public final class com.sun.javafx.logging.jfr.JFRPulseLogger extends com.sun.javafx.logging.Logger
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: com.sun.javafx.logging.jfr.JFRPulseLogger
  super_class: com.sun.javafx.logging.Logger
{
  private final java.lang.ThreadLocal<com.sun.javafx.logging.jfr.JFRPulsePhaseEvent> currentPulsePhaseEvent;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/lang/ThreadLocal<Lcom/sun/javafx/logging/jfr/JFRPulsePhaseEvent;>;

  private final java.lang.ThreadLocal<com.sun.javafx.logging.jfr.JFRInputEvent> currentInputEvent;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/lang/ThreadLocal<Lcom/sun/javafx/logging/jfr/JFRInputEvent;>;

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

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

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

  private java.lang.Thread fxThread;
    descriptor: Ljava/lang/Thread;
    flags: (0x0002) ACC_PRIVATE

  public static com.sun.javafx.logging.Logger createInstance();
    descriptor: ()Lcom/sun/javafx/logging/Logger;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 42
            invokestatic jdk.jfr.FlightRecorder.isInitialized:()Z
            ifne 1
            invokestatic com.sun.javafx.logging.PulseLogger.isPulseLoggingRequested:()Z
            ifeq 2
         1: .line 43
      StackMap locals:
      StackMap stack:
            new com.sun.javafx.logging.jfr.JFRPulseLogger
            dup
            invokespecial com.sun.javafx.logging.jfr.JFRPulseLogger.<init>:()V
            areturn
         2: .line 45
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
         0: .line 48
            aload 0 /* this */
            invokespecial com.sun.javafx.logging.Logger.<init>:()V
         1: .line 49
            ldc Lcom/sun/javafx/logging/jfr/JFRInputEvent;
            invokestatic jdk.jfr.FlightRecorder.register:(Ljava/lang/Class;)V
         2: .line 50
            ldc Lcom/sun/javafx/logging/jfr/JFRPulsePhaseEvent;
            invokestatic jdk.jfr.FlightRecorder.register:(Ljava/lang/Class;)V
         3: .line 51
            aload 0 /* this */
            new com.sun.javafx.logging.jfr.JFRPulseLogger$1
            dup
            aload 0 /* this */
            invokespecial com.sun.javafx.logging.jfr.JFRPulseLogger$1.<init>:(Lcom/sun/javafx/logging/jfr/JFRPulseLogger;)V
            putfield com.sun.javafx.logging.jfr.JFRPulseLogger.currentPulsePhaseEvent:Ljava/lang/ThreadLocal;
         4: .line 57
            aload 0 /* this */
            new com.sun.javafx.logging.jfr.JFRPulseLogger$2
            dup
            aload 0 /* this */
            invokespecial com.sun.javafx.logging.jfr.JFRPulseLogger$2.<init>:(Lcom/sun/javafx/logging/jfr/JFRPulseLogger;)V
            putfield com.sun.javafx.logging.jfr.JFRPulseLogger.currentInputEvent:Ljava/lang/ThreadLocal;
         5: .line 63
            return
        end local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lcom/sun/javafx/logging/jfr/JFRPulseLogger;

  public void pulseStart();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
         0: .line 67
            aload 0 /* this */
            dup
            getfield com.sun.javafx.logging.jfr.JFRPulseLogger.pulseNumber:I
            iconst_1
            iadd
            putfield com.sun.javafx.logging.jfr.JFRPulseLogger.pulseNumber:I
         1: .line 68
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.javafx.logging.jfr.JFRPulseLogger.pulseNumber:I
            putfield com.sun.javafx.logging.jfr.JFRPulseLogger.fxPulseNumber:I
         2: .line 69
            aload 0 /* this */
            getfield com.sun.javafx.logging.jfr.JFRPulseLogger.fxThread:Ljava/lang/Thread;
            ifnonnull 4
         3: .line 70
            aload 0 /* this */
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            putfield com.sun.javafx.logging.jfr.JFRPulseLogger.fxThread:Ljava/lang/Thread;
         4: .line 72
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "Pulse start"
            invokevirtual com.sun.javafx.logging.jfr.JFRPulseLogger.newPhase:(Ljava/lang/String;)V
         5: .line 73
            return
        end local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lcom/sun/javafx/logging/jfr/JFRPulseLogger;

  public void pulseEnd();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
         0: .line 77
            aload 0 /* this */
            aconst_null
            invokevirtual com.sun.javafx.logging.jfr.JFRPulseLogger.newPhase:(Ljava/lang/String;)V
         1: .line 78
            aload 0 /* this */
            iconst_0
            putfield com.sun.javafx.logging.jfr.JFRPulseLogger.fxPulseNumber:I
         2: .line 79
            return
        end local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/sun/javafx/logging/jfr/JFRPulseLogger;

  public void renderStart();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
         0: .line 83
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.javafx.logging.jfr.JFRPulseLogger.fxPulseNumber:I
            putfield com.sun.javafx.logging.jfr.JFRPulseLogger.renderPulseNumber:I
         1: .line 84
            return
        end local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/sun/javafx/logging/jfr/JFRPulseLogger;

  public void renderEnd();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
         0: .line 88
            aload 0 /* this */
            aconst_null
            invokevirtual com.sun.javafx.logging.jfr.JFRPulseLogger.newPhase:(Ljava/lang/String;)V
         1: .line 89
            aload 0 /* this */
            iconst_0
            putfield com.sun.javafx.logging.jfr.JFRPulseLogger.renderPulseNumber:I
         2: .line 90
            return
        end local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/sun/javafx/logging/jfr/JFRPulseLogger;

  public void newPhase(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
        start local 1 // java.lang.String phaseName
         0: .line 99
            aload 0 /* this */
            getfield com.sun.javafx.logging.jfr.JFRPulseLogger.currentPulsePhaseEvent:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast com.sun.javafx.logging.jfr.JFRPulsePhaseEvent
            astore 2 /* event */
        start local 2 // com.sun.javafx.logging.jfr.JFRPulsePhaseEvent event
         1: .line 102
            aload 2 /* event */
            invokevirtual com.sun.javafx.logging.jfr.JFRPulsePhaseEvent.isEnabled:()Z
            ifne 4
         2: .line 103
            aload 2 /* event */
            aconst_null
            invokevirtual com.sun.javafx.logging.jfr.JFRPulsePhaseEvent.setPhaseName:(Ljava/lang/String;)V
         3: .line 104
            return
         4: .line 108
      StackMap locals: com.sun.javafx.logging.jfr.JFRPulsePhaseEvent
      StackMap stack:
            aload 2 /* event */
            invokevirtual com.sun.javafx.logging.jfr.JFRPulsePhaseEvent.getPhaseName:()Ljava/lang/String;
            ifnull 6
         5: .line 109
            aload 2 /* event */
            invokevirtual com.sun.javafx.logging.jfr.JFRPulsePhaseEvent.commit:()V
         6: .line 113
      StackMap locals:
      StackMap stack:
            aload 1 /* phaseName */
            ifnonnull 9
         7: .line 114
            aload 2 /* event */
            aconst_null
            invokevirtual com.sun.javafx.logging.jfr.JFRPulsePhaseEvent.setPhaseName:(Ljava/lang/String;)V
         8: .line 115
            return
         9: .line 118
      StackMap locals:
      StackMap stack:
            new com.sun.javafx.logging.jfr.JFRPulsePhaseEvent
            dup
            invokespecial com.sun.javafx.logging.jfr.JFRPulsePhaseEvent.<init>:()V
            astore 2 /* event */
        10: .line 119
            aload 2 /* event */
            invokevirtual com.sun.javafx.logging.jfr.JFRPulsePhaseEvent.begin:()V
        11: .line 120
            aload 2 /* event */
            aload 1 /* phaseName */
            invokevirtual com.sun.javafx.logging.jfr.JFRPulsePhaseEvent.setPhaseName:(Ljava/lang/String;)V
        12: .line 121
            aload 2 /* event */
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            aload 0 /* this */
            getfield com.sun.javafx.logging.jfr.JFRPulseLogger.fxThread:Ljava/lang/Thread;
            if_acmpne 13
            aload 0 /* this */
            getfield com.sun.javafx.logging.jfr.JFRPulseLogger.fxPulseNumber:I
            goto 14
      StackMap locals:
      StackMap stack: com.sun.javafx.logging.jfr.JFRPulsePhaseEvent
        13: aload 0 /* this */
            getfield com.sun.javafx.logging.jfr.JFRPulseLogger.renderPulseNumber:I
      StackMap locals: com.sun.javafx.logging.jfr.JFRPulseLogger java.lang.String com.sun.javafx.logging.jfr.JFRPulsePhaseEvent
      StackMap stack: com.sun.javafx.logging.jfr.JFRPulsePhaseEvent int
        14: invokevirtual com.sun.javafx.logging.jfr.JFRPulsePhaseEvent.setPulseId:(I)V
        15: .line 122
            aload 0 /* this */
            getfield com.sun.javafx.logging.jfr.JFRPulseLogger.currentPulsePhaseEvent:Ljava/lang/ThreadLocal;
            aload 2 /* event */
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
        16: .line 123
            return
        end local 2 // com.sun.javafx.logging.jfr.JFRPulsePhaseEvent event
        end local 1 // java.lang.String phaseName
        end local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   17     0       this  Lcom/sun/javafx/logging/jfr/JFRPulseLogger;
            0   17     1  phaseName  Ljava/lang/String;
            1   17     2      event  Lcom/sun/javafx/logging/jfr/JFRPulsePhaseEvent;
    MethodParameters:
           Name  Flags
      phaseName  

  public void newInput(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
        start local 1 // java.lang.String input
         0: .line 127
            aload 0 /* this */
            getfield com.sun.javafx.logging.jfr.JFRPulseLogger.currentInputEvent:Ljava/lang/ThreadLocal;
            invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
            checkcast com.sun.javafx.logging.jfr.JFRInputEvent
            astore 2 /* event */
        start local 2 // com.sun.javafx.logging.jfr.JFRInputEvent event
         1: .line 130
            aload 2 /* event */
            invokevirtual com.sun.javafx.logging.jfr.JFRInputEvent.isEnabled:()Z
            ifne 4
         2: .line 131
            aload 2 /* event */
            aconst_null
            invokevirtual com.sun.javafx.logging.jfr.JFRInputEvent.setInput:(Ljava/lang/String;)V
         3: .line 132
            return
         4: .line 136
      StackMap locals: com.sun.javafx.logging.jfr.JFRInputEvent
      StackMap stack:
            aload 2 /* event */
            invokevirtual com.sun.javafx.logging.jfr.JFRInputEvent.getInput:()Ljava/lang/String;
            ifnull 6
         5: .line 137
            aload 2 /* event */
            invokevirtual com.sun.javafx.logging.jfr.JFRInputEvent.commit:()V
         6: .line 141
      StackMap locals:
      StackMap stack:
            aload 1 /* input */
            ifnonnull 9
         7: .line 142
            aload 2 /* event */
            aconst_null
            invokevirtual com.sun.javafx.logging.jfr.JFRInputEvent.setInput:(Ljava/lang/String;)V
         8: .line 143
            return
         9: .line 146
      StackMap locals:
      StackMap stack:
            new com.sun.javafx.logging.jfr.JFRInputEvent
            dup
            invokespecial com.sun.javafx.logging.jfr.JFRInputEvent.<init>:()V
            astore 2 /* event */
        10: .line 147
            aload 2 /* event */
            invokevirtual com.sun.javafx.logging.jfr.JFRInputEvent.begin:()V
        11: .line 148
            aload 2 /* event */
            aload 1 /* input */
            invokevirtual com.sun.javafx.logging.jfr.JFRInputEvent.setInput:(Ljava/lang/String;)V
        12: .line 149
            aload 0 /* this */
            getfield com.sun.javafx.logging.jfr.JFRPulseLogger.currentInputEvent:Ljava/lang/ThreadLocal;
            aload 2 /* event */
            invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
        13: .line 150
            return
        end local 2 // com.sun.javafx.logging.jfr.JFRInputEvent event
        end local 1 // java.lang.String input
        end local 0 // com.sun.javafx.logging.jfr.JFRPulseLogger this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   14     0   this  Lcom/sun/javafx/logging/jfr/JFRPulseLogger;
            0   14     1  input  Ljava/lang/String;
            1   14     2  event  Lcom/sun/javafx/logging/jfr/JFRInputEvent;
    MethodParameters:
       Name  Flags
      input  
}
SourceFile: "JFRPulseLogger.java"
NestMembers:
  com.sun.javafx.logging.jfr.JFRPulseLogger$1  com.sun.javafx.logging.jfr.JFRPulseLogger$2
InnerClasses:
  com.sun.javafx.logging.jfr.JFRPulseLogger$1
  com.sun.javafx.logging.jfr.JFRPulseLogger$2