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: 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: getstatic org.jruby.runtime.ThreadContext.WALKER:Lcom/headius/backport9/stack/StackWalker;
putstatic org.jruby.runtime.backtrace.TraceType.WALKER:Lcom/headius/backport9/stack/StackWalker;
2: 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: 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 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aload 1
putfield org.jruby.runtime.backtrace.TraceType.gather:Lorg/jruby/runtime/backtrace/TraceType$Gather;
2: aload 0
aload 2
putfield org.jruby.runtime.backtrace.TraceType.format:Lorg/jruby/runtime/backtrace/TraceType$Format;
3: return
end local 2 end local 1 end local 0 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 0: aload 0
getfield org.jruby.runtime.backtrace.TraceType.gather:Lorg/jruby/runtime/backtrace/TraceType$Gather;
areturn
end local 0 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 0: aload 0
getfield org.jruby.runtime.backtrace.TraceType.format:Lorg/jruby/runtime/backtrace/TraceType$Format;
areturn
end local 0 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 start local 1 0: aload 0
getfield org.jruby.runtime.backtrace.TraceType.gather:Lorg/jruby/runtime/backtrace/TraceType$Gather;
aload 1
invokevirtual org.jruby.runtime.backtrace.TraceType$Gather.getBacktraceData:(Lorg/jruby/runtime/ThreadContext;)Lorg/jruby/runtime/backtrace/BacktraceData;
areturn
end local 1 end local 0 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 start local 1 start local 2 0: aload 0
getfield org.jruby.runtime.backtrace.TraceType.gather:Lorg/jruby/runtime/backtrace/TraceType$Gather;
aload 1
aload 2
invokevirtual org.jruby.runtime.backtrace.TraceType$Gather.getIntegratedBacktraceData:(Lorg/jruby/runtime/ThreadContext;[Ljava/lang/StackTraceElement;)Lorg/jruby/runtime/backtrace/BacktraceData;
areturn
end local 2 end local 1 end local 0 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 start local 1 start local 2 0: aload 0
getfield org.jruby.runtime.backtrace.TraceType.format:Lorg/jruby/runtime/backtrace/TraceType$Format;
aload 1
iload 2
invokevirtual org.jruby.runtime.backtrace.TraceType$Format.printBacktrace:(Lorg/jruby/RubyException;Z)Ljava/lang/String;
areturn
end local 2 end local 1 end local 0 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 start local 1 0: aload 1
ifnonnull 1
getstatic org.jruby.runtime.backtrace.RubyStackTraceElement.EMPTY_ARRAY:[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
astore 1
1: StackMap locals:
StackMap stack:
new java.lang.StringBuilder
dup
bipush 64
aload 1
arraylength
bipush 48
imul
iadd
invokespecial java.lang.StringBuilder.<init>:(I)V
astore 2
start local 2 2: aload 2
ldc "Backtrace generated:\n"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
3: aload 0
aload 1
aload 2
iconst_0
invokestatic org.jruby.runtime.backtrace.TraceType.renderBacktraceJRuby:(Lorg/jruby/Ruby;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/StringBuilder;Z)V
4: getstatic org.jruby.runtime.backtrace.TraceType.LOG:Lorg/jruby/util/log/Logger;
aload 2
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: return
end local 2 end local 1 end local 0 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 0: 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
invokevirtual org.jruby.RubyException.getMetaClass:()Lorg/jruby/RubyClass;
aastore
dup
iconst_1
aload 0
aastore
invokeinterface org.jruby.util.log.Logger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
1: return
end local 0 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 0: aload 0
invokestatic org.jruby.runtime.backtrace.TraceType.logException:(Lorg/jruby/RubyException;)V
1: return
end local 0 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 0: aload 0
invokevirtual org.jruby.RubyException.getRuntime:()Lorg/jruby/Ruby;
astore 1
start local 1 1: 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
aload 1
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: return
end local 1 end local 0 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 0: new java.lang.StringBuilder
dup
bipush 64
aload 0
invokevirtual org.jruby.RubyArray.size:()I
bipush 48
imul
iadd
invokespecial java.lang.StringBuilder.<init>:(I)V
astore 1
start local 1 1: aload 1
ldc "Caller backtrace generated:\n"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
2: iconst_0
istore 2
start local 2 3: goto 6
4: StackMap locals: java.lang.StringBuilder int
StackMap stack:
aload 1
ldc " "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
iload 2
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: iinc 2 1
StackMap locals:
StackMap stack:
6: iload 2
aload 0
invokevirtual org.jruby.RubyArray.size:()I
if_icmplt 4
end local 2 7: getstatic org.jruby.runtime.backtrace.TraceType.LOG:Lorg/jruby/util/log/Logger;
aload 1
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: return
end local 1 end local 0 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 0: aload 0
invokestatic org.jruby.runtime.backtrace.TraceType.logCaller:(Lorg/jruby/RubyArray;)V
1: return
end local 0 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 0: aload 0
ifnonnull 1
getstatic org.jruby.runtime.backtrace.RubyStackTraceElement.EMPTY_ARRAY:[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
astore 0
1: StackMap locals:
StackMap stack:
getstatic org.jruby.runtime.backtrace.TraceType.LOG:Lorg/jruby/util/log/Logger;
ldc "Caller backtrace generated:\n"
aload 0
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: return
end local 0 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 start local 1 0: new java.lang.StringBuilder
dup
bipush 64
aload 1
arraylength
bipush 48
imul
iadd
invokespecial java.lang.StringBuilder.<init>:(I)V
astore 2
start local 2 1: aload 2
aload 0
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
2: aload 1
ldc " "
aload 2
iconst_0
invokestatic org.jruby.runtime.backtrace.TraceType.renderBacktraceMRI:([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/String;Ljava/lang/StringBuilder;Z)V
3: aload 2
areturn
end local 2 end local 1 end local 0 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 0: aload 0
invokestatic org.jruby.runtime.backtrace.TraceType.logCaller:([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)V
1: return
end local 0 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 0: aload 0
ifnonnull 1
getstatic org.jruby.runtime.backtrace.RubyStackTraceElement.EMPTY_ARRAY:[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
astore 0
1: StackMap locals:
StackMap stack:
getstatic org.jruby.runtime.backtrace.TraceType.LOG:Lorg/jruby/util/log/Logger;
ldc "Warning backtrace generated:\n"
aload 0
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: return
end local 0 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 0: aload 0
invokestatic org.jruby.runtime.backtrace.TraceType.logWarning:([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)V
1: return
end local 0 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 0: aload 0
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: StackMap locals:
StackMap stack:
aload 0
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: StackMap locals:
StackMap stack:
aload 0
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: StackMap locals:
StackMap stack:
aload 0
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: StackMap locals:
StackMap stack:
aload 0
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: 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 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 start local 1 start local 2 0: aload 0
getfield org.jruby.runtime.ThreadContext.runtime:Lorg/jruby/Ruby;
astore 3
start local 3 1: aload 3
aload 2
invokestatic org.jruby.ast.util.ArgsUtil.getOptionsArg:(Lorg/jruby/Ruby;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 4
start local 4 2: iconst_0
istore 5
start local 5 3: aload 4
invokeinterface org.jruby.runtime.builtin.IRubyObject.isNil:()Z
ifne 16
4: aload 0
aload 4
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
start local 6 5: aload 6
iconst_0
aaload
astore 7
start local 7 6: aload 7
ifnonnull 7
aload 0
getfield org.jruby.runtime.ThreadContext.nil:Lorg/jruby/runtime/builtin/IRubyObject;
astore 7
7: 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
aload 0
getfield org.jruby.runtime.ThreadContext.nil:Lorg/jruby/runtime/builtin/IRubyObject;
if_acmpeq 9
aload 7
aload 0
getfield org.jruby.runtime.ThreadContext.fals:Lorg/jruby/RubyBoolean;
if_acmpeq 9
aload 7
aload 0
getfield org.jruby.runtime.ThreadContext.tru:Lorg/jruby/RubyBoolean;
if_acmpeq 9
8: aload 3
new java.lang.StringBuilder
dup
ldc "expected true or false as highlight: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 7
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: StackMap locals:
StackMap stack:
aload 7
invokeinterface org.jruby.runtime.builtin.IRubyObject.isTrue:()Z
istore 5
10: aload 6
iconst_1
aaload
astore 8
start local 8 11: aload 8
ifnull 16
12: aload 8
invokestatic org.jruby.util.TypeConverter.checkID:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubySymbol;
astore 8
13: aload 8
aload 3
ldc "bottom"
invokevirtual org.jruby.Ruby.newSymbol:(Ljava/lang/String;)Lorg/jruby/RubySymbol;
if_acmpne 14
goto 16
14: StackMap locals: org.jruby.runtime.builtin.IRubyObject
StackMap stack:
aload 8
aload 3
ldc "top"
invokevirtual org.jruby.Ruby.newSymbol:(Ljava/lang/String;)Lorg/jruby/RubySymbol;
if_acmpne 15
goto 16
15: StackMap locals:
StackMap stack:
aload 3
new java.lang.StringBuilder
dup
ldc "expected :top or :bottom as order: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 8
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 end local 7 end local 6 16: StackMap locals:
StackMap stack:
aload 1
iload 5
invokestatic org.jruby.runtime.backtrace.TraceType.printBacktraceMRI:(Lorg/jruby/runtime/builtin/IRubyObject;Z)Ljava/lang/String;
areturn
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 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 start local 1 0: aload 0
invokeinterface org.jruby.runtime.builtin.IRubyObject.getRuntime:()Lorg/jruby/Ruby;
astore 2
start local 2 1: aload 2
invokevirtual org.jruby.Ruby.getCurrentContext:()Lorg/jruby/runtime/ThreadContext;
astore 3
start local 3 2: aload 0
aload 3
ldc "backtrace"
invokeinterface org.jruby.runtime.builtin.IRubyObject.callMethod:(Lorg/jruby/runtime/ThreadContext;Ljava/lang/String;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 4
start local 4 3: new java.io.ByteArrayOutputStream
dup
invokespecial java.io.ByteArrayOutputStream.<init>:()V
astore 5
start local 5 4: new java.io.PrintStream
dup
aload 5
invokespecial java.io.PrintStream.<init>:(Ljava/io/OutputStream;)V
astore 6
start local 6 5: iconst_0
istore 7
start local 7 6: aload 4
invokeinterface org.jruby.runtime.builtin.IRubyObject.isNil:()Z
ifne 7
aload 4
instanceof org.jruby.RubyArray
ifne 14
7: 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
invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
ifnull 11
aload 3
invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
invokevirtual java.lang.String.length:()I
ifle 11
8: aload 6
new java.lang.StringBuilder
dup
aload 3
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
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: iconst_1
istore 7
10: goto 23
11: StackMap locals:
StackMap stack:
aload 6
aload 3
invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
invokevirtual java.io.PrintStream.print:(I)V
12: iconst_1
istore 7
13: goto 23
StackMap locals:
StackMap stack:
14: aload 4
checkcast org.jruby.RubyArray
invokevirtual org.jruby.RubyArray.getLength:()I
ifne 17
15: aload 3
aload 6
invokestatic org.jruby.runtime.backtrace.TraceType.printErrorPos:(Lorg/jruby/runtime/ThreadContext;Ljava/io/PrintStream;)V
16: goto 23
17: StackMap locals:
StackMap stack:
aload 4
checkcast org.jruby.RubyArray
invokevirtual org.jruby.RubyArray.first:()Lorg/jruby/runtime/builtin/IRubyObject;
astore 8
start local 8 18: aload 8
invokeinterface org.jruby.runtime.builtin.IRubyObject.isNil:()Z
ifeq 21
19: aload 3
aload 6
invokestatic org.jruby.runtime.backtrace.TraceType.printErrorPos:(Lorg/jruby/runtime/ThreadContext;Ljava/io/PrintStream;)V
20: goto 23
21: StackMap locals: org.jruby.runtime.builtin.IRubyObject
StackMap stack:
aload 6
aload 8
invokevirtual java.io.PrintStream.print:(Ljava/lang/Object;)V
22: iconst_1
istore 7
end local 8 23: StackMap locals:
StackMap stack:
aload 0
invokeinterface org.jruby.runtime.builtin.IRubyObject.getMetaClass:()Lorg/jruby/RubyClass;
astore 8
start local 8 24: aload 0
invokevirtual java.lang.Object.toString:()Ljava/lang/String;
astore 9
start local 9 25: aload 8
aload 2
invokevirtual org.jruby.Ruby.getRuntimeError:()Lorg/jruby/RubyClass;
if_acmpne 28
aload 9
ifnull 26
aload 9
invokevirtual java.lang.String.length:()I
ifne 28
26: StackMap locals: org.jruby.RubyClass java.lang.String
StackMap stack:
aload 6
ldc ": unhandled exception\n"
invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
27: goto 47
28: StackMap locals:
StackMap stack:
iload 7
ifeq 29
aload 6
ldc ": "
invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
29: StackMap locals:
StackMap stack:
aload 8
invokevirtual org.jruby.RubyClass.getName:()Ljava/lang/String;
astore 10
start local 10 30: aload 9
invokevirtual java.lang.String.length:()I
ifne 33
31: aload 6
new java.lang.StringBuilder
dup
aload 10
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: goto 47
33: StackMap locals: java.lang.String
StackMap stack:
aload 10
ldc "#"
invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
ifeq 35
34: aconst_null
astore 10
35: StackMap locals:
StackMap stack:
aconst_null
astore 11
start local 11 36: aload 9
bipush 10
invokevirtual java.lang.String.indexOf:(I)I
istore 12
start local 12 37: iload 12
iconst_m1
if_icmpeq 40
38: aload 9
iload 12
iconst_1
iadd
invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
astore 11
39: aload 9
iconst_0
iload 12
invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
astore 9
40: StackMap locals: java.lang.String int
StackMap stack:
aload 6
aload 9
invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
41: aload 10
ifnull 44
42: aload 6
new java.lang.StringBuilder
dup
ldc " ("
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 10
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: goto 45
44: StackMap locals:
StackMap stack:
aload 6
bipush 10
invokevirtual java.io.PrintStream.print:(C)V
45: StackMap locals:
StackMap stack:
aload 11
ifnull 47
46: aload 6
new java.lang.StringBuilder
dup
aload 11
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 end local 11 end local 10 47: StackMap locals:
StackMap stack:
aload 4
aload 6
iconst_1
invokestatic org.jruby.runtime.backtrace.TraceType.printBacktraceToStream:(Lorg/jruby/runtime/builtin/IRubyObject;Ljava/io/PrintStream;I)V
48: aload 5
invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
areturn
end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 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 start local 1 start local 2 start local 3 start local 4 0: aload 1
ifnonnull 1
getstatic org.jruby.runtime.backtrace.RubyStackTraceElement.EMPTY_ARRAY:[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
astore 1
1: StackMap locals:
StackMap stack:
new java.lang.StringBuilder
dup
bipush 64
aload 1
arraylength
bipush 48
imul
iadd
invokespecial java.lang.StringBuilder.<init>:(I)V
astore 5
start local 5 2: aload 5
aload 2
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
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
bipush 10
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
3: aload 0
aload 1
aload 5
iload 4
invokestatic org.jruby.runtime.backtrace.TraceType.renderBacktraceJRuby:(Lorg/jruby/Ruby;[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/StringBuilder;Z)V
4: aload 5
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 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 start local 1 0: aload 0
invokevirtual org.jruby.RubyException.getRuntime:()Lorg/jruby/Ruby;
astore 2
start local 2 1: aload 2
invokevirtual org.jruby.Ruby.getCurrentContext:()Lorg/jruby/runtime/ThreadContext;
astore 3
start local 3 2: iload 1
ifeq 3
aload 2
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
start local 4 5: aload 0
aload 3
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
start local 5 6: goto 9
end local 5 StackMap locals: org.jruby.RubyException int org.jruby.Ruby org.jruby.runtime.ThreadContext int
StackMap stack: org.jruby.exceptions.Exception
7: pop
8: aload 0
aload 3
invokevirtual org.jruby.RubyException.message:(Lorg/jruby/runtime/ThreadContext;)Lorg/jruby/runtime/builtin/IRubyObject;
invokevirtual java.lang.Object.toString:()Ljava/lang/String;
astore 5
start local 5 9: StackMap locals: java.lang.String
StackMap stack:
aload 0
invokevirtual org.jruby.RubyException.getMetaClass:()Lorg/jruby/RubyClass;
aload 2
invokevirtual org.jruby.Ruby.getRuntimeError:()Lorg/jruby/RubyClass;
if_acmpne 11
aload 5
invokevirtual java.lang.String.length:()I
ifne 11
10: ldc "No current exception"
astore 5
11: StackMap locals:
StackMap stack:
aload 0
invokevirtual org.jruby.RubyException.getMetaClass:()Lorg/jruby/RubyClass;
invokevirtual org.jruby.RubyClass.getName:()Ljava/lang/String;
astore 6
start local 6 12: aload 0
invokevirtual org.jruby.RubyException.getRuntime:()Lorg/jruby/Ruby;
aload 0
invokevirtual org.jruby.RubyException.getBacktraceElements:()[Lorg/jruby/runtime/backtrace/RubyStackTraceElement;
aload 6
aload 5
iload 4
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 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 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 start local 1 start local 2 start local 3 0: iconst_0
istore 4
start local 4 1: aload 1
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
start local 5 3: iload 4
aload 5
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
end local 5 4: iinc 6 1
StackMap locals:
StackMap stack:
5: iload 6
iload 7
if_icmplt 2
6: iconst_1
istore 5
start local 5 7: aload 1
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
start local 6 9: iload 3
ifeq 19
10: iload 5
ifeq 13
11: aload 2
ldc "\u001B[0;31m"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
12: 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
invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.isBinding:()Z
ifne 14
aload 6
invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getFileName:()Ljava/lang/String;
ldc "(eval)"
invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
ifeq 16
14: StackMap locals:
StackMap stack:
aload 2
ldc "\u001B[0;33m"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
15: goto 18
StackMap locals:
StackMap stack:
16: aload 6
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: aload 2
ldc "\u001B[0;36m"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
18: StackMap locals:
StackMap stack:
iconst_0
istore 5
19: StackMap locals:
StackMap stack:
aload 2
ldc " "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
20: aload 0
ifnonnull 21
aload 6
invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getMethodName:()Ljava/lang/String;
goto 22
StackMap locals:
StackMap stack:
21: aload 0
aload 6
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
start local 10 23: iconst_0
istore 11
start local 11 24: goto 27
25: StackMap locals: java.lang.String int
StackMap stack:
aload 2
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
26: iinc 11 1
StackMap locals:
StackMap stack:
27: iload 11
iload 4
aload 10
invokevirtual java.lang.String.length:()I
isub
if_icmplt 25
end local 11 28: aload 2
29: aload 10
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
30: ldc " at "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
31: aload 6
invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getFileName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
32: bipush 58
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
33: aload 6
invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getLineNumber:()I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
pop
34: iload 3
ifeq 36
35: aload 2
ldc "\u001B[0m"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
36: StackMap locals:
StackMap stack:
aload 2
37: bipush 10
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
end local 10 end local 6 38: 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: return
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 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 start local 1 start local 2 0: aload 0
ldc ""
aload 1
iload 2
invokestatic org.jruby.runtime.backtrace.TraceType.renderBacktraceMRI:([Lorg/jruby/runtime/backtrace/RubyStackTraceElement;Ljava/lang/String;Ljava/lang/StringBuilder;Z)V
1: return
end local 2 end local 1 end local 0 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 start local 1 start local 2 start local 3 0: iconst_0
istore 4
start local 4 1: goto 12
2: StackMap locals: int
StackMap stack:
aload 0
iload 4
aaload
astore 5
start local 5 3: aload 2
4: aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
5: aload 5
invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getFileName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
6: bipush 58
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
7: aload 5
invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getLineNumber:()I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
8: ldc ":in `"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
9: aload 5
invokevirtual org.jruby.runtime.backtrace.RubyStackTraceElement.getMethodName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
10: ldc "'\n"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
end local 5 11: iinc 4 1
StackMap locals:
StackMap stack:
12: iload 4
aload 0
arraylength
if_icmplt 2
end local 4 13: return
end local 3 end local 2 end local 1 end local 0 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 start local 1 0: aload 0
invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
ifnull 9
aload 0
invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
invokevirtual java.lang.String.length:()I
ifle 9
1: aload 0
invokevirtual org.jruby.runtime.ThreadContext.getFrameName:()Ljava/lang/String;
ifnull 5
2: aload 1
new java.lang.StringBuilder
dup
aload 0
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
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: aload 1
new java.lang.StringBuilder
dup
ldc ":in '"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
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: goto 9
StackMap locals:
StackMap stack:
5: aload 0
invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
ifeq 8
6: aload 1
new java.lang.StringBuilder
dup
aload 0
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
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: goto 9
8: StackMap locals:
StackMap stack:
aload 1
aload 0
invokevirtual org.jruby.runtime.ThreadContext.getFile:()Ljava/lang/String;
invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
9: StackMap locals:
StackMap stack:
return
end local 1 end local 0 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 start local 1 start local 2 0: aload 0
invokeinterface org.jruby.runtime.builtin.IRubyObject.isNil:()Z
ifeq 1
return
1: StackMap locals:
StackMap stack:
aload 0
instanceof org.jruby.RubyArray
ifeq 12
2: aload 0
checkcast org.jruby.RubyArray
invokevirtual org.jruby.RubyArray.toJavaArrayMaybeUnsafe:()[Lorg/jruby/runtime/builtin/IRubyObject;
astore 3
start local 3 3: iload 2
istore 4
start local 4 4: goto 11
5: StackMap locals: org.jruby.runtime.builtin.IRubyObject[] int
StackMap stack:
aload 3
iload 4
aaload
astore 5
start local 5 6: aload 5
instanceof org.jruby.RubyString
ifeq 9
7: aload 1
new java.lang.StringBuilder
dup
ldc "\tfrom "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 5
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: goto 10
9: StackMap locals: org.jruby.runtime.builtin.IRubyObject
StackMap stack:
aload 1
new java.lang.StringBuilder
dup
ldc "\t"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 5
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 10: StackMap locals:
StackMap stack:
iinc 4 1
StackMap locals:
StackMap stack:
11: iload 4
aload 3
arraylength
if_icmplt 5
end local 4 end local 3 12: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 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 start local 1 0: aload 1
ifnonnull 1
aload 0
invokevirtual org.jruby.Ruby.getNil:()Lorg/jruby/runtime/builtin/IRubyObject;
areturn
1: StackMap locals:
StackMap stack:
aload 0
invokevirtual org.jruby.Ruby.getCurrentContext:()Lorg/jruby/runtime/ThreadContext;
astore 2
start local 2 2: aload 1
arraylength
anewarray org.jruby.runtime.builtin.IRubyObject
astore 3
start local 3 3: iconst_0
istore 4
start local 4 4: goto 7
5: StackMap locals: org.jruby.runtime.ThreadContext org.jruby.runtime.builtin.IRubyObject[] int
StackMap stack:
aload 3
iload 4
aload 2
aload 1
iload 4
aaload
invokestatic org.jruby.runtime.backtrace.RubyStackTraceElement.to_s_mri:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/backtrace/RubyStackTraceElement;)Lorg/jruby/RubyString;
aastore
6: iinc 4 1
StackMap locals:
StackMap stack:
7: iload 4
aload 1
arraylength
if_icmplt 5
end local 4 8: aload 0
aload 3
invokestatic org.jruby.RubyArray.newArrayMayCopy:(Lorg/jruby/Ruby;[Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyArray;
areturn
end local 3 end local 2 end local 1 end local 0 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 start local 1 start local 2 0: aload 0
aload 1
invokevirtual org.jruby.runtime.backtrace.TraceType.getBacktrace:(Lorg/jruby/runtime/ThreadContext;)Lorg/jruby/runtime/backtrace/BacktraceData;
aload 1
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
start local 3 1: aload 3
arraylength
iload 2
iconst_1
iadd
if_icmpgt 2
iconst_m1
istore 2
2: StackMap locals: org.jruby.runtime.backtrace.RubyStackTraceElement[]
StackMap stack:
aload 3
iload 2
iconst_1
iadd
aaload
areturn
end local 3 end local 2 end local 1 end local 0 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