public class org.jruby.runtime.backtrace.TraceType
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.jruby.runtime.backtrace.TraceType
  super_class: java.lang.Object
{
  private static final org.jruby.util.log.Logger LOG;
    descriptor: Lorg/jruby/util/log/Logger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final com.headius.backport9.stack.StackWalker WALKER;
    descriptor: Lcom/headius/backport9/stack/StackWalker;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String[] FULL_MESSAGE_KEYS;
    descriptor: [Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final org.jruby.runtime.backtrace.TraceType$Gather gather;
    descriptor: Lorg/jruby/runtime/backtrace/TraceType$Gather;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.jruby.runtime.backtrace.TraceType$Format format;
    descriptor: Lorg/jruby/runtime/backtrace/TraceType$Format;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private static final java.lang.String FIRST_COLOR;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "\u001B[0;31m"

  private static final java.lang.String KERNEL_COLOR;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "\u001B[0;36m"

  private static final java.lang.String EVAL_COLOR;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "\u001B[0;33m"

  private static final java.lang.String CLEAR_COLOR;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "\u001B[0m"

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 26
            ldc Lorg/jruby/runtime/backtrace/TraceType;
            invokestatic org.jruby.util.log.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/jruby/util/log/Logger;
            putstatic org.jruby.runtime.backtrace.TraceType.LOG:Lorg/jruby/util/log/Logger;
         1: .line 27
            getstatic org.jruby.runtime.ThreadContext.WALKER:Lcom/headius/backport9/stack/StackWalker;
            putstatic org.jruby.runtime.backtrace.TraceType.WALKER:Lcom/headius/backport9/stack/StackWalker;
         2: .line 28
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
            ldc "highlight"
            aastore
            dup
            iconst_1
            ldc "order"
            aastore
            putstatic org.jruby.runtime.backtrace.TraceType.FULL_MESSAGE_KEYS:[Ljava/lang/String;
         3: .line 416
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(org.jruby.runtime.backtrace.TraceType$Gather, org.jruby.runtime.backtrace.TraceType$Format);
    descriptor: (Lorg/jruby/runtime/backtrace/TraceType$Gather;Lorg/jruby/runtime/backtrace/TraceType$Format;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.jruby.runtime.backtrace.TraceType this
        start local 1 // org.jruby.runtime.backtrace.TraceType$Gather gather
        start local 2 // org.jruby.runtime.backtrace.TraceType$Format format
         0: .line 33
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 34
            aload 0 /* this */
            aload 1 /* gather */
            putfield org.jruby.runtime.backtrace.TraceType.gather:Lorg/jruby/runtime/backtrace/TraceType$Gather;
         2: .line 35
            aload 0 /* this */
            aload 2 /* format */
            putfield org.jruby.runtime.backtrace.TraceType.format:Lorg/jruby/runtime/backtrace/TraceType$Format;
         3: .line 36
            return
        end local 2 // org.jruby.runtime.backtrace.TraceType$Format format
        end local 1 // org.jruby.runtime.backtrace.TraceType$Gather gather
        end local 0 // org.jruby.runtime.backtrace.TraceType this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lorg/jruby/runtime/backtrace/TraceType;
            0    4     1  gather  Lorg/jruby/runtime/backtrace/TraceType$Gather;
            0    4     2  format  Lorg/jruby/runtime/backtrace/TraceType$Format;
    MethodParameters:
        Name  Flags
      gather  
      format  

  public org.jruby.runtime.backtrace.TraceType$Gather getGather();
    descriptor: ()Lorg/jruby/runtime/backtrace/TraceType$Gather;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.jruby.runtime.backtrace.TraceType this
         0: .line 39
            aload 0 /* this */
            getfield org.jruby.runtime.backtrace.TraceType.gather:Lorg/jruby/runtime/backtrace/TraceType$Gather;
            areturn
        end local 0 // org.jruby.runtime.backtrace.TraceType this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/jruby/runtime/backtrace/TraceType;

  public org.jruby.runtime.backtrace.TraceType$Format getFormat();
    descriptor: ()Lorg/jruby/runtime/backtrace/TraceType$Format;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.jruby.runtime.backtrace.TraceType this
         0: .line 43
            aload 0 /* this */
            getfield org.jruby.runtime.backtrace.TraceType.format:Lorg/jruby/runtime/backtrace/TraceType$Format;
            areturn
        end local 0 // org.jruby.runtime.backtrace.TraceType this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/jruby/runtime/backtrace/TraceType;

  public org.jruby.runtime.backtrace.BacktraceData getBacktrace(org.jruby.runtime.ThreadContext);
    descriptor: (Lorg/jruby/runtime/ThreadContext;)Lorg/jruby/runtime/backtrace/BacktraceData;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.jruby.runtime.backtrace.TraceType this
        start local 1 // org.jruby.runtime.ThreadContext context
         0: .line 53
            aload 0 /* this */
            getfield org.jruby.runtime.backtrace.TraceType.gather:Lorg/jruby/runtime/backtrace/TraceType$Gather;
            aload 1 /* context */
            invokevirtual org.jruby.runtime.backtrace.TraceType$Gather.getBacktraceData:(Lorg/jruby/runtime/ThreadContext;)Lorg/jruby/runtime/backtrace/BacktraceData;
            areturn
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.backtrace.TraceType this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0     this  Lorg/jruby/runtime/backtrace/TraceType;
            0    1     1  context  Lorg/jruby/runtime/ThreadContext;
    MethodParameters:
         Name  Flags
      context  

  public org.jruby.runtime.backtrace.BacktraceData getIntegratedBacktrace(org.jruby.runtime.ThreadContext, java.lang.StackTraceElement[]);
    descriptor: (Lorg/jruby/runtime/ThreadContext;[Ljava/lang/StackTraceElement;)Lorg/jruby/runtime/backtrace/BacktraceData;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.jruby.runtime.backtrace.TraceType this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // java.lang.StackTraceElement[] javaTrace
         0: .line 64
            aload 0 /* this */
            getfield org.jruby.runtime.backtrace.TraceType.gather:Lorg/jruby/runtime/backtrace/TraceType$Gather;
            aload 1 /* context */
            aload 2 /* javaTrace */
            invokevirtual org.jruby.runtime.backtrace.TraceType$Gather.getIntegratedBacktraceData:(Lorg/jruby/runtime/ThreadContext;[Ljava/lang/StackTraceElement;)Lorg/jruby/runtime/backtrace/BacktraceData;
            areturn
        end local 2 // java.lang.StackTraceElement[] javaTrace
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.backtrace.TraceType this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0       this  Lorg/jruby/runtime/backtrace/TraceType;
            0    1     1    context  Lorg/jruby/runtime/ThreadContext;
            0    1     2  javaTrace  [Ljava/lang/StackTraceElement;
    MethodParameters:
           Name  Flags
      context    
      javaTrace  

  public java.lang.String printBacktrace(org.jruby.RubyException, boolean);
    descriptor: (Lorg/jruby/RubyException;Z)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.jruby.runtime.backtrace.TraceType this
        start local 1 // org.jruby.RubyException exception
        start local 2 // boolean console
         0: .line 68
            aload 0 /* this */
            getfield org.jruby.runtime.backtrace.TraceType.format:Lorg/jruby/runtime/backtrace/TraceType$Format;
            aload 1 /* exception */
            iload 2 /* console */
            invokevirtual org.jruby.runtime.backtrace.TraceType$Format.printBacktrace:(Lorg/jruby/RubyException;Z)Ljava/lang/String;
            areturn
        end local 2 // boolean console
        end local 1 // org.jruby.RubyException exception
        end local 0 // org.jruby.runtime.backtrace.TraceType this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0       this  Lorg/jruby/runtime/backtrace/TraceType;
            0    1     1  exception  Lorg/jruby/RubyException;
            0    1     2    console  Z
    MethodParameters:
           Name  Flags
      exception  
      console    

  public static void logBacktrace(org.jruby.Ruby, org.jruby.runtime.backtrace.RubyStackTraceElement[]);
    descriptor: (Lorg/jruby/Ruby;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // org.jruby.Ruby runtime
        start local 1 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
         0: .line 72
            aload 1 /* trace */
            ifnonnull 1
            getstatic org.jruby.runtime.backtrace.RubyStackTraceElement.EMPTY_ARRAY:[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            astore 1 /* trace */
         1: .line 74
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            bipush 64
            aload 1 /* trace */
            arraylength
            bipush 48
            imul
            iadd
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 2 /* buffer */
        start local 2 // java.lang.StringBuilder buffer
         2: .line 76
            aload 2 /* buffer */
            ldc "Backtrace generated:\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         3: .line 78
            aload 0 /* runtime */
            aload 1 /* trace */
            aload 2 /* buffer */
            iconst_0
            invokestatic org.jruby.runtime.backtrace.TraceType.renderBacktraceJRuby:(Lorg/jruby/Ruby;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/StringBuilder;Z)V
         4: .line 80
            getstatic org.jruby.runtime.backtrace.TraceType.LOG:Lorg/jruby/util/log/Logger;
            aload 2 /* buffer */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokeinterface org.jruby.util.log.Logger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
         5: .line 81
            return
        end local 2 // java.lang.StringBuilder buffer
        end local 1 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
        end local 0 // org.jruby.Ruby runtime
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0  runtime  Lorg/jruby/Ruby;
            0    6     1    trace  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            2    6     2   buffer  Ljava/lang/StringBuilder;
    MethodParameters:
         Name  Flags
      runtime  
      trace    

  public static void logException(org.jruby.RubyException);
    descriptor: (Lorg/jruby/RubyException;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=6, locals=1, args_size=1
        start local 0 // org.jruby.RubyException exception
         0: .line 84
            getstatic org.jruby.runtime.backtrace.TraceType.LOG:Lorg/jruby/util/log/Logger;
            ldc "Exception raised: {} : {}"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* exception */
            invokevirtual org.jruby.RubyException.getMetaClass:()Lorg/jruby/RubyClass;
            aastore
            dup
            iconst_1
            aload 0 /* exception */
            aastore
            invokeinterface org.jruby.util.log.Logger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 85
            return
        end local 0 // org.jruby.RubyException exception
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0  exception  Lorg/jruby/RubyException;
    MethodParameters:
           Name  Flags
      exception  

  public static void dumpException(org.jruby.RubyException);
    descriptor: (Lorg/jruby/RubyException;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.jruby.RubyException exception
         0: .line 91
            aload 0 /* exception */
            invokestatic org.jruby.runtime.backtrace.TraceType.logException:(Lorg/jruby/RubyException;)V
         1: .line 92
            return
        end local 0 // org.jruby.RubyException exception
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0  exception  Lorg/jruby/RubyException;
    MethodParameters:
           Name  Flags
      exception  

  public static void dumpBacktrace(org.jruby.RubyException);
    descriptor: (Lorg/jruby/RubyException;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // org.jruby.RubyException exception
         0: .line 95
            aload 0 /* exception */
            invokevirtual org.jruby.RubyException.getRuntime:()Lorg/jruby/Ruby;
            astore 1 /* runtime */
        start local 1 // org.jruby.Ruby runtime
         1: .line 96
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Backtrace generated:\n"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* exception */
            aload 1 /* runtime */
            invokevirtual org.jruby.Ruby.getPosix:()Ljnr/posix/POSIX;
            getstatic java.io.FileDescriptor.err:Ljava/io/FileDescriptor;
            invokeinterface jnr.posix.POSIX.isatty:(Ljava/io/FileDescriptor;)Z
            invokestatic org.jruby.runtime.backtrace.TraceType.printBacktraceJRuby:(Lorg/jruby/RubyException;Z)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 97
            return
        end local 1 // org.jruby.Ruby runtime
        end local 0 // org.jruby.RubyException exception
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  exception  Lorg/jruby/RubyException;
            1    3     1    runtime  Lorg/jruby/Ruby;
    MethodParameters:
           Name  Flags
      exception  

  public static void logCaller(org.jruby.RubyArray);
    descriptor: (Lorg/jruby/RubyArray;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=1
        start local 0 // org.jruby.RubyArray trace
         0: .line 100
            new java.lang.StringBuilder
            dup
            bipush 64
            aload 0 /* trace */
            invokevirtual org.jruby.RubyArray.size:()I
            bipush 48
            imul
            iadd
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 1 /* buffer */
        start local 1 // java.lang.StringBuilder buffer
         1: .line 102
            aload 1 /* buffer */
            ldc "Caller backtrace generated:\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         2: .line 104
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         3: goto 6
         4: .line 106
      StackMap locals: java.lang.StringBuilder int
      StackMap stack:
            aload 1 /* buffer */
            ldc "  "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* trace */
            iload 2 /* i */
            invokevirtual org.jruby.RubyArray.eltInternal:(I)Lorg/jruby/runtime/builtin/IRubyObject;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         5: .line 104
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         6: iload 2 /* i */
            aload 0 /* trace */
            invokevirtual org.jruby.RubyArray.size:()I
            if_icmplt 4
        end local 2 // int i
         7: .line 109
            getstatic org.jruby.runtime.backtrace.TraceType.LOG:Lorg/jruby/util/log/Logger;
            aload 1 /* buffer */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokeinterface org.jruby.util.log.Logger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
         8: .line 110
            return
        end local 1 // java.lang.StringBuilder buffer
        end local 0 // org.jruby.RubyArray trace
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0   trace  Lorg/jruby/RubyArray;
            1    9     1  buffer  Ljava/lang/StringBuilder;
            3    7     2       i  I
    MethodParameters:
       Name  Flags
      trace  

  public static void dumpCaller(org.jruby.RubyArray);
    descriptor: (Lorg/jruby/RubyArray;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.jruby.RubyArray trace
         0: .line 116
            aload 0 /* trace */
            invokestatic org.jruby.runtime.backtrace.TraceType.logCaller:(Lorg/jruby/RubyArray;)V
         1: .line 117
            return
        end local 0 // org.jruby.RubyArray trace
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0  trace  Lorg/jruby/RubyArray;
    MethodParameters:
       Name  Flags
      trace  

  public static void logCaller(org.jruby.runtime.backtrace.RubyStackTraceElement[]);
    descriptor: ([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
         0: .line 120
            aload 0 /* trace */
            ifnonnull 1
            getstatic org.jruby.runtime.backtrace.RubyStackTraceElement.EMPTY_ARRAY:[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            astore 0 /* trace */
         1: .line 122
      StackMap locals:
      StackMap stack:
            getstatic org.jruby.runtime.backtrace.TraceType.LOG:Lorg/jruby/util/log/Logger;
            ldc "Caller backtrace generated:\n"
            aload 0 /* trace */
            invokestatic org.jruby.runtime.backtrace.TraceType.formatWithMRIBacktrace:(Ljava/lang/String;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokeinterface org.jruby.util.log.Logger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
         2: .line 123
            return
        end local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0  trace  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
    MethodParameters:
       Name  Flags
      trace  

  private static java.lang.StringBuilder formatWithMRIBacktrace(java.lang.String, org.jruby.runtime.backtrace.RubyStackTraceElement[]);
    descriptor: (Ljava/lang/String;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)Ljava/lang/StringBuilder;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // java.lang.String message
        start local 1 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
         0: .line 126
            new java.lang.StringBuilder
            dup
            bipush 64
            aload 1 /* trace */
            arraylength
            bipush 48
            imul
            iadd
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 2 /* buffer */
        start local 2 // java.lang.StringBuilder buffer
         1: .line 128
            aload 2 /* buffer */
            aload 0 /* message */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         2: .line 130
            aload 1 /* trace */
            ldc "  "
            aload 2 /* buffer */
            iconst_0
            invokestatic org.jruby.runtime.backtrace.TraceType.renderBacktraceMRI:([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/String;Ljava/lang/StringBuilder;Z)V
         3: .line 132
            aload 2 /* buffer */
            areturn
        end local 2 // java.lang.StringBuilder buffer
        end local 1 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
        end local 0 // java.lang.String message
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    4     0  message  Ljava/lang/String;
            0    4     1    trace  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            1    4     2   buffer  Ljava/lang/StringBuilder;
    MethodParameters:
         Name  Flags
      message  final
      trace    

  public static void dumpCaller(org.jruby.runtime.backtrace.RubyStackTraceElement[]);
    descriptor: ([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
         0: .line 139
            aload 0 /* trace */
            invokestatic org.jruby.runtime.backtrace.TraceType.logCaller:([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)V
         1: .line 140
            return
        end local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0  trace  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
    MethodParameters:
       Name  Flags
      trace  

  public static void logWarning(org.jruby.runtime.backtrace.RubyStackTraceElement[]);
    descriptor: ([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
         0: .line 143
            aload 0 /* trace */
            ifnonnull 1
            getstatic org.jruby.runtime.backtrace.RubyStackTraceElement.EMPTY_ARRAY:[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            astore 0 /* trace */
         1: .line 145
      StackMap locals:
      StackMap stack:
            getstatic org.jruby.runtime.backtrace.TraceType.LOG:Lorg/jruby/util/log/Logger;
            ldc "Warning backtrace generated:\n"
            aload 0 /* trace */
            invokestatic org.jruby.runtime.backtrace.TraceType.formatWithMRIBacktrace:(Ljava/lang/String;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokeinterface org.jruby.util.log.Logger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
         2: .line 146
            return
        end local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0  trace  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
    MethodParameters:
       Name  Flags
      trace  

  public static void dumpWarning(org.jruby.runtime.backtrace.RubyStackTraceElement[]);
    descriptor: ([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
         0: .line 152
            aload 0 /* trace */
            invokestatic org.jruby.runtime.backtrace.TraceType.logWarning:([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)V
         1: .line 153
            return
        end local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0  trace  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
    MethodParameters:
       Name  Flags
      trace  

  public static org.jruby.runtime.backtrace.TraceType traceTypeFor(java.lang.String);
    descriptor: (Ljava/lang/String;)Lorg/jruby/runtime/backtrace/TraceType;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // java.lang.String style
         0: .line 156
            aload 0 /* style */
            ldc "raw"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 1
            new org.jruby.runtime.backtrace.TraceType
            dup
            getstatic org.jruby.runtime.backtrace.TraceType$Gather.RAW:Lorg/jruby/runtime/backtrace/TraceType$Gather;
            getstatic org.jruby.runtime.backtrace.TraceType$Format.JRUBY:Lorg/jruby/runtime/backtrace/TraceType$Format;
            invokespecial org.jruby.runtime.backtrace.TraceType.<init>:(Lorg/jruby/runtime/backtrace/TraceType$Gather;Lorg/jruby/runtime/backtrace/TraceType$Format;)V
            areturn
         1: .line 157
      StackMap locals:
      StackMap stack:
            aload 0 /* style */
            ldc "ruby_framed"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 2
            new org.jruby.runtime.backtrace.TraceType
            dup
            getstatic org.jruby.runtime.backtrace.TraceType$Gather.NORMAL:Lorg/jruby/runtime/backtrace/TraceType$Gather;
            getstatic org.jruby.runtime.backtrace.TraceType$Format.JRUBY:Lorg/jruby/runtime/backtrace/TraceType$Format;
            invokespecial org.jruby.runtime.backtrace.TraceType.<init>:(Lorg/jruby/runtime/backtrace/TraceType$Gather;Lorg/jruby/runtime/backtrace/TraceType$Format;)V
            areturn
         2: .line 158
      StackMap locals:
      StackMap stack:
            aload 0 /* style */
            ldc "normal"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 3
            new org.jruby.runtime.backtrace.TraceType
            dup
            getstatic org.jruby.runtime.backtrace.TraceType$Gather.NORMAL:Lorg/jruby/runtime/backtrace/TraceType$Gather;
            getstatic org.jruby.runtime.backtrace.TraceType$Format.JRUBY:Lorg/jruby/runtime/backtrace/TraceType$Format;
            invokespecial org.jruby.runtime.backtrace.TraceType.<init>:(Lorg/jruby/runtime/backtrace/TraceType$Gather;Lorg/jruby/runtime/backtrace/TraceType$Format;)V
            areturn
         3: .line 159
      StackMap locals:
      StackMap stack:
            aload 0 /* style */
            ldc "full"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 4
            new org.jruby.runtime.backtrace.TraceType
            dup
            getstatic org.jruby.runtime.backtrace.TraceType$Gather.FULL:Lorg/jruby/runtime/backtrace/TraceType$Gather;
            getstatic org.jruby.runtime.backtrace.TraceType$Format.JRUBY:Lorg/jruby/runtime/backtrace/TraceType$Format;
            invokespecial org.jruby.runtime.backtrace.TraceType.<init>:(Lorg/jruby/runtime/backtrace/TraceType$Gather;Lorg/jruby/runtime/backtrace/TraceType$Format;)V
            areturn
         4: .line 160
      StackMap locals:
      StackMap stack:
            aload 0 /* style */
            ldc "mri"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 5
            new org.jruby.runtime.backtrace.TraceType
            dup
            getstatic org.jruby.runtime.backtrace.TraceType$Gather.NORMAL:Lorg/jruby/runtime/backtrace/TraceType$Gather;
            getstatic org.jruby.runtime.backtrace.TraceType$Format.MRI:Lorg/jruby/runtime/backtrace/TraceType$Format;
            invokespecial org.jruby.runtime.backtrace.TraceType.<init>:(Lorg/jruby/runtime/backtrace/TraceType$Gather;Lorg/jruby/runtime/backtrace/TraceType$Format;)V
            areturn
         5: .line 161
      StackMap locals:
      StackMap stack:
            new org.jruby.runtime.backtrace.TraceType
            dup
            getstatic org.jruby.runtime.backtrace.TraceType$Gather.NORMAL:Lorg/jruby/runtime/backtrace/TraceType$Gather;
            getstatic org.jruby.runtime.backtrace.TraceType$Format.JRUBY:Lorg/jruby/runtime/backtrace/TraceType$Format;
            invokespecial org.jruby.runtime.backtrace.TraceType.<init>:(Lorg/jruby/runtime/backtrace/TraceType$Gather;Lorg/jruby/runtime/backtrace/TraceType$Format;)V
            areturn
        end local 0 // java.lang.String style
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    6     0  style  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      style  

  public static java.lang.String printFullMessage(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Ljava/lang/String;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=9, args_size=3
        start local 0 // org.jruby.runtime.ThreadContext context
        start local 1 // org.jruby.runtime.builtin.IRubyObject exception
        start local 2 // org.jruby.runtime.builtin.IRubyObject opts
         0: .line 311
            aload 0 /* context */
            getfield org.jruby.runtime.ThreadContext.runtime:Lorg/jruby/Ruby;
            astore 3 /* runtime */
        start local 3 // org.jruby.Ruby runtime
         1: .line 312
            aload 3 /* runtime */
            aload 2 /* opts */
            invokestatic org.jruby.ast.util.ArgsUtil.getOptionsArg:(Lorg/jruby/Ruby;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            astore 4 /* optArg */
        start local 4 // org.jruby.runtime.builtin.IRubyObject optArg
         2: .line 313
            iconst_0
            istore 5 /* highlight */
        start local 5 // boolean highlight
         3: .line 316
            aload 4 /* optArg */
            invokeinterface org.jruby.runtime.builtin.IRubyObject.isNil:()Z
            ifne 16
         4: .line 317
            aload 0 /* context */
            aload 4 /* optArg */
            checkcast org.jruby.RubyHash
            getstatic org.jruby.runtime.backtrace.TraceType.FULL_MESSAGE_KEYS:[Ljava/lang/String;
            invokestatic org.jruby.ast.util.ArgsUtil.extractKeywordArgs:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/RubyHash;[Ljava/lang/String;)[Lorg/jruby/runtime/builtin/IRubyObject;
            astore 6 /* highlightOrder */
        start local 6 // org.jruby.runtime.builtin.IRubyObject[] highlightOrder
         5: .line 319
            aload 6 /* highlightOrder */
            iconst_0
            aaload
            astore 7 /* vHigh */
        start local 7 // org.jruby.runtime.builtin.IRubyObject vHigh
         6: .line 320
            aload 7 /* vHigh */
            ifnonnull 7
            aload 0 /* context */
            getfield org.jruby.runtime.ThreadContext.nil:Lorg/jruby/runtime/builtin/IRubyObject;
            astore 7 /* vHigh */
         7: .line 321
      StackMap locals: org.jruby.runtime.ThreadContext org.jruby.runtime.builtin.IRubyObject org.jruby.runtime.builtin.IRubyObject org.jruby.Ruby org.jruby.runtime.builtin.IRubyObject int org.jruby.runtime.builtin.IRubyObject[] org.jruby.runtime.builtin.IRubyObject
      StackMap stack:
            aload 7 /* vHigh */
            aload 0 /* context */
            getfield org.jruby.runtime.ThreadContext.nil:Lorg/jruby/runtime/builtin/IRubyObject;
            if_acmpeq 9
            aload 7 /* vHigh */
            aload 0 /* context */
            getfield org.jruby.runtime.ThreadContext.fals:Lorg/jruby/RubyBoolean;
            if_acmpeq 9
            aload 7 /* vHigh */
            aload 0 /* context */
            getfield org.jruby.runtime.ThreadContext.tru:Lorg/jruby/RubyBoolean;
            if_acmpeq 9
         8: .line 322
            aload 3 /* runtime */
            new java.lang.StringBuilder
            dup
            ldc "expected true or false as highlight: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* vHigh */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.jruby.Ruby.newArgumentError:(Ljava/lang/String;)Lorg/jruby/exceptions/RaiseException;
            athrow
         9: .line 324
      StackMap locals:
      StackMap stack:
            aload 7 /* vHigh */
            invokeinterface org.jruby.runtime.builtin.IRubyObject.isTrue:()Z
            istore 5 /* highlight */
        10: .line 326
            aload 6 /* highlightOrder */
            iconst_1
            aaload
            astore 8 /* vOrder */
        start local 8 // org.jruby.runtime.builtin.IRubyObject vOrder
        11: .line 327
            aload 8 /* vOrder */
            ifnull 16
        12: .line 328
            aload 8 /* vOrder */
            invokestatic org.jruby.util.TypeConverter.checkID:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubySymbol;
            astore 8 /* vOrder */
        13: .line 329
            aload 8 /* vOrder */
            aload 3 /* runtime */
            ldc "bottom"
            invokevirtual org.jruby.Ruby.newSymbol:(Ljava/lang/String;)Lorg/jruby/RubySymbol;
            if_acmpne 14
            goto 16
        14: .line 330
      StackMap locals: org.jruby.runtime.builtin.IRubyObject
      StackMap stack:
            aload 8 /* vOrder */
            aload 3 /* runtime */
            ldc "top"
            invokevirtual org.jruby.Ruby.newSymbol:(Ljava/lang/String;)Lorg/jruby/RubySymbol;
            if_acmpne 15
            goto 16
        15: .line 332
      StackMap locals:
      StackMap stack:
            aload 3 /* runtime */
            new java.lang.StringBuilder
            dup
            ldc "expected :top or :bottom as order: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 8 /* vOrder */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.jruby.Ruby.newArgumentError:(Ljava/lang/String;)Lorg/jruby/exceptions/RaiseException;
            athrow
        end local 8 // org.jruby.runtime.builtin.IRubyObject vOrder
        end local 7 // org.jruby.runtime.builtin.IRubyObject vHigh
        end local 6 // org.jruby.runtime.builtin.IRubyObject[] highlightOrder
        16: .line 338
      StackMap locals:
      StackMap stack:
            aload 1 /* exception */
            iload 5 /* highlight */
            invokestatic org.jruby.runtime.backtrace.TraceType.printBacktraceMRI:(Lorg/jruby/runtime/builtin/IRubyObject;Z)Ljava/lang/String;
            areturn
        end local 5 // boolean highlight
        end local 4 // org.jruby.runtime.builtin.IRubyObject optArg
        end local 3 // org.jruby.Ruby runtime
        end local 2 // org.jruby.runtime.builtin.IRubyObject opts
        end local 1 // org.jruby.runtime.builtin.IRubyObject exception
        end local 0 // org.jruby.runtime.ThreadContext context
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   17     0         context  Lorg/jruby/runtime/ThreadContext;
            0   17     1       exception  Lorg/jruby/runtime/builtin/IRubyObject;
            0   17     2            opts  Lorg/jruby/runtime/builtin/IRubyObject;
            1   17     3         runtime  Lorg/jruby/Ruby;
            2   17     4          optArg  Lorg/jruby/runtime/builtin/IRubyObject;
            3   17     5       highlight  Z
            5   16     6  highlightOrder  [Lorg/jruby/runtime/builtin/IRubyObject;
            6   16     7           vHigh  Lorg/jruby/runtime/builtin/IRubyObject;
           11   16     8          vOrder  Lorg/jruby/runtime/builtin/IRubyObject;
    MethodParameters:
           Name  Flags
      context    
      exception  
      opts       

  private static java.lang.String printBacktraceMRI(org.jruby.runtime.builtin.IRubyObject, boolean);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Z)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=13, args_size=2
        start local 0 // org.jruby.runtime.builtin.IRubyObject exception
        start local 1 // boolean console
         0: .line 342
            aload 0 /* exception */
            invokeinterface org.jruby.runtime.builtin.IRubyObject.getRuntime:()Lorg/jruby/Ruby;
            astore 2 /* runtime */
        start local 2 // org.jruby.Ruby runtime
         1: .line 343
            aload 2 /* runtime */
            invokevirtual org.jruby.Ruby.getCurrentContext:()Lorg/jruby/runtime/ThreadContext;
            astore 3 /* context */
        start local 3 // org.jruby.runtime.ThreadContext context
         2: .line 345
            aload 0 /* exception */
            aload 3 /* context */
            ldc "backtrace"
            invokeinterface org.jruby.runtime.builtin.IRubyObject.callMethod:(Lorg/jruby/runtime/ThreadContext;Ljava/lang/String;)Lorg/jruby/runtime/builtin/IRubyObject;
            astore 4 /* backtrace */
        start local 4 // org.jruby.runtime.builtin.IRubyObject backtrace
         3: .line 347
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 5 /* baos */
        start local 5 // java.io.ByteArrayOutputStream baos
         4: .line 348
            new java.io.PrintStream
            dup
            aload 5 /* baos */
            invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
            astore 6 /* errorStream */
        start local 6 // java.io.PrintStream errorStream
         5: .line 349
            iconst_0
            istore 7 /* printedPosition */
        start local 7 // boolean printedPosition
         6: .line 350
            aload 4 /* backtrace */
            invokeinterface org.jruby.runtime.builtin.IRubyObject.isNil:()Z
            ifne 7
            aload 4 /* backtrace */
            instanceof org.jruby.RubyArray
            ifne 14
         7: .line 351
      StackMap locals: org.jruby.runtime.builtin.IRubyObject int org.jruby.Ruby org.jruby.runtime.ThreadContext org.jruby.runtime.builtin.IRubyObject java.io.ByteArrayOutputStream java.io.PrintStream int
      StackMap stack:
            aload 3 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
            ifnull 11
            aload 3 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            ifle 11
         8: .line 352
            aload 6 /* errorStream */
            new java.lang.StringBuilder
            dup
            aload 3 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            aload 3 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
         9: .line 353
            iconst_1
            istore 7 /* printedPosition */
        10: .line 354
            goto 23
        11: .line 355
      StackMap locals:
      StackMap stack:
            aload 6 /* errorStream */
            aload 3 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
            invokevirtual java.io.PrintStream.print:(I)V
        12: .line 356
            iconst_1
            istore 7 /* printedPosition */
        13: .line 358
            goto 23
      StackMap locals:
      StackMap stack:
        14: aload 4 /* backtrace */
            checkcast org.jruby.RubyArray
            invokevirtual org.jruby.RubyArray.getLength:()I
            ifne 17
        15: .line 359
            aload 3 /* context */
            aload 6 /* errorStream */
            invokestatic org.jruby.runtime.backtrace.TraceType.printErrorPos:(Lorg/jruby/runtime/ThreadContext;Ljava/io/PrintStream;)V
        16: .line 360
            goto 23
        17: .line 361
      StackMap locals:
      StackMap stack:
            aload 4 /* backtrace */
            checkcast org.jruby.RubyArray
            invokevirtual org.jruby.RubyArray.first:()Lorg/jruby/runtime/builtin/IRubyObject;
            astore 8 /* mesg */
        start local 8 // org.jruby.runtime.builtin.IRubyObject mesg
        18: .line 363
            aload 8 /* mesg */
            invokeinterface org.jruby.runtime.builtin.IRubyObject.isNil:()Z
            ifeq 21
        19: .line 364
            aload 3 /* context */
            aload 6 /* errorStream */
            invokestatic org.jruby.runtime.backtrace.TraceType.printErrorPos:(Lorg/jruby/runtime/ThreadContext;Ljava/io/PrintStream;)V
        20: .line 365
            goto 23
        21: .line 366
      StackMap locals: org.jruby.runtime.builtin.IRubyObject
      StackMap stack:
            aload 6 /* errorStream */
            aload 8 /* mesg */
            invokevirtual java.io.PrintStream.print:(Ljava/lang/Object;)V
        22: .line 367
            iconst_1
            istore 7 /* printedPosition */
        end local 8 // org.jruby.runtime.builtin.IRubyObject mesg
        23: .line 371
      StackMap locals:
      StackMap stack:
            aload 0 /* exception */
            invokeinterface org.jruby.runtime.builtin.IRubyObject.getMetaClass:()Lorg/jruby/RubyClass;
            astore 8 /* type */
        start local 8 // org.jruby.RubyClass type
        24: .line 372
            aload 0 /* exception */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            astore 9 /* info */
        start local 9 // java.lang.String info
        25: .line 374
            aload 8 /* type */
            aload 2 /* runtime */
            invokevirtual org.jruby.Ruby.getRuntimeError:()Lorg/jruby/RubyClass;
            if_acmpne 28
            aload 9 /* info */
            ifnull 26
            aload 9 /* info */
            invokevirtual java.lang.String.length:()I
            ifne 28
        26: .line 375
      StackMap locals: org.jruby.RubyClass java.lang.String
      StackMap stack:
            aload 6 /* errorStream */
            ldc ": unhandled exception\n"
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        27: .line 376
            goto 47
        28: .line 377
      StackMap locals:
      StackMap stack:
            iload 7 /* printedPosition */
            ifeq 29
            aload 6 /* errorStream */
            ldc ": "
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        29: .line 378
      StackMap locals:
      StackMap stack:
            aload 8 /* type */
            invokevirtual org.jruby.RubyClass.getName:()Ljava/lang/String;
            astore 10 /* path */
        start local 10 // java.lang.String path
        30: .line 380
            aload 9 /* info */
            invokevirtual java.lang.String.length:()I
            ifne 33
        31: .line 381
            aload 6 /* errorStream */
            new java.lang.StringBuilder
            dup
            aload 10 /* path */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        32: .line 382
            goto 47
        33: .line 383
      StackMap locals: java.lang.String
      StackMap stack:
            aload 10 /* path */
            ldc "#"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 35
        34: .line 384
            aconst_null
            astore 10 /* path */
        35: .line 387
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 11 /* tail */
        start local 11 // java.lang.String tail
        36: .line 388
            aload 9 /* info */
            bipush 10
            invokevirtual java.lang.String.indexOf:(I)I
            istore 12 /* idx */
        start local 12 // int idx
        37: .line 389
            iload 12 /* idx */
            iconst_m1
            if_icmpeq 40
        38: .line 390
            aload 9 /* info */
            iload 12 /* idx */
            iconst_1
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 11 /* tail */
        39: .line 391
            aload 9 /* info */
            iconst_0
            iload 12 /* idx */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 9 /* info */
        40: .line 394
      StackMap locals: java.lang.String int
      StackMap stack:
            aload 6 /* errorStream */
            aload 9 /* info */
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        41: .line 396
            aload 10 /* path */
            ifnull 44
        42: .line 397
            aload 6 /* errorStream */
            new java.lang.StringBuilder
            dup
            ldc " ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 10 /* path */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ")\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        43: .line 398
            goto 45
        44: .line 399
      StackMap locals:
      StackMap stack:
            aload 6 /* errorStream */
            bipush 10
            invokevirtual java.io.PrintStream.print:(C)V
        45: .line 402
      StackMap locals:
      StackMap stack:
            aload 11 /* tail */
            ifnull 47
        46: .line 403
            aload 6 /* errorStream */
            new java.lang.StringBuilder
            dup
            aload 11 /* tail */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        end local 12 // int idx
        end local 11 // java.lang.String tail
        end local 10 // java.lang.String path
        47: .line 408
      StackMap locals:
      StackMap stack:
            aload 4 /* backtrace */
            aload 6 /* errorStream */
            iconst_1
            invokestatic org.jruby.runtime.backtrace.TraceType.printBacktraceToStream:(Lorg/jruby/runtime/builtin/IRubyObject;Ljava/io/PrintStream;I)V
        48: .line 410
            aload 5 /* baos */
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            areturn
        end local 9 // java.lang.String info
        end local 8 // org.jruby.RubyClass type
        end local 7 // boolean printedPosition
        end local 6 // java.io.PrintStream errorStream
        end local 5 // java.io.ByteArrayOutputStream baos
        end local 4 // org.jruby.runtime.builtin.IRubyObject backtrace
        end local 3 // org.jruby.runtime.ThreadContext context
        end local 2 // org.jruby.Ruby runtime
        end local 1 // boolean console
        end local 0 // org.jruby.runtime.builtin.IRubyObject exception
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   49     0        exception  Lorg/jruby/runtime/builtin/IRubyObject;
            0   49     1          console  Z
            1   49     2          runtime  Lorg/jruby/Ruby;
            2   49     3          context  Lorg/jruby/runtime/ThreadContext;
            3   49     4        backtrace  Lorg/jruby/runtime/builtin/IRubyObject;
            4   49     5             baos  Ljava/io/ByteArrayOutputStream;
            5   49     6      errorStream  Ljava/io/PrintStream;
            6   49     7  printedPosition  Z
           18   23     8             mesg  Lorg/jruby/runtime/builtin/IRubyObject;
           24   49     8             type  Lorg/jruby/RubyClass;
           25   49     9             info  Ljava/lang/String;
           30   47    10             path  Ljava/lang/String;
           36   47    11             tail  Ljava/lang/String;
           37   47    12              idx  I
    MethodParameters:
           Name  Flags
      exception  
      console    

  public static java.lang.String printBacktraceJRuby(org.jruby.Ruby, org.jruby.runtime.backtrace.RubyStackTraceElement[], java.lang.String, java.lang.String, boolean);
    descriptor: (Lorg/jruby/Ruby;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/String;Ljava/lang/String;Z)Ljava/lang/String;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=6, args_size=5
        start local 0 // org.jruby.Ruby runtime
        start local 1 // org.jruby.runtime.backtrace.RubyStackTraceElement[] frames
        start local 2 // java.lang.String type
        start local 3 // java.lang.String message
        start local 4 // boolean color
         0: .line 419
            aload 1 /* frames */
            ifnonnull 1
            getstatic org.jruby.runtime.backtrace.RubyStackTraceElement.EMPTY_ARRAY:[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            astore 1 /* frames */
         1: .line 421
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            bipush 64
            aload 1 /* frames */
            arraylength
            bipush 48
            imul
            iadd
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 5 /* buffer */
        start local 5 // java.lang.StringBuilder buffer
         2: .line 423
            aload 5 /* buffer */
            aload 2 /* type */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ": "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* message */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         3: .line 425
            aload 0 /* runtime */
            aload 1 /* frames */
            aload 5 /* buffer */
            iload 4 /* color */
            invokestatic org.jruby.runtime.backtrace.TraceType.renderBacktraceJRuby:(Lorg/jruby/Ruby;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/StringBuilder;Z)V
         4: .line 427
            aload 5 /* buffer */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 5 // java.lang.StringBuilder buffer
        end local 4 // boolean color
        end local 3 // java.lang.String message
        end local 2 // java.lang.String type
        end local 1 // org.jruby.runtime.backtrace.RubyStackTraceElement[] frames
        end local 0 // org.jruby.Ruby runtime
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0  runtime  Lorg/jruby/Ruby;
            0    5     1   frames  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            0    5     2     type  Ljava/lang/String;
            0    5     3  message  Ljava/lang/String;
            0    5     4    color  Z
            2    5     5   buffer  Ljava/lang/StringBuilder;
    MethodParameters:
         Name  Flags
      runtime  
      frames   
      type     
      message  
      color    

  protected static java.lang.String printBacktraceJRuby(org.jruby.RubyException, boolean);
    descriptor: (Lorg/jruby/RubyException;Z)Ljava/lang/String;
    flags: (0x000c) ACC_PROTECTED, ACC_STATIC
    Code:
      stack=5, locals=7, args_size=2
        start local 0 // org.jruby.RubyException exception
        start local 1 // boolean console
         0: .line 431
            aload 0 /* exception */
            invokevirtual org.jruby.RubyException.getRuntime:()Lorg/jruby/Ruby;
            astore 2 /* runtime */
        start local 2 // org.jruby.Ruby runtime
         1: .line 432
            aload 2 /* runtime */
            invokevirtual org.jruby.Ruby.getCurrentContext:()Lorg/jruby/runtime/ThreadContext;
            astore 3 /* context */
        start local 3 // org.jruby.runtime.ThreadContext context
         2: .line 434
            iload 1 /* console */
            ifeq 3
            aload 2 /* runtime */
            invokevirtual org.jruby.Ruby.getInstanceConfig:()Lorg/jruby/RubyInstanceConfig;
            invokevirtual org.jruby.RubyInstanceConfig.getBacktraceColor:()Z
            ifeq 3
            iconst_1
            goto 4
      StackMap locals: org.jruby.Ruby org.jruby.runtime.ThreadContext
      StackMap stack:
         3: iconst_0
      StackMap locals:
      StackMap stack: int
         4: istore 4 /* color */
        start local 4 // boolean color
         5: .line 439
            aload 0 /* exception */
            aload 3 /* context */
            ldc "message"
            invokevirtual org.jruby.RubyException.callMethod:(Lorg/jruby/runtime/ThreadContext;Ljava/lang/String;)Lorg/jruby/runtime/builtin/IRubyObject;
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            astore 5 /* message */
        start local 5 // java.lang.String message
         6: .line 440
            goto 9
        end local 5 // java.lang.String message
      StackMap locals: org.jruby.RubyException int org.jruby.Ruby org.jruby.runtime.ThreadContext int
      StackMap stack: org.jruby.exceptions.Exception
         7: pop
         8: .line 441
            aload 0 /* exception */
            aload 3 /* context */
            invokevirtual org.jruby.RubyException.message:(Lorg/jruby/runtime/ThreadContext;)Lorg/jruby/runtime/builtin/IRubyObject;
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            astore 5 /* message */
        start local 5 // java.lang.String message
         9: .line 443
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* exception */
            invokevirtual org.jruby.RubyException.getMetaClass:()Lorg/jruby/RubyClass;
            aload 2 /* runtime */
            invokevirtual org.jruby.Ruby.getRuntimeError:()Lorg/jruby/RubyClass;
            if_acmpne 11
            aload 5 /* message */
            invokevirtual java.lang.String.length:()I
            ifne 11
        10: .line 444
            ldc "No current exception"
            astore 5 /* message */
        11: .line 446
      StackMap locals:
      StackMap stack:
            aload 0 /* exception */
            invokevirtual org.jruby.RubyException.getMetaClass:()Lorg/jruby/RubyClass;
            invokevirtual org.jruby.RubyClass.getName:()Ljava/lang/String;
            astore 6 /* type */
        start local 6 // java.lang.String type
        12: .line 448
            aload 0 /* exception */
            invokevirtual org.jruby.RubyException.getRuntime:()Lorg/jruby/Ruby;
            aload 0 /* exception */
            invokevirtual org.jruby.RubyException.getBacktraceElements:()[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            aload 6 /* type */
            aload 5 /* message */
            iload 4 /* color */
            invokestatic org.jruby.runtime.backtrace.TraceType.printBacktraceJRuby:(Lorg/jruby/Ruby;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/String;Ljava/lang/String;Z)Ljava/lang/String;
            areturn
        end local 6 // java.lang.String type
        end local 5 // java.lang.String message
        end local 4 // boolean color
        end local 3 // org.jruby.runtime.ThreadContext context
        end local 2 // org.jruby.Ruby runtime
        end local 1 // boolean console
        end local 0 // org.jruby.RubyException exception
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   13     0  exception  Lorg/jruby/RubyException;
            0   13     1    console  Z
            1   13     2    runtime  Lorg/jruby/Ruby;
            2   13     3    context  Lorg/jruby/runtime/ThreadContext;
            5   13     4      color  Z
            6    7     5    message  Ljava/lang/String;
            9   13     5    message  Ljava/lang/String;
           12   13     6       type  Ljava/lang/String;
      Exception table:
        from    to  target  type
           5     6       7  Class org.jruby.exceptions.Exception
    MethodParameters:
           Name  Flags
      exception  
      console    

  private static void renderBacktraceJRuby(org.jruby.Ruby, org.jruby.runtime.backtrace.RubyStackTraceElement[], java.lang.StringBuilder, boolean);
    descriptor: (Lorg/jruby/Ruby;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/StringBuilder;Z)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=12, args_size=4
        start local 0 // org.jruby.Ruby runtime
        start local 1 // org.jruby.runtime.backtrace.RubyStackTraceElement[] frames
        start local 2 // java.lang.StringBuilder buffer
        start local 3 // boolean color
         0: .line 453
            iconst_0
            istore 4 /* longestMethod */
        start local 4 // int longestMethod
         1: .line 454
            aload 1 /* frames */
            dup
            astore 8
            arraylength
            istore 7
            iconst_0
            istore 6
            goto 5
      StackMap locals: org.jruby.Ruby org.jruby.runtime.backtrace.RubyStackTraceElement[] java.lang.StringBuilder int int top int int org.jruby.runtime.backtrace.RubyStackTraceElement[]
      StackMap stack:
         2: aload 8
            iload 6
            aaload
            astore 5 /* frame */
        start local 5 // org.jruby.runtime.backtrace.RubyStackTraceElement frame
         3: .line 455
            iload 4 /* longestMethod */
            aload 5 /* frame */
            invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getMethodName:()Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            invokestatic java.lang.Math.max:(II)I
            istore 4 /* longestMethod */
        end local 5 // org.jruby.runtime.backtrace.RubyStackTraceElement frame
         4: .line 454
            iinc 6 1
      StackMap locals:
      StackMap stack:
         5: iload 6
            iload 7
            if_icmplt 2
         6: .line 459
            iconst_1
            istore 5 /* first */
        start local 5 // boolean first
         7: .line 460
            aload 1 /* frames */
            dup
            astore 9
            arraylength
            istore 8
            iconst_0
            istore 7
            goto 39
      StackMap locals: org.jruby.Ruby org.jruby.runtime.backtrace.RubyStackTraceElement[] java.lang.StringBuilder int int int top int int org.jruby.runtime.backtrace.RubyStackTraceElement[]
      StackMap stack:
         8: aload 9
            iload 7
            aaload
            astore 6 /* frame */
        start local 6 // org.jruby.runtime.backtrace.RubyStackTraceElement frame
         9: .line 461
            iload 3 /* color */
            ifeq 19
        10: .line 462
            iload 5 /* first */
            ifeq 13
        11: .line 463
            aload 2 /* buffer */
            ldc "\u001B[0;31m"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        12: .line 464
            goto 18
      StackMap locals: org.jruby.Ruby org.jruby.runtime.backtrace.RubyStackTraceElement[] java.lang.StringBuilder int int int org.jruby.runtime.backtrace.RubyStackTraceElement int int org.jruby.runtime.backtrace.RubyStackTraceElement[]
      StackMap stack:
        13: aload 6 /* frame */
            invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.isBinding:()Z
            ifne 14
            aload 6 /* frame */
            invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getFileName:()Ljava/lang/String;
            ldc "(eval)"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 16
        14: .line 465
      StackMap locals:
      StackMap stack:
            aload 2 /* buffer */
            ldc "\u001B[0;33m"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        15: .line 466
            goto 18
      StackMap locals:
      StackMap stack:
        16: aload 6 /* frame */
            invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getFileName:()Ljava/lang/String;
            ldc ".java"
            invokevirtual java.lang.String.indexOf:(Ljava/lang/String;)I
            iconst_m1
            if_icmpeq 18
        17: .line 467
            aload 2 /* buffer */
            ldc "\u001B[0;36m"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        18: .line 469
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 5 /* first */
        19: .line 472
      StackMap locals:
      StackMap stack:
            aload 2 /* buffer */
            ldc "  "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        20: .line 475
            aload 0 /* runtime */
            ifnonnull 21
            aload 6 /* frame */
            invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getMethodName:()Ljava/lang/String;
            goto 22
      StackMap locals:
      StackMap stack:
        21: aload 0 /* runtime */
            aload 6 /* frame */
            invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getMethodName:()Ljava/lang/String;
            invokevirtual org.jruby.Ruby.newSymbol:(Ljava/lang/String;)Lorg/jruby/RubySymbol;
            invokevirtual org.jruby.RubySymbol.idString:()Ljava/lang/String;
      StackMap locals:
      StackMap stack: java.lang.String
        22: astore 10 /* methodName */
        start local 10 // java.lang.String methodName
        23: .line 476
            iconst_0
            istore 11 /* j */
        start local 11 // int j
        24: goto 27
        25: .line 477
      StackMap locals: java.lang.String int
      StackMap stack:
            aload 2 /* buffer */
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        26: .line 476
            iinc 11 /* j */ 1
      StackMap locals:
      StackMap stack:
        27: iload 11 /* j */
            iload 4 /* longestMethod */
            aload 10 /* methodName */
            invokevirtual java.lang.String.length:()I
            isub
            if_icmplt 25
        end local 11 // int j
        28: .line 479
            aload 2 /* buffer */
        29: .line 480
            aload 10 /* methodName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        30: .line 481
            ldc " at "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        31: .line 482
            aload 6 /* frame */
            invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getFileName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        32: .line 483
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
        33: .line 484
            aload 6 /* frame */
            invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getLineNumber:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            pop
        34: .line 486
            iload 3 /* color */
            ifeq 36
        35: .line 487
            aload 2 /* buffer */
            ldc "\u001B[0m"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        36: .line 490
      StackMap locals:
      StackMap stack:
            aload 2 /* buffer */
        37: .line 491
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        end local 10 // java.lang.String methodName
        end local 6 // org.jruby.runtime.backtrace.RubyStackTraceElement frame
        38: .line 460
            iinc 7 1
      StackMap locals: org.jruby.Ruby org.jruby.runtime.backtrace.RubyStackTraceElement[] java.lang.StringBuilder int int int top int int org.jruby.runtime.backtrace.RubyStackTraceElement[]
      StackMap stack:
        39: iload 7
            iload 8
            if_icmplt 8
        40: .line 493
            return
        end local 5 // boolean first
        end local 4 // int longestMethod
        end local 3 // boolean color
        end local 2 // java.lang.StringBuilder buffer
        end local 1 // org.jruby.runtime.backtrace.RubyStackTraceElement[] frames
        end local 0 // org.jruby.Ruby runtime
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   41     0        runtime  Lorg/jruby/Ruby;
            0   41     1         frames  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            0   41     2         buffer  Ljava/lang/StringBuilder;
            0   41     3          color  Z
            1   41     4  longestMethod  I
            3    4     5          frame  Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            7   41     5          first  Z
            9   38     6          frame  Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
           23   38    10     methodName  Ljava/lang/String;
           24   28    11              j  I
    MethodParameters:
         Name  Flags
      runtime  
      frames   
      buffer   
      color    

  private static void renderBacktraceMRI(org.jruby.runtime.backtrace.RubyStackTraceElement[], java.lang.StringBuilder, boolean);
    descriptor: ([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/StringBuilder;Z)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
        start local 1 // java.lang.StringBuilder buffer
        start local 2 // boolean color
         0: .line 496
            aload 0 /* trace */
            ldc ""
            aload 1 /* buffer */
            iload 2 /* color */
            invokestatic org.jruby.runtime.backtrace.TraceType.renderBacktraceMRI:([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/String;Ljava/lang/StringBuilder;Z)V
         1: .line 497
            return
        end local 2 // boolean color
        end local 1 // java.lang.StringBuilder buffer
        end local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0   trace  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            0    2     1  buffer  Ljava/lang/StringBuilder;
            0    2     2   color  Z
    MethodParameters:
        Name  Flags
      trace   
      buffer  
      color   

  private static void renderBacktraceMRI(org.jruby.runtime.backtrace.RubyStackTraceElement[], java.lang.String, java.lang.StringBuilder, boolean);
    descriptor: ([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/String;Ljava/lang/StringBuilder;Z)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=6, args_size=4
        start local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
        start local 1 // java.lang.String linePrefix
        start local 2 // java.lang.StringBuilder buffer
        start local 3 // boolean color
         0: .line 500
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         1: goto 12
         2: .line 501
      StackMap locals: int
      StackMap stack:
            aload 0 /* trace */
            iload 4 /* i */
            aaload
            astore 5 /* element */
        start local 5 // org.jruby.runtime.backtrace.RubyStackTraceElement element
         3: .line 502
            aload 2 /* buffer */
         4: .line 503
            aload 1 /* linePrefix */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         5: .line 504
            aload 5 /* element */
            invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getFileName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         6: .line 505
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
         7: .line 506
            aload 5 /* element */
            invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getLineNumber:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
         8: .line 507
            ldc ":in `"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         9: .line 508
            aload 5 /* element */
            invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getMethodName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        10: .line 509
            ldc "'\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 5 // org.jruby.runtime.backtrace.RubyStackTraceElement element
        11: .line 500
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
        12: iload 4 /* i */
            aload 0 /* trace */
            arraylength
            if_icmplt 2
        end local 4 // int i
        13: .line 511
            return
        end local 3 // boolean color
        end local 2 // java.lang.StringBuilder buffer
        end local 1 // java.lang.String linePrefix
        end local 0 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   14     0       trace  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            0   14     1  linePrefix  Ljava/lang/String;
            0   14     2      buffer  Ljava/lang/StringBuilder;
            0   14     3       color  Z
            1   13     4           i  I
            3   11     5     element  Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
    MethodParameters:
            Name  Flags
      trace       
      linePrefix  
      buffer      
      color       

  private static void printErrorPos(org.jruby.runtime.ThreadContext, java.io.PrintStream);
    descriptor: (Lorg/jruby/runtime/ThreadContext;Ljava/io/PrintStream;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.jruby.runtime.ThreadContext context
        start local 1 // java.io.PrintStream errorStream
         0: .line 514
            aload 0 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
            ifnull 9
            aload 0 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            ifle 9
         1: .line 515
            aload 0 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getFrameName:()Ljava/lang/String;
            ifnull 5
         2: .line 516
            aload 1 /* errorStream */
            new java.lang.StringBuilder
            dup
            aload 0 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            aload 0 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
         3: .line 517
            aload 1 /* errorStream */
            new java.lang.StringBuilder
            dup
            ldc ":in '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getFrameName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 39
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
         4: .line 518
            goto 9
      StackMap locals:
      StackMap stack:
         5: aload 0 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
            ifeq 8
         6: .line 519
            aload 1 /* errorStream */
            new java.lang.StringBuilder
            dup
            aload 0 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            aload 0 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
         7: .line 520
            goto 9
         8: .line 521
      StackMap locals:
      StackMap stack:
            aload 1 /* errorStream */
            aload 0 /* context */
            invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
         9: .line 524
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.io.PrintStream errorStream
        end local 0 // org.jruby.runtime.ThreadContext context
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   10     0      context  Lorg/jruby/runtime/ThreadContext;
            0   10     1  errorStream  Ljava/io/PrintStream;
    MethodParameters:
             Name  Flags
      context      
      errorStream  

  public static void printBacktraceToStream(org.jruby.runtime.builtin.IRubyObject, java.io.PrintStream, int);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Ljava/io/PrintStream;I)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // org.jruby.runtime.builtin.IRubyObject backtrace
        start local 1 // java.io.PrintStream errorStream
        start local 2 // int skip
         0: .line 527
            aload 0 /* backtrace */
            invokeinterface org.jruby.runtime.builtin.IRubyObject.isNil:()Z
            ifeq 1
            return
         1: .line 528
      StackMap locals:
      StackMap stack:
            aload 0 /* backtrace */
            instanceof org.jruby.RubyArray
            ifeq 12
         2: .line 529
            aload 0 /* backtrace */
            checkcast org.jruby.RubyArray
            invokevirtual org.jruby.RubyArray.toJavaArrayMaybeUnsafe:()[Lorg/jruby/runtime/builtin/IRubyObject;
            astore 3 /* elements */
        start local 3 // org.jruby.runtime.builtin.IRubyObject[] elements
         3: .line 530
            iload 2 /* skip */
            istore 4 /* i */
        start local 4 // int i
         4: goto 11
         5: .line 531
      StackMap locals: org.jruby.runtime.builtin.IRubyObject[] int
      StackMap stack:
            aload 3 /* elements */
            iload 4 /* i */
            aaload
            astore 5 /* stackTraceLine */
        start local 5 // org.jruby.runtime.builtin.IRubyObject stackTraceLine
         6: .line 532
            aload 5 /* stackTraceLine */
            instanceof org.jruby.RubyString
            ifeq 9
         7: .line 533
            aload 1 /* errorStream */
            new java.lang.StringBuilder
            dup
            ldc "\tfrom "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* stackTraceLine */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         8: .line 534
            goto 10
         9: .line 536
      StackMap locals: org.jruby.runtime.builtin.IRubyObject
      StackMap stack:
            aload 1 /* errorStream */
            new java.lang.StringBuilder
            dup
            ldc "\t"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* stackTraceLine */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 5 // org.jruby.runtime.builtin.IRubyObject stackTraceLine
        10: .line 530
      StackMap locals:
      StackMap stack:
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
        11: iload 4 /* i */
            aload 3 /* elements */
            arraylength
            if_icmplt 5
        end local 4 // int i
        end local 3 // org.jruby.runtime.builtin.IRubyObject[] elements
        12: .line 540
      StackMap locals:
      StackMap stack:
            return
        end local 2 // int skip
        end local 1 // java.io.PrintStream errorStream
        end local 0 // org.jruby.runtime.builtin.IRubyObject backtrace
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   13     0       backtrace  Lorg/jruby/runtime/builtin/IRubyObject;
            0   13     1     errorStream  Ljava/io/PrintStream;
            0   13     2            skip  I
            3   12     3        elements  [Lorg/jruby/runtime/builtin/IRubyObject;
            4   12     4               i  I
            6   10     5  stackTraceLine  Lorg/jruby/runtime/builtin/IRubyObject;
    MethodParameters:
             Name  Flags
      backtrace    
      errorStream  
      skip         

  public static org.jruby.runtime.builtin.IRubyObject generateMRIBacktrace(org.jruby.Ruby, org.jruby.runtime.backtrace.RubyStackTraceElement[]);
    descriptor: (Lorg/jruby/Ruby;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // org.jruby.Ruby runtime
        start local 1 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
         0: .line 544
            aload 1 /* trace */
            ifnonnull 1
            aload 0 /* runtime */
            invokevirtual org.jruby.Ruby.getNil:()Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
         1: .line 546
      StackMap locals:
      StackMap stack:
            aload 0 /* runtime */
            invokevirtual org.jruby.Ruby.getCurrentContext:()Lorg/jruby/runtime/ThreadContext;
            astore 2 /* context */
        start local 2 // org.jruby.runtime.ThreadContext context
         2: .line 547
            aload 1 /* trace */
            arraylength
            anewarray org.jruby.runtime.builtin.IRubyObject
            astore 3 /* traceArray */
        start local 3 // org.jruby.runtime.builtin.IRubyObject[] traceArray
         3: .line 549
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         4: goto 7
         5: .line 550
      StackMap locals: org.jruby.runtime.ThreadContext org.jruby.runtime.builtin.IRubyObject[] int
      StackMap stack:
            aload 3 /* traceArray */
            iload 4 /* i */
            aload 2 /* context */
            aload 1 /* trace */
            iload 4 /* i */
            aaload
            invokestatic org.jruby.runtime.backtrace.RubyStackTraceElement.to_s_mri:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)Lorg/jruby/RubyString;
            aastore
         6: .line 549
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
         7: iload 4 /* i */
            aload 1 /* trace */
            arraylength
            if_icmplt 5
        end local 4 // int i
         8: .line 553
            aload 0 /* runtime */
            aload 3 /* traceArray */
            invokestatic org.jruby.RubyArray.newArrayMayCopy:(Lorg/jruby/Ruby;[Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyArray;
            areturn
        end local 3 // org.jruby.runtime.builtin.IRubyObject[] traceArray
        end local 2 // org.jruby.runtime.ThreadContext context
        end local 1 // org.jruby.runtime.backtrace.RubyStackTraceElement[] trace
        end local 0 // org.jruby.Ruby runtime
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    9     0     runtime  Lorg/jruby/Ruby;
            0    9     1       trace  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            2    9     2     context  Lorg/jruby/runtime/ThreadContext;
            3    9     3  traceArray  [Lorg/jruby/runtime/builtin/IRubyObject;
            4    8     4           i  I
    RuntimeVisibleAnnotations: 
      java.lang.Deprecated()
    MethodParameters:
         Name  Flags
      runtime  
      trace    

  public org.jruby.runtime.backtrace.RubyStackTraceElement getBacktraceElement(org.jruby.runtime.ThreadContext, int);
    descriptor: (Lorg/jruby/runtime/ThreadContext;I)Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // org.jruby.runtime.backtrace.TraceType this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // int uplevel
         0: .line 559
            aload 0 /* this */
            aload 1 /* context */
            invokevirtual org.jruby.runtime.backtrace.TraceType.getBacktrace:(Lorg/jruby/runtime/ThreadContext;)Lorg/jruby/runtime/backtrace/BacktraceData;
            aload 1 /* context */
            getfield org.jruby.runtime.ThreadContext.runtime:Lorg/jruby/Ruby;
            invokevirtual org.jruby.runtime.backtrace.BacktraceData.getBacktrace:(Lorg/jruby/Ruby;)[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
            astore 3 /* elements */
        start local 3 // org.jruby.runtime.backtrace.RubyStackTraceElement[] elements
         1: .line 562
            aload 3 /* elements */
            arraylength
            iload 2 /* uplevel */
            iconst_1
            iadd
            if_icmpgt 2
            iconst_m1
            istore 2 /* uplevel */
         2: .line 564
      StackMap locals: org.jruby.runtime.backtrace.RubyStackTraceElement[]
      StackMap stack:
            aload 3 /* elements */
            iload 2 /* uplevel */
            iconst_1
            iadd
            aaload
            areturn
        end local 3 // org.jruby.runtime.backtrace.RubyStackTraceElement[] elements
        end local 2 // int uplevel
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.backtrace.TraceType this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lorg/jruby/runtime/backtrace/TraceType;
            0    3     1   context  Lorg/jruby/runtime/ThreadContext;
            0    3     2   uplevel  I
            1    3     3  elements  [Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
    RuntimeVisibleAnnotations: 
      java.lang.Deprecated()
    MethodParameters:
         Name  Flags
      context  
      uplevel  
}
SourceFile: "TraceType.java"
NestMembers:
  org.jruby.runtime.backtrace.TraceType$Format  org.jruby.runtime.backtrace.TraceType$Format$1  org.jruby.runtime.backtrace.TraceType$Format$2  org.jruby.runtime.backtrace.TraceType$Gather  org.jruby.runtime.backtrace.TraceType$Gather$1  org.jruby.runtime.backtrace.TraceType$Gather$2  org.jruby.runtime.backtrace.TraceType$Gather$3  org.jruby.runtime.backtrace.TraceType$Gather$4  org.jruby.runtime.backtrace.TraceType$Gather$5
InnerClasses:
  public abstract Format = org.jruby.runtime.backtrace.TraceType$Format of org.jruby.runtime.backtrace.TraceType
  public abstract Gather = org.jruby.runtime.backtrace.TraceType$Gather of org.jruby.runtime.backtrace.TraceType