public class org.apache.logging.log4j.core.time.MutableInstant implements org.apache.logging.log4j.core.time.Instant, java.io.Serializable
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.logging.log4j.core.time.MutableInstant
  super_class: java.lang.Object
{
  private static final int MILLIS_PER_SECOND;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1000

  private static final int NANOS_PER_MILLI;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1000000

  private static final int NANOS_PER_SECOND;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1000000000

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

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

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
         0: .line 35
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/time/MutableInstant;

  public long getEpochSecond();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
         0: .line 46
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.epochSecond:J
            lreturn
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/time/MutableInstant;

  public int getNanoOfSecond();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
         0: .line 51
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.nanoOfSecond:I
            ireturn
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/time/MutableInstant;

  public long getEpochMillisecond();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
         0: .line 56
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.nanoOfSecond:I
            ldc 1000000
            idiv
            istore 1 /* millis */
        start local 1 // int millis
         1: .line 57
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.epochSecond:J
            ldc 1000
            lmul
            iload 1 /* millis */
            i2l
            ladd
            lstore 2 /* epochMillisecond */
        start local 2 // long epochMillisecond
         2: .line 58
            lload 2 /* epochMillisecond */
            lreturn
        end local 2 // long epochMillisecond
        end local 1 // int millis
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    3     0              this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            1    3     1            millis  I
            2    3     2  epochMillisecond  J

  public int getNanoOfMillisecond();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
         0: .line 63
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.nanoOfSecond:I
            ldc 1000000
            idiv
            istore 1 /* millis */
        start local 1 // int millis
         1: .line 64
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.nanoOfSecond:I
            iload 1 /* millis */
            ldc 1000000
            imul
            isub
            istore 2 /* nanoOfMillisecond */
        start local 2 // int nanoOfMillisecond
         2: .line 65
            iload 2 /* nanoOfMillisecond */
            ireturn
        end local 2 // int nanoOfMillisecond
        end local 1 // int millis
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    3     0               this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            1    3     1             millis  I
            2    3     2  nanoOfMillisecond  I

  public void initFrom(org.apache.logging.log4j.core.time.Instant);
    descriptor: (Lorg/apache/logging/log4j/core/time/Instant;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
        start local 1 // org.apache.logging.log4j.core.time.Instant other
         0: .line 69
            aload 0 /* this */
            aload 1 /* other */
            invokeinterface org.apache.logging.log4j.core.time.Instant.getEpochSecond:()J
            putfield org.apache.logging.log4j.core.time.MutableInstant.epochSecond:J
         1: .line 70
            aload 0 /* this */
            aload 1 /* other */
            invokeinterface org.apache.logging.log4j.core.time.Instant.getNanoOfSecond:()I
            putfield org.apache.logging.log4j.core.time.MutableInstant.nanoOfSecond:I
         2: .line 71
            return
        end local 1 // org.apache.logging.log4j.core.time.Instant other
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            0    3     1  other  Lorg/apache/logging/log4j/core/time/Instant;
    MethodParameters:
       Name  Flags
      other  final

  public void initFromEpochMilli(long, int);
    descriptor: (JI)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=3
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
        start local 1 // long epochMilli
        start local 3 // int nanoOfMillisecond
         0: .line 79
            aload 0 /* this */
            iload 3 /* nanoOfMillisecond */
            invokevirtual org.apache.logging.log4j.core.time.MutableInstant.validateNanoOfMillisecond:(I)V
         1: .line 80
            aload 0 /* this */
            lload 1 /* epochMilli */
            ldc 1000
            ldiv
            putfield org.apache.logging.log4j.core.time.MutableInstant.epochSecond:J
         2: .line 81
            aload 0 /* this */
            lload 1 /* epochMilli */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.epochSecond:J
            ldc 1000
            lmul
            lsub
            l2i
            ldc 1000000
            imul
            iload 3 /* nanoOfMillisecond */
            iadd
            putfield org.apache.logging.log4j.core.time.MutableInstant.nanoOfSecond:I
         3: .line 82
            return
        end local 3 // int nanoOfMillisecond
        end local 1 // long epochMilli
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    4     0               this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            0    4     1         epochMilli  J
            0    4     3  nanoOfMillisecond  I
    MethodParameters:
                   Name  Flags
      epochMilli         final
      nanoOfMillisecond  final

  private void validateNanoOfMillisecond(int);
    descriptor: (I)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
        start local 1 // int nanoOfMillisecond
         0: .line 85
            iload 1 /* nanoOfMillisecond */
            iflt 1
            iload 1 /* nanoOfMillisecond */
            ldc 1000000
            if_icmplt 2
         1: .line 86
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Invalid nanoOfMillisecond "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 1 /* nanoOfMillisecond */
            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
         2: .line 88
      StackMap locals:
      StackMap stack:
            return
        end local 1 // int nanoOfMillisecond
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    3     0               this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            0    3     1  nanoOfMillisecond  I
    MethodParameters:
                   Name  Flags
      nanoOfMillisecond  final

  public void initFrom(org.apache.logging.log4j.core.util.Clock);
    descriptor: (Lorg/apache/logging/log4j/core/util/Clock;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
        start local 1 // org.apache.logging.log4j.core.util.Clock clock
         0: .line 91
            aload 1 /* clock */
            instanceof org.apache.logging.log4j.core.time.PreciseClock
            ifeq 3
         1: .line 92
            aload 1 /* clock */
            checkcast org.apache.logging.log4j.core.time.PreciseClock
            aload 0 /* this */
            invokeinterface org.apache.logging.log4j.core.time.PreciseClock.init:(Lorg/apache/logging/log4j/core/time/MutableInstant;)V
         2: .line 93
            goto 4
         3: .line 94
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* clock */
            invokeinterface org.apache.logging.log4j.core.util.Clock.currentTimeMillis:()J
            iconst_0
            invokevirtual org.apache.logging.log4j.core.time.MutableInstant.initFromEpochMilli:(JI)V
         4: .line 96
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.logging.log4j.core.util.Clock clock
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            0    5     1  clock  Lorg/apache/logging/log4j/core/util/Clock;
    MethodParameters:
       Name  Flags
      clock  final

  public void initFromEpochSecond(long, int);
    descriptor: (JI)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
        start local 1 // long epochSecond
        start local 3 // int nano
         0: .line 104
            aload 0 /* this */
            iload 3 /* nano */
            invokevirtual org.apache.logging.log4j.core.time.MutableInstant.validateNanoOfSecond:(I)V
         1: .line 105
            aload 0 /* this */
            lload 1 /* epochSecond */
            putfield org.apache.logging.log4j.core.time.MutableInstant.epochSecond:J
         2: .line 106
            aload 0 /* this */
            iload 3 /* nano */
            putfield org.apache.logging.log4j.core.time.MutableInstant.nanoOfSecond:I
         3: .line 107
            return
        end local 3 // int nano
        end local 1 // long epochSecond
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    4     0         this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            0    4     1  epochSecond  J
            0    4     3         nano  I
    MethodParameters:
             Name  Flags
      epochSecond  final
      nano         final

  private void validateNanoOfSecond(int);
    descriptor: (I)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
        start local 1 // int nano
         0: .line 110
            iload 1 /* nano */
            iflt 1
            iload 1 /* nano */
            ldc 1000000000
            if_icmplt 2
         1: .line 111
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Invalid nanoOfSecond "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 1 /* nano */
            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
         2: .line 113
      StackMap locals:
      StackMap stack:
            return
        end local 1 // int nano
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            0    3     1  nano  I
    MethodParameters:
      Name  Flags
      nano  final

  public static void instantToMillisAndNanos(long, int, long[]);
    descriptor: (JI[J)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=6, locals=5, args_size=3
        start local 0 // long epochSecond
        start local 2 // int nano
        start local 3 // long[] result
         0: .line 124
            iload 2 /* nano */
            ldc 1000000
            idiv
            istore 4 /* millis */
        start local 4 // int millis
         1: .line 125
            aload 3 /* result */
            iconst_0
            lload 0 /* epochSecond */
            ldc 1000
            lmul
            iload 4 /* millis */
            i2l
            ladd
            lastore
         2: .line 126
            aload 3 /* result */
            iconst_1
            iload 2 /* nano */
            iload 4 /* millis */
            ldc 1000000
            imul
            isub
            i2l
            lastore
         3: .line 127
            return
        end local 4 // int millis
        end local 3 // long[] result
        end local 2 // int nano
        end local 0 // long epochSecond
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    4     0  epochSecond  J
            0    4     2         nano  I
            0    4     3       result  [J
            1    4     4       millis  I
    MethodParameters:
             Name  Flags
      epochSecond  final
      nano         final
      result       final

  public boolean equals(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
        start local 1 // java.lang.Object object
         0: .line 131
            aload 1 /* object */
            aload 0 /* this */
            if_acmpne 2
         1: .line 132
            iconst_1
            ireturn
         2: .line 134
      StackMap locals:
      StackMap stack:
            aload 1 /* object */
            instanceof org.apache.logging.log4j.core.time.MutableInstant
            ifne 4
         3: .line 135
            iconst_0
            ireturn
         4: .line 137
      StackMap locals:
      StackMap stack:
            aload 1 /* object */
            checkcast org.apache.logging.log4j.core.time.MutableInstant
            astore 2 /* other */
        start local 2 // org.apache.logging.log4j.core.time.MutableInstant other
         5: .line 138
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.epochSecond:J
            aload 2 /* other */
            getfield org.apache.logging.log4j.core.time.MutableInstant.epochSecond:J
            lcmp
            ifne 6
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.nanoOfSecond:I
            aload 2 /* other */
            getfield org.apache.logging.log4j.core.time.MutableInstant.nanoOfSecond:I
            if_icmpne 6
            iconst_1
            ireturn
      StackMap locals: org.apache.logging.log4j.core.time.MutableInstant
      StackMap stack:
         6: iconst_0
            ireturn
        end local 2 // org.apache.logging.log4j.core.time.MutableInstant other
        end local 1 // java.lang.Object object
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    7     0    this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            0    7     1  object  Ljava/lang/Object;
            5    7     2   other  Lorg/apache/logging/log4j/core/time/MutableInstant;
    MethodParameters:
        Name  Flags
      object  final

  public int hashCode();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=2, args_size=1
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
         0: .line 143
            bipush 17
            istore 1 /* result */
        start local 1 // int result
         1: .line 144
            bipush 31
            iload 1 /* result */
            imul
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.epochSecond:J
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.epochSecond:J
            bipush 32
            lushr
            lxor
            l2i
            iadd
            istore 1 /* result */
         2: .line 145
            bipush 31
            iload 1 /* result */
            imul
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.nanoOfSecond:I
            iadd
            istore 1 /* result */
         3: .line 146
            iload 1 /* result */
            ireturn
        end local 1 // int result
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            1    4     1  result  I

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
         0: .line 151
            new java.lang.StringBuilder
            dup
            bipush 64
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuilder sb
         1: .line 152
            aload 0 /* this */
            aload 1 /* sb */
            invokevirtual org.apache.logging.log4j.core.time.MutableInstant.formatTo:(Ljava/lang/StringBuilder;)V
         2: .line 153
            aload 1 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuilder sb
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            1    3     1    sb  Ljava/lang/StringBuilder;

  public void formatTo(java.lang.StringBuilder);
    descriptor: (Ljava/lang/StringBuilder;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.time.MutableInstant this
        start local 1 // java.lang.StringBuilder buffer
         0: .line 158
            aload 1 /* buffer */
            ldc "MutableInstant[epochSecond="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.epochSecond:J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            ldc ", nano="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.time.MutableInstant.nanoOfSecond:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         1: .line 159
            return
        end local 1 // java.lang.StringBuilder buffer
        end local 0 // org.apache.logging.log4j.core.time.MutableInstant this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/apache/logging/log4j/core/time/MutableInstant;
            0    2     1  buffer  Ljava/lang/StringBuilder;
    MethodParameters:
        Name  Flags
      buffer  final
}
SourceFile: "MutableInstant.java"
    RuntimeInvisibleAnnotations: 
      org.apache.logging.log4j.util.PerformanceSensitive(value = {"allocation"})