public abstract class org.aspectj.weaver.tools.AbstractTrace implements org.aspectj.weaver.tools.Trace
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: org.aspectj.weaver.tools.AbstractTrace
  super_class: java.lang.Object
{
  private static final java.util.regex.Pattern packagePrefixPattern;
    descriptor: Ljava/util/regex/Pattern;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  protected java.lang.Class<?> tracedClass;
    descriptor: Ljava/lang/Class;
    flags: (0x0004) ACC_PROTECTED
    Signature: Ljava/lang/Class<*>;

  private static java.text.SimpleDateFormat timeFormat;
    descriptor: Ljava/text/SimpleDateFormat;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 25
            ldc "([^.])[^.]*(\\.)"
            invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
            putstatic org.aspectj.weaver.tools.AbstractTrace.packagePrefixPattern:Ljava/util/regex/Pattern;
         1: .line 29
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  protected void <init>(java.lang.Class);
    descriptor: (Ljava/lang/Class;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.Class clazz
         0: .line 31
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 32
            aload 0 /* this */
            aload 1 /* clazz */
            putfield org.aspectj.weaver.tools.AbstractTrace.tracedClass:Ljava/lang/Class;
         2: .line 33
            return
        end local 1 // java.lang.Class clazz
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    3     1  clazz  Ljava/lang/Class;
    MethodParameters:
       Name  Flags
      clazz  

  public abstract void enter(java.lang.String, java.lang.Object, java.lang.Object[]);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;[Ljava/lang/Object;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
            Name  Flags
      methodName  
      thiz        
      args        

  public abstract void enter(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
            Name  Flags
      methodName  
      thiz        

  public abstract void exit(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
            Name  Flags
      methodName  
      ret         

  public abstract void exit(java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
            Name  Flags
      methodName  
      th          

  public void enter(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String methodName
         0: .line 47
            aload 0 /* this */
            aload 1 /* methodName */
            aconst_null
            aconst_null
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.enter:(Ljava/lang/String;Ljava/lang/Object;[Ljava/lang/Object;)V
         1: .line 48
            return
        end local 1 // java.lang.String methodName
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    2     1  methodName  Ljava/lang/String;
    MethodParameters:
            Name  Flags
      methodName  

  public void enter(java.lang.String, java.lang.Object, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=4
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String methodName
        start local 2 // java.lang.Object thiz
        start local 3 // java.lang.Object arg
         0: .line 51
            aload 0 /* this */
            aload 1 /* methodName */
            aload 2 /* thiz */
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 3 /* arg */
            aastore
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.enter:(Ljava/lang/String;Ljava/lang/Object;[Ljava/lang/Object;)V
         1: .line 52
            return
        end local 3 // java.lang.Object arg
        end local 2 // java.lang.Object thiz
        end local 1 // java.lang.String methodName
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    2     1  methodName  Ljava/lang/String;
            0    2     2        thiz  Ljava/lang/Object;
            0    2     3         arg  Ljava/lang/Object;
    MethodParameters:
            Name  Flags
      methodName  
      thiz        
      arg         

  public void enter(java.lang.String, java.lang.Object, boolean);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=4
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String methodName
        start local 2 // java.lang.Object thiz
        start local 3 // boolean z
         0: .line 55
            aload 0 /* this */
            aload 1 /* methodName */
            aload 2 /* thiz */
            new java.lang.Boolean
            dup
            iload 3 /* z */
            invokespecial java.lang.Boolean.<init>:(Z)V
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.enter:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         1: .line 56
            return
        end local 3 // boolean z
        end local 2 // java.lang.Object thiz
        end local 1 // java.lang.String methodName
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    2     1  methodName  Ljava/lang/String;
            0    2     2        thiz  Ljava/lang/Object;
            0    2     3           z  Z
    MethodParameters:
            Name  Flags
      methodName  
      thiz        
      z           

  public void exit(java.lang.String, boolean);
    descriptor: (Ljava/lang/String;Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String methodName
        start local 2 // boolean b
         0: .line 59
            aload 0 /* this */
            aload 1 /* methodName */
            new java.lang.Boolean
            dup
            iload 2 /* b */
            invokespecial java.lang.Boolean.<init>:(Z)V
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.exit:(Ljava/lang/String;Ljava/lang/Object;)V
         1: .line 60
            return
        end local 2 // boolean b
        end local 1 // java.lang.String methodName
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    2     1  methodName  Ljava/lang/String;
            0    2     2           b  Z
    MethodParameters:
            Name  Flags
      methodName  
      b           

  public void exit(java.lang.String, int);
    descriptor: (Ljava/lang/String;I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String methodName
        start local 2 // int i
         0: .line 63
            aload 0 /* this */
            aload 1 /* methodName */
            new java.lang.Integer
            dup
            iload 2 /* i */
            invokespecial java.lang.Integer.<init>:(I)V
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.exit:(Ljava/lang/String;Ljava/lang/Object;)V
         1: .line 64
            return
        end local 2 // int i
        end local 1 // java.lang.String methodName
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    2     1  methodName  Ljava/lang/String;
            0    2     2           i  I
    MethodParameters:
            Name  Flags
      methodName  
      i           

  public void event(java.lang.String, java.lang.Object, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=4
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String methodName
        start local 2 // java.lang.Object thiz
        start local 3 // java.lang.Object arg
         0: .line 67
            aload 0 /* this */
            aload 1 /* methodName */
            aload 2 /* thiz */
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 3 /* arg */
            aastore
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.event:(Ljava/lang/String;Ljava/lang/Object;[Ljava/lang/Object;)V
         1: .line 68
            return
        end local 3 // java.lang.Object arg
        end local 2 // java.lang.Object thiz
        end local 1 // java.lang.String methodName
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    2     1  methodName  Ljava/lang/String;
            0    2     2        thiz  Ljava/lang/Object;
            0    2     3         arg  Ljava/lang/Object;
    MethodParameters:
            Name  Flags
      methodName  
      thiz        
      arg         

  public void warn(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String message
         0: .line 71
            aload 0 /* this */
            aload 1 /* message */
            aconst_null
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.warn:(Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 72
            return
        end local 1 // java.lang.String message
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    2     1  message  Ljava/lang/String;
    MethodParameters:
         Name  Flags
      message  

  public void error(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String message
         0: .line 75
            aload 0 /* this */
            aload 1 /* message */
            aconst_null
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 76
            return
        end local 1 // java.lang.String message
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    2     1  message  Ljava/lang/String;
    MethodParameters:
         Name  Flags
      message  

  public void fatal(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String message
         0: .line 79
            aload 0 /* this */
            aload 1 /* message */
            aconst_null
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.fatal:(Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 80
            return
        end local 1 // java.lang.String message
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    2     1  message  Ljava/lang/String;
    MethodParameters:
         Name  Flags
      message  

  protected java.lang.String formatMessage(java.lang.String, java.lang.String, java.lang.String, java.lang.Object, java.lang.Object[]);
    descriptor: (Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=8, args_size=6
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String kind
        start local 2 // java.lang.String className
        start local 3 // java.lang.String methodName
        start local 4 // java.lang.Object thiz
        start local 5 // java.lang.Object[] args
         0: .line 86
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 6 /* message */
        start local 6 // java.lang.StringBuffer message
         1: .line 87
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            astore 7 /* now */
        start local 7 // java.util.Date now
         2: .line 88
            aload 6 /* message */
            aload 7 /* now */
            invokestatic org.aspectj.weaver.tools.AbstractTrace.formatDate:(Ljava/util/Date;)Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            ldc " "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         3: .line 89
            aload 6 /* message */
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            ldc " "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         4: .line 90
            aload 6 /* message */
            aload 1 /* kind */
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            ldc " "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         5: .line 91
            aload 6 /* message */
            aload 0 /* this */
            aload 2 /* className */
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.formatClassName:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         6: .line 92
            aload 6 /* message */
            ldc "."
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 3 /* methodName */
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         7: .line 93
            aload 4 /* thiz */
            ifnull 8
            aload 6 /* message */
            ldc " "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            aload 4 /* thiz */
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.formatObj:(Ljava/lang/Object;)Ljava/lang/Object;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/Object;)Ljava/lang/StringBuffer;
            pop
         8: .line 94
      StackMap locals: java.lang.StringBuffer java.util.Date
      StackMap stack:
            aload 5 /* args */
            ifnull 9
            aload 6 /* message */
            ldc " "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            aload 5 /* args */
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.formatArgs:([Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         9: .line 95
      StackMap locals:
      StackMap stack:
            aload 6 /* message */
            invokevirtual java.lang.StringBuffer.toString:()Ljava/lang/String;
            areturn
        end local 7 // java.util.Date now
        end local 6 // java.lang.StringBuffer message
        end local 5 // java.lang.Object[] args
        end local 4 // java.lang.Object thiz
        end local 3 // java.lang.String methodName
        end local 2 // java.lang.String className
        end local 1 // java.lang.String kind
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   10     0        this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0   10     1        kind  Ljava/lang/String;
            0   10     2   className  Ljava/lang/String;
            0   10     3  methodName  Ljava/lang/String;
            0   10     4        thiz  Ljava/lang/Object;
            0   10     5        args  [Ljava/lang/Object;
            1   10     6     message  Ljava/lang/StringBuffer;
            2   10     7         now  Ljava/util/Date;
    MethodParameters:
            Name  Flags
      kind        
      className   
      methodName  
      thiz        
      args        

  private java.lang.String formatClassName(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String className
         0: .line 103
            getstatic org.aspectj.weaver.tools.AbstractTrace.packagePrefixPattern:Ljava/util/regex/Pattern;
            aload 1 /* className */
            invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
            ldc "$1."
            invokevirtual java.util.regex.Matcher.replaceAll:(Ljava/lang/String;)Ljava/lang/String;
            areturn
        end local 1 // java.lang.String className
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0       this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    1     1  className  Ljava/lang/String;
    MethodParameters:
           Name  Flags
      className  

  protected java.lang.String formatMessage(java.lang.String, java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=6, args_size=4
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.String kind
        start local 2 // java.lang.String text
        start local 3 // java.lang.Throwable th
         0: .line 107
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 4 /* message */
        start local 4 // java.lang.StringBuffer message
         1: .line 108
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            astore 5 /* now */
        start local 5 // java.util.Date now
         2: .line 109
            aload 4 /* message */
            aload 5 /* now */
            invokestatic org.aspectj.weaver.tools.AbstractTrace.formatDate:(Ljava/util/Date;)Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            ldc " "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         3: .line 110
            aload 4 /* message */
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            ldc " "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         4: .line 111
            aload 4 /* message */
            aload 1 /* kind */
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            ldc " "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         5: .line 112
            aload 4 /* message */
            aload 2 /* text */
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         6: .line 113
            aload 3 /* th */
            ifnull 7
            aload 4 /* message */
            ldc " "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            aload 3 /* th */
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.formatObj:(Ljava/lang/Object;)Ljava/lang/Object;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/Object;)Ljava/lang/StringBuffer;
            pop
         7: .line 114
      StackMap locals: java.lang.StringBuffer java.util.Date
      StackMap stack:
            aload 4 /* message */
            invokevirtual java.lang.StringBuffer.toString:()Ljava/lang/String;
            areturn
        end local 5 // java.util.Date now
        end local 4 // java.lang.StringBuffer message
        end local 3 // java.lang.Throwable th
        end local 2 // java.lang.String text
        end local 1 // java.lang.String kind
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0     this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    8     1     kind  Ljava/lang/String;
            0    8     2     text  Ljava/lang/String;
            0    8     3       th  Ljava/lang/Throwable;
            1    8     4  message  Ljava/lang/StringBuffer;
            2    8     5      now  Ljava/util/Date;
    MethodParameters:
      Name  Flags
      kind  
      text  
      th    

  private static java.lang.String formatDate(java.util.Date);
    descriptor: (Ljava/util/Date;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // java.util.Date date
         0: .line 118
            getstatic org.aspectj.weaver.tools.AbstractTrace.timeFormat:Ljava/text/SimpleDateFormat;
            ifnonnull 2
         1: .line 119
            new java.text.SimpleDateFormat
            dup
            ldc "HH:mm:ss.SSS"
            invokespecial java.text.SimpleDateFormat.<init>:(Ljava/lang/String;)V
            putstatic org.aspectj.weaver.tools.AbstractTrace.timeFormat:Ljava/text/SimpleDateFormat;
         2: .line 122
      StackMap locals:
      StackMap stack:
            getstatic org.aspectj.weaver.tools.AbstractTrace.timeFormat:Ljava/text/SimpleDateFormat;
            aload 0 /* date */
            invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
            areturn
        end local 0 // java.util.Date date
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  date  Ljava/util/Date;
    MethodParameters:
      Name  Flags
      date  

  protected java.lang.Object formatObj(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.Object obj
         0: .line 135
            aload 1 /* obj */
            ifnull 11
         1: .line 136
            aload 1 /* obj */
            instanceof java.lang.String
            ifne 11
         2: .line 137
            aload 1 /* obj */
            instanceof java.lang.Number
            ifne 11
         3: .line 138
            aload 1 /* obj */
            instanceof java.lang.Boolean
            ifne 11
         4: .line 139
            aload 1 /* obj */
            instanceof java.lang.Exception
            ifne 11
         5: .line 140
            aload 1 /* obj */
            instanceof java.lang.Character
            ifne 11
         6: .line 141
            aload 1 /* obj */
            instanceof java.lang.Class
            ifne 11
         7: .line 142
            aload 1 /* obj */
            instanceof java.io.File
            ifne 11
         8: .line 143
            aload 1 /* obj */
            instanceof java.lang.StringBuffer
            ifne 11
         9: .line 144
            aload 1 /* obj */
            instanceof java.net.URL
            ifne 11
        10: .line 145
            aload 1 /* obj */
            instanceof org.aspectj.bridge.IMessage$Kind
            ifeq 12
        11: .line 146
      StackMap locals:
      StackMap stack:
            aload 1 /* obj */
            areturn
        12: .line 147
      StackMap locals:
      StackMap stack:
            aload 1 /* obj */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.isArray:()Z
            ifeq 14
        13: .line 148
            aload 0 /* this */
            aload 1 /* obj */
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.formatArray:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        14: .line 150
      StackMap locals:
      StackMap stack:
            aload 1 /* obj */
            instanceof java.util.Collection
            ifeq 16
        15: .line 151
            aload 0 /* this */
            aload 1 /* obj */
            checkcast java.util.Collection
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.formatCollection:(Ljava/util/Collection;)Ljava/lang/String;
            areturn
        16: .line 156
      StackMap locals:
      StackMap stack:
            aload 1 /* obj */
            instanceof org.aspectj.weaver.tools.Traceable
            ifeq 19
        17: .line 157
            aload 1 /* obj */
            checkcast org.aspectj.weaver.tools.Traceable
            invokeinterface org.aspectj.weaver.tools.Traceable.toTraceString:()Ljava/lang/String;
        18: areturn
        19: .line 161
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            aload 1 /* obj */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.formatClassName:(Ljava/lang/String;)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;
            aload 1 /* obj */
            invokestatic java.lang.System.identityHashCode:(Ljava/lang/Object;)I
            invokestatic java.lang.Integer.toHexString:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        20: areturn
        21: .line 164
      StackMap locals:
      StackMap stack: java.lang.Exception
            pop
        22: .line 165
            new java.lang.StringBuilder
            dup
            aload 1 /* obj */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "@FFFFFFFF"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.Object obj
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   23     0  this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0   23     1   obj  Ljava/lang/Object;
      Exception table:
        from    to  target  type
          16    18      21  Class java.lang.Exception
          19    20      21  Class java.lang.Exception
    MethodParameters:
      Name  Flags
      obj   

  protected java.lang.String formatArray(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.Object obj
         0: .line 170
            new java.lang.StringBuilder
            dup
            aload 1 /* obj */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getComponentType:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()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;
            aload 1 /* obj */
            invokestatic java.lang.reflect.Array.getLength:(Ljava/lang/Object;)I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.Object obj
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    1     1   obj  Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      obj   

  protected java.lang.String formatCollection(java.util.Collection<?>);
    descriptor: (Ljava/util/Collection;)Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.util.Collection c
         0: .line 174
            new java.lang.StringBuilder
            dup
            aload 1 /* c */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()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;
            aload 1 /* c */
            invokeinterface java.util.Collection.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.util.Collection c
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    1     1     c  Ljava/util/Collection<*>;
    Signature: (Ljava/util/Collection<*>;)Ljava/lang/String;
    MethodParameters:
      Name  Flags
      c     

  protected java.lang.String formatArgs(java.lang.Object[]);
    descriptor: ([Ljava/lang/Object;)Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.Object[] args
         0: .line 185
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 2 /* sb */
        start local 2 // java.lang.StringBuffer sb
         1: .line 187
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         2: goto 6
         3: .line 188
      StackMap locals: java.lang.StringBuffer int
      StackMap stack:
            aload 2 /* sb */
            aload 0 /* this */
            aload 1 /* args */
            iload 3 /* i */
            aaload
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.formatObj:(Ljava/lang/Object;)Ljava/lang/Object;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/Object;)Ljava/lang/StringBuffer;
            pop
         4: .line 189
            iload 3 /* i */
            aload 1 /* args */
            arraylength
            iconst_1
            isub
            if_icmpge 5
            aload 2 /* sb */
            ldc ", "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         5: .line 187
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
         6: iload 3 /* i */
            aload 1 /* args */
            arraylength
            if_icmplt 3
        end local 3 // int i
         7: .line 192
            aload 2 /* sb */
            invokevirtual java.lang.StringBuffer.toString:()Ljava/lang/String;
            areturn
        end local 2 // java.lang.StringBuffer sb
        end local 1 // java.lang.Object[] args
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    8     1  args  [Ljava/lang/Object;
            1    8     2    sb  Ljava/lang/StringBuffer;
            2    7     3     i  I
    MethodParameters:
      Name  Flags
      args  

  protected java.lang.Object[] formatObjects(java.lang.Object[]);
    descriptor: ([Ljava/lang/Object;)[Ljava/lang/Object;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // org.aspectj.weaver.tools.AbstractTrace this
        start local 1 // java.lang.Object[] args
         0: .line 196
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         1: goto 4
         2: .line 197
      StackMap locals: int
      StackMap stack:
            aload 1 /* args */
            iload 2 /* i */
            aload 0 /* this */
            aload 1 /* args */
            iload 2 /* i */
            aaload
            invokevirtual org.aspectj.weaver.tools.AbstractTrace.formatObj:(Ljava/lang/Object;)Ljava/lang/Object;
            aastore
         3: .line 196
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         4: iload 2 /* i */
            aload 1 /* args */
            arraylength
            if_icmplt 2
        end local 2 // int i
         5: .line 200
            aload 1 /* args */
            areturn
        end local 1 // java.lang.Object[] args
        end local 0 // org.aspectj.weaver.tools.AbstractTrace this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/aspectj/weaver/tools/AbstractTrace;
            0    6     1  args  [Ljava/lang/Object;
            1    5     2     i  I
    MethodParameters:
      Name  Flags
      args  
}
SourceFile: "AbstractTrace.java"
InnerClasses:
  public final Kind = org.aspectj.bridge.IMessage$Kind of org.aspectj.bridge.IMessage