public class com.oracle.truffle.sl.test.SLDebugALot
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: com.oracle.truffle.sl.test.SLDebugALot
  super_class: java.lang.Object
{
  private final org.graalvm.polyglot.Source slCode;
    descriptor: Lorg/graalvm/polyglot/Source;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.io.ByteArrayOutputStream out;
    descriptor: Ljava/io/ByteArrayOutputStream;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.io.ByteArrayOutputStream err;
    descriptor: Ljava/io/ByteArrayOutputStream;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.oracle.truffle.sl.test.SLDebugALot this
         0: .line 54
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 56
            aload 0 /* this */
            ldc "sl"
            ldc "function main() {\n  n = 2;\n  return types(n);\n}\nfunction doNull() {}\nfunction compute(n, l) {\n  z = new();\n  z.a = n + l;\n  z.b = z;\n  z.c = n - l;\n  return z;\n}\nfunction types(n) {\n  a = 1;\n  b = n + a;\n  c = \"string\";\n  d = doNull();\n  e = 10 == 10;\n  f = new();\n  f.p1 = 1;\n  f.p2 = new();\n  f.p2.p21 = 21;\n  g = doNull;\n  i = 0;\n  while (i < n) {\n    b = b * i;\n    l = b + i;\n    z = compute(n, l);\n    a = a + z.a;\n    i = i + 1;\n  }\n  return n * a;\n}\n"
            invokestatic org.graalvm.polyglot.Source.create:(Ljava/lang/String;Ljava/lang/CharSequence;)Lorg/graalvm/polyglot/Source;
            putfield com.oracle.truffle.sl.test.SLDebugALot.slCode:Lorg/graalvm/polyglot/Source;
         2: .line 90
            aload 0 /* this */
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            putfield com.oracle.truffle.sl.test.SLDebugALot.out:Ljava/io/ByteArrayOutputStream;
         3: .line 91
            aload 0 /* this */
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            putfield com.oracle.truffle.sl.test.SLDebugALot.err:Ljava/io/ByteArrayOutputStream;
         4: .line 54
            return
        end local 0 // com.oracle.truffle.sl.test.SLDebugALot this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lcom/oracle/truffle/sl/test/SLDebugALot;

  public void test();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=7, args_size=1
        start local 0 // com.oracle.truffle.sl.test.SLDebugALot this
         0: .line 95
            aconst_null
            astore 1
            aconst_null
            astore 2
         1: invokestatic org.graalvm.polyglot.Engine.newBuilder:()Lorg/graalvm/polyglot/Engine$Builder;
            aload 0 /* this */
            getfield com.oracle.truffle.sl.test.SLDebugALot.out:Ljava/io/ByteArrayOutputStream;
            invokevirtual org.graalvm.polyglot.Engine$Builder.out:(Ljava/io/OutputStream;)Lorg/graalvm/polyglot/Engine$Builder;
            aload 0 /* this */
            getfield com.oracle.truffle.sl.test.SLDebugALot.err:Ljava/io/ByteArrayOutputStream;
            invokevirtual org.graalvm.polyglot.Engine$Builder.err:(Ljava/io/OutputStream;)Lorg/graalvm/polyglot/Engine$Builder;
            iconst_1
            invokevirtual org.graalvm.polyglot.Engine$Builder.allowExperimentalOptions:(Z)Lorg/graalvm/polyglot/Engine$Builder;
            ldc "debugalot"
            ldc "true"
            invokevirtual org.graalvm.polyglot.Engine$Builder.option:(Ljava/lang/String;Ljava/lang/String;)Lorg/graalvm/polyglot/Engine$Builder;
            invokevirtual org.graalvm.polyglot.Engine$Builder.build:()Lorg/graalvm/polyglot/Engine;
            astore 3 /* engine */
        start local 3 // org.graalvm.polyglot.Engine engine
         2: .line 96
            aconst_null
            astore 4
            aconst_null
            astore 5
         3: iconst_0
            anewarray java.lang.String
            invokestatic org.graalvm.polyglot.Context.newBuilder:([Ljava/lang/String;)Lorg/graalvm/polyglot/Context$Builder;
            aload 3 /* engine */
            invokevirtual org.graalvm.polyglot.Context$Builder.engine:(Lorg/graalvm/polyglot/Engine;)Lorg/graalvm/polyglot/Context$Builder;
            invokevirtual org.graalvm.polyglot.Context$Builder.build:()Lorg/graalvm/polyglot/Context;
            astore 6 /* context */
        start local 6 // org.graalvm.polyglot.Context context
         4: .line 97
            aload 6 /* context */
            aload 0 /* this */
            getfield com.oracle.truffle.sl.test.SLDebugALot.slCode:Lorg/graalvm/polyglot/Source;
            invokevirtual org.graalvm.polyglot.Context.eval:(Lorg/graalvm/polyglot/Source;)Lorg/graalvm/polyglot/Value;
            pop
         5: .line 98
            aload 6 /* context */
            ifnull 11
            aload 6 /* context */
            invokevirtual org.graalvm.polyglot.Context.close:()V
            goto 11
      StackMap locals: com.oracle.truffle.sl.test.SLDebugALot java.lang.Throwable java.lang.Throwable org.graalvm.polyglot.Engine java.lang.Throwable java.lang.Throwable org.graalvm.polyglot.Context
      StackMap stack: java.lang.Throwable
         6: astore 4
            aload 6 /* context */
            ifnull 7
            aload 6 /* context */
            invokevirtual org.graalvm.polyglot.Context.close:()V
        end local 6 // org.graalvm.polyglot.Context context
      StackMap locals:
      StackMap stack:
         7: aload 4
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
         8: astore 5
            aload 4
            ifnonnull 9
            aload 5
            astore 4
            goto 10
      StackMap locals:
      StackMap stack:
         9: aload 4
            aload 5
            if_acmpeq 10
            aload 4
            aload 5
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        10: aload 4
            athrow
        11: .line 99
      StackMap locals:
      StackMap stack:
            aload 3 /* engine */
            ifnull 17
            aload 3 /* engine */
            invokevirtual org.graalvm.polyglot.Engine.close:()V
            goto 17
      StackMap locals:
      StackMap stack: java.lang.Throwable
        12: astore 1
            aload 3 /* engine */
            ifnull 13
            aload 3 /* engine */
            invokevirtual org.graalvm.polyglot.Engine.close:()V
        end local 3 // org.graalvm.polyglot.Engine engine
      StackMap locals:
      StackMap stack:
        13: aload 1
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        14: astore 2
            aload 1
            ifnonnull 15
            aload 2
            astore 1
            goto 16
      StackMap locals:
      StackMap stack:
        15: aload 1
            aload 2
            if_acmpeq 16
            aload 1
            aload 2
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        16: aload 1
            athrow
        17: .line 100
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.oracle.truffle.sl.test.SLDebugALot.out:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.toString:()Ljava/lang/String;
            astore 1 /* log */
        start local 1 // java.lang.String log
        18: .line 101
            ldc "Executed successfully:"
            astore 2 /* successMessage */
        start local 2 // java.lang.String successMessage
        19: .line 102
            aload 1 /* log */
            aload 2 /* successMessage */
            invokevirtual java.lang.String.lastIndexOf:(Ljava/lang/String;)I
            istore 3 /* index */
        start local 3 // int index
        20: .line 103
            aload 1 /* log */
            iload 3 /* index */
            ifle 21
            iconst_1
            goto 22
      StackMap locals: com.oracle.truffle.sl.test.SLDebugALot java.lang.String java.lang.String int
      StackMap stack: java.lang.String
        21: iconst_0
      StackMap locals: com.oracle.truffle.sl.test.SLDebugALot java.lang.String java.lang.String int
      StackMap stack: java.lang.String int
        22: invokestatic org.junit.Assert.assertTrue:(Ljava/lang/String;Z)V
        23: .line 104
            aload 1 /* log */
            iload 3 /* index */
            aload 2 /* successMessage */
            invokevirtual java.lang.String.length:()I
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            invokevirtual java.lang.String.trim:()Ljava/lang/String;
            astore 4 /* success */
        start local 4 // java.lang.String success
        24: .line 105
            aload 1 /* log */
            ldc "TRUE"
            aload 4 /* success */
            invokestatic org.junit.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        25: .line 106
            return
        end local 4 // java.lang.String success
        end local 3 // int index
        end local 2 // java.lang.String successMessage
        end local 1 // java.lang.String log
        end local 0 // com.oracle.truffle.sl.test.SLDebugALot this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   26     0            this  Lcom/oracle/truffle/sl/test/SLDebugALot;
            2   13     3          engine  Lorg/graalvm/polyglot/Engine;
            4    7     6         context  Lorg/graalvm/polyglot/Context;
           18   26     1             log  Ljava/lang/String;
           19   26     2  successMessage  Ljava/lang/String;
           20   26     3           index  I
           24   26     4         success  Ljava/lang/String;
      Exception table:
        from    to  target  type
           4     5       6  any
           3     8       8  any
           2    11      12  any
           1    14      14  any
    RuntimeVisibleAnnotations: 
      org.junit.Test()
}
SourceFile: "SLDebugALot.java"
InnerClasses:
  public final Builder = org.graalvm.polyglot.Context$Builder of org.graalvm.polyglot.Context
  public final Builder = org.graalvm.polyglot.Engine$Builder of org.graalvm.polyglot.Engine