public class android.util.TimingLogger
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: android.util.TimingLogger
  super_class: java.lang.Object
{
  private java.lang.String mTag;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String mLabel;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

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

  java.util.ArrayList<java.lang.Long> mSplits;
    descriptor: Ljava/util/ArrayList;
    flags: (0x0000) 
    Signature: Ljava/util/ArrayList<Ljava/lang/Long;>;

  java.util.ArrayList<java.lang.String> mSplitLabels;
    descriptor: Ljava/util/ArrayList;
    flags: (0x0000) 
    Signature: Ljava/util/ArrayList<Ljava/lang/String;>;

  public void <init>(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // android.util.TimingLogger this
        start local 1 // java.lang.String tag
        start local 2 // java.lang.String label
         0: .line 76
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 77
            aload 0 /* this */
            aload 1 /* tag */
            aload 2 /* label */
            invokevirtual android.util.TimingLogger.reset:(Ljava/lang/String;Ljava/lang/String;)V
         2: .line 78
            return
        end local 2 // java.lang.String label
        end local 1 // java.lang.String tag
        end local 0 // android.util.TimingLogger this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Landroid/util/TimingLogger;
            0    3     1    tag  Ljava/lang/String;
            0    3     2  label  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      tag    
      label  

  public void reset(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // android.util.TimingLogger this
        start local 1 // java.lang.String tag
        start local 2 // java.lang.String label
         0: .line 89
            aload 0 /* this */
            aload 1 /* tag */
            putfield android.util.TimingLogger.mTag:Ljava/lang/String;
         1: .line 90
            aload 0 /* this */
            aload 2 /* label */
            putfield android.util.TimingLogger.mLabel:Ljava/lang/String;
         2: .line 91
            aload 0 /* this */
            invokevirtual android.util.TimingLogger.reset:()V
         3: .line 92
            return
        end local 2 // java.lang.String label
        end local 1 // java.lang.String tag
        end local 0 // android.util.TimingLogger this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Landroid/util/TimingLogger;
            0    4     1    tag  Ljava/lang/String;
            0    4     2  label  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      tag    
      label  

  public void reset();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // android.util.TimingLogger this
         0: .line 103
            aload 0 /* this */
            aload 0 /* this */
            getfield android.util.TimingLogger.mTag:Ljava/lang/String;
            iconst_2
            invokestatic android.util.Log.isLoggable:(Ljava/lang/String;I)Z
            ifeq 1
            iconst_0
            goto 2
      StackMap locals:
      StackMap stack: android.util.TimingLogger
         1: iconst_1
      StackMap locals: android.util.TimingLogger
      StackMap stack: android.util.TimingLogger int
         2: putfield android.util.TimingLogger.mDisabled:Z
         3: .line 104
            aload 0 /* this */
            getfield android.util.TimingLogger.mDisabled:Z
            ifeq 4
            return
         4: .line 105
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield android.util.TimingLogger.mSplits:Ljava/util/ArrayList;
            ifnonnull 8
         5: .line 106
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield android.util.TimingLogger.mSplits:Ljava/util/ArrayList;
         6: .line 107
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield android.util.TimingLogger.mSplitLabels:Ljava/util/ArrayList;
         7: .line 108
            goto 10
         8: .line 109
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield android.util.TimingLogger.mSplits:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.clear:()V
         9: .line 110
            aload 0 /* this */
            getfield android.util.TimingLogger.mSplitLabels:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.clear:()V
        10: .line 112
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            invokevirtual android.util.TimingLogger.addSplit:(Ljava/lang/String;)V
        11: .line 113
            return
        end local 0 // android.util.TimingLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Landroid/util/TimingLogger;

  public void addSplit(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // android.util.TimingLogger this
        start local 1 // java.lang.String splitLabel
         0: .line 123
            aload 0 /* this */
            getfield android.util.TimingLogger.mDisabled:Z
            ifeq 1
            return
         1: .line 124
      StackMap locals:
      StackMap stack:
            invokestatic android.os.SystemClock.elapsedRealtime:()J
            lstore 2 /* now */
        start local 2 // long now
         2: .line 125
            aload 0 /* this */
            getfield android.util.TimingLogger.mSplits:Ljava/util/ArrayList;
            lload 2 /* now */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
         3: .line 126
            aload 0 /* this */
            getfield android.util.TimingLogger.mSplitLabels:Ljava/util/ArrayList;
            aload 1 /* splitLabel */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
         4: .line 127
            return
        end local 2 // long now
        end local 1 // java.lang.String splitLabel
        end local 0 // android.util.TimingLogger this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    5     0        this  Landroid/util/TimingLogger;
            0    5     1  splitLabel  Ljava/lang/String;
            2    5     2         now  J
    MethodParameters:
            Name  Flags
      splitLabel  

  public void dumpToLog();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=9, args_size=1
        start local 0 // android.util.TimingLogger this
         0: .line 135
            aload 0 /* this */
            getfield android.util.TimingLogger.mDisabled:Z
            ifeq 1
            return
         1: .line 136
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield android.util.TimingLogger.mTag:Ljava/lang/String;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield android.util.TimingLogger.mLabel:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ": begin"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Log.d:(Ljava/lang/String;Ljava/lang/String;)I
            pop
         2: .line 137
            aload 0 /* this */
            getfield android.util.TimingLogger.mSplits:Ljava/util/ArrayList;
            iconst_0
            invokevirtual java.util.ArrayList.get:(I)Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            lstore 1 /* first */
        start local 1 // long first
         3: .line 138
            lload 1 /* first */
            lstore 3 /* now */
        start local 3 // long now
         4: .line 139
            iconst_1
            istore 5 /* i */
        start local 5 // int i
         5: goto 11
         6: .line 140
      StackMap locals: long long int
      StackMap stack:
            aload 0 /* this */
            getfield android.util.TimingLogger.mSplits:Ljava/util/ArrayList;
            iload 5 /* i */
            invokevirtual java.util.ArrayList.get:(I)Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            lstore 3 /* now */
         7: .line 141
            aload 0 /* this */
            getfield android.util.TimingLogger.mSplitLabels:Ljava/util/ArrayList;
            iload 5 /* i */
            invokevirtual java.util.ArrayList.get:(I)Ljava/lang/Object;
            checkcast java.lang.String
            astore 6 /* splitLabel */
        start local 6 // java.lang.String splitLabel
         8: .line 142
            aload 0 /* this */
            getfield android.util.TimingLogger.mSplits:Ljava/util/ArrayList;
            iload 5 /* i */
            iconst_1
            isub
            invokevirtual java.util.ArrayList.get:(I)Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            lstore 7 /* prev */
        start local 7 // long prev
         9: .line 144
            aload 0 /* this */
            getfield android.util.TimingLogger.mTag:Ljava/lang/String;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield android.util.TimingLogger.mLabel:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ":      "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            lload 3 /* now */
            lload 7 /* prev */
            lsub
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            ldc " ms, "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 6 /* splitLabel */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Log.d:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        end local 7 // long prev
        end local 6 // java.lang.String splitLabel
        10: .line 139
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
        11: iload 5 /* i */
            aload 0 /* this */
            getfield android.util.TimingLogger.mSplits:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.size:()I
            if_icmplt 6
        end local 5 // int i
        12: .line 146
            aload 0 /* this */
            getfield android.util.TimingLogger.mTag:Ljava/lang/String;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield android.util.TimingLogger.mLabel:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ": end, "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            lload 3 /* now */
            lload 1 /* first */
            lsub
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            ldc " ms"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic android.util.Log.d:(Ljava/lang/String;Ljava/lang/String;)I
            pop
        13: .line 147
            return
        end local 3 // long now
        end local 1 // long first
        end local 0 // android.util.TimingLogger this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   14     0        this  Landroid/util/TimingLogger;
            3   14     1       first  J
            4   14     3         now  J
            5   12     5           i  I
            8   10     6  splitLabel  Ljava/lang/String;
            9   10     7        prev  J
}
SourceFile: "TimingLogger.java"