public class org.hsqldb.test.TestUtil
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.hsqldb.test.TestUtil
  super_class: java.lang.Object
{
  private static final java.text.SimpleDateFormat sdfYMDHMS;
    descriptor: Ljava/text/SimpleDateFormat;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static boolean abortOnErr;
    descriptor: Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static final java.lang.String TIMESTAMP_VAR_STR;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "${timestamp}"

  static final java.lang.String LS;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final boolean oneSessionOnly;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 74
            new java.text.SimpleDateFormat
            dup
            ldc "yyyy-MM-dd HH:mm:ss"
            invokespecial java.text.SimpleDateFormat.<init>:(Ljava/lang/String;)V
         1: .line 73
            putstatic org.hsqldb.test.TestUtil.sdfYMDHMS:Ljava/text/SimpleDateFormat;
         2: .line 75
            iconst_0
            putstatic org.hsqldb.test.TestUtil.abortOnErr:Z
         3: .line 77
            ldc "line.separator"
            ldc "\n"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
            putstatic org.hsqldb.test.TestUtil.LS:Ljava/lang/String;
         4: .line 78
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.hsqldb.test.TestUtil this
         0: .line 67
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.hsqldb.test.TestUtil this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/hsqldb/test/TestUtil;

  public static void main(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // java.lang.String[] argv
         0: .line 82
            new org.hsqldb.lib.StopWatch
            dup
            iconst_1
            invokespecial org.hsqldb.lib.StopWatch.<init>:(Z)V
            astore 1 /* sw */
        start local 1 // org.hsqldb.lib.StopWatch sw
         1: .line 84
            ldc "testrun/hsqldb"
            aload 1 /* sw */
            invokestatic org.hsqldb.test.TestUtil.testScripts:(Ljava/lang/String;Lorg/hsqldb/lib/StopWatch;)V
         2: .line 85
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 1 /* sw */
            ldc "Total time :"
            invokevirtual org.hsqldb.lib.StopWatch.currentElapsedTimeToMessage:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         3: .line 86
            return
        end local 1 // org.hsqldb.lib.StopWatch sw
        end local 0 // java.lang.String[] argv
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  argv  [Ljava/lang/String;
            1    4     1    sw  Lorg/hsqldb/lib/StopWatch;
    MethodParameters:
      Name  Flags
      argv  

  public static void deleteDatabase(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.lang.String path
         0: .line 89
            aload 0 /* path */
            invokestatic org.hsqldb.lib.FileUtil.deleteOrRenameDatabaseFiles:(Ljava/lang/String;)Z
            pop
         1: .line 90
            return
        end local 0 // java.lang.String path
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  path  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      path  

  public static boolean delete(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // java.lang.String file
         0: .line 93
            new java.io.File
            dup
            aload 0 /* file */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            invokevirtual java.io.File.delete:()Z
            ireturn
        end local 0 // java.lang.String file
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  file  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      file  

  public static void checkDatabaseFilesDeleted(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // java.lang.String path
         0: .line 98
            aload 0 /* path */
            invokestatic org.hsqldb.lib.FileUtil.getDatabaseFileList:(Ljava/lang/String;)[Ljava/io/File;
            astore 1 /* list */
        start local 1 // java.io.File[] list
         1: .line 100
            aload 1 /* list */
            arraylength
            ifeq 3
         2: .line 101
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "database files not deleted"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         3: .line 103
      StackMap locals: java.io.File[]
      StackMap stack:
            return
        end local 1 // java.io.File[] list
        end local 0 // java.lang.String path
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  path  Ljava/lang/String;
            1    4     1  list  [Ljava/io/File;
    MethodParameters:
      Name  Flags
      path  

  protected static void expandStamps(java.lang.StringBuilder);
    descriptor: (Ljava/lang/StringBuilder;)V
    flags: (0x000c) ACC_PROTECTED, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // java.lang.StringBuilder sb
         0: .line 110
            aload 0 /* sb */
            ldc "${timestamp}"
            invokevirtual java.lang.StringBuilder.indexOf:(Ljava/lang/String;)I
            istore 1 /* i */
        start local 1 // int i
         1: .line 112
            iload 1 /* i */
            iconst_1
            if_icmpge 3
         2: .line 113
            return
         3: .line 118
      StackMap locals: int
      StackMap stack:
            getstatic org.hsqldb.test.TestUtil.sdfYMDHMS:Ljava/text/SimpleDateFormat;
            dup
            astore 3
            monitorenter
         4: .line 119
            getstatic org.hsqldb.test.TestUtil.sdfYMDHMS:Ljava/text/SimpleDateFormat;
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            invokevirtual java.text.SimpleDateFormat.format:(Ljava/util/Date;)Ljava/lang/String;
            astore 2 /* timestamp */
        start local 2 // java.lang.String timestamp
         5: .line 118
            aload 3
            monitorexit
         6: goto 11
        end local 2 // java.lang.String timestamp
      StackMap locals: java.lang.StringBuilder int top java.text.SimpleDateFormat
      StackMap stack: java.lang.Throwable
         7: aload 3
            monitorexit
         8: athrow
        start local 2 // java.lang.String timestamp
         9: .line 123
      StackMap locals: java.lang.StringBuilder int java.lang.String
      StackMap stack:
            aload 0 /* sb */
            iload 1 /* i */
            iload 1 /* i */
            ldc "${timestamp}"
            invokevirtual java.lang.String.length:()I
            iadd
            aload 2 /* timestamp */
            invokevirtual java.lang.StringBuilder.replace:(IILjava/lang/String;)Ljava/lang/StringBuilder;
            pop
        10: .line 125
            aload 0 /* sb */
            ldc "${timestamp}"
            invokevirtual java.lang.StringBuilder.indexOf:(Ljava/lang/String;)I
            istore 1 /* i */
        11: .line 122
      StackMap locals:
      StackMap stack:
            iload 1 /* i */
            iconst_m1
            if_icmpgt 9
        12: .line 127
            return
        end local 2 // java.lang.String timestamp
        end local 1 // int i
        end local 0 // java.lang.StringBuilder sb
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   13     0         sb  Ljava/lang/StringBuilder;
            1   13     1          i  I
            5    7     2  timestamp  Ljava/lang/String;
            9   13     2  timestamp  Ljava/lang/String;
      Exception table:
        from    to  target  type
           4     6       7  any
           7     8       7  any
    MethodParameters:
      Name  Flags
      sb    

  static void testScripts(java.lang.String, org.hsqldb.lib.StopWatch);
    descriptor: (Ljava/lang/String;Lorg/hsqldb/lib/StopWatch;)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=12, args_size=2
        start local 0 // java.lang.String directory
        start local 1 // org.hsqldb.lib.StopWatch sw
         0: .line 131
            ldc "test1"
            invokestatic org.hsqldb.test.TestUtil.deleteDatabase:(Ljava/lang/String;)V
         1: .line 134
            ldc "org.hsqldb.jdbc.JDBCDriver"
            invokestatic java.lang.Class.forName:(Ljava/lang/String;)Ljava/lang/Class;
            pop
         2: .line 136
            ldc "jdbc:hsqldb:test1;sql.enforce_strict_size=true"
            astore 2 /* url */
        start local 2 // java.lang.String url
         3: .line 137
            ldc "sa"
            astore 3 /* user */
        start local 3 // java.lang.String user
         4: .line 138
            ldc ""
            astore 4 /* password */
        start local 4 // java.lang.String password
         5: .line 139
            aconst_null
            astore 5 /* cConnection */
        start local 5 // java.sql.Connection cConnection
         6: .line 141
            new java.io.File
            dup
            aload 0 /* directory */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            invokevirtual java.io.File.getAbsolutePath:()Ljava/lang/String;
            astore 7 /* absolute */
        start local 7 // java.lang.String absolute
         7: .line 143
            new java.io.File
            dup
            aload 7 /* absolute */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            invokevirtual java.io.File.list:()[Ljava/lang/String;
            astore 6 /* filelist */
        start local 6 // java.lang.String[] filelist
         8: .line 145
            aload 6 /* filelist */
            aload 6 /* filelist */
            arraylength
         9: .line 146
            new org.hsqldb.lib.StringComparator
            dup
            invokespecial org.hsqldb.lib.StringComparator.<init>:()V
        10: .line 145
            invokestatic org.hsqldb.lib.ArraySort.sort:([Ljava/lang/Object;ILjava/util/Comparator;)V
        11: .line 148
            iconst_0
            istore 8 /* i */
        start local 8 // int i
        12: goto 26
        13: .line 149
      StackMap locals: java.lang.String org.hsqldb.lib.StopWatch java.lang.String java.lang.String java.lang.String java.sql.Connection java.lang.String[] java.lang.String int
      StackMap stack:
            aload 6 /* filelist */
            iload 8 /* i */
            aaload
            astore 9 /* fname */
        start local 9 // java.lang.String fname
        14: .line 151
            aload 9 /* fname */
            ldc "TestSelf"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 25
            aload 9 /* fname */
            ldc ".txt"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 25
        15: .line 152
            aload 1 /* sw */
            invokevirtual org.hsqldb.lib.StopWatch.elapsedTime:()J
            lstore 10 /* elapsed */
        start local 10 // long elapsed
        16: .line 155
            aload 2 /* url */
            aload 3 /* user */
        17: .line 156
            aload 4 /* password */
        18: .line 155
            invokestatic java.sql.DriverManager.getConnection:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/sql/Connection;
            astore 5 /* cConnection */
        19: .line 159
            new java.lang.StringBuilder
            dup
            ldc "Opened DB in "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        20: .line 160
            aload 1 /* sw */
            invokevirtual org.hsqldb.lib.StopWatch.elapsedTime:()J
            lload 10 /* elapsed */
            lsub
            l2d
            ldc 1000.0
            ddiv
            invokevirtual java.lang.StringBuilder.append:(D)Ljava/lang/StringBuilder;
        21: .line 161
            ldc " s"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        22: .line 159
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.hsqldb.test.TestUtil.print:(Ljava/lang/String;)V
        23: .line 162
            aload 5 /* cConnection */
            new java.lang.StringBuilder
            dup
            aload 7 /* absolute */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            getstatic java.io.File.separator:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 9 /* fname */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.hsqldb.test.TestUtil.testScript:(Ljava/sql/Connection;Ljava/lang/String;)V
        24: .line 165
            aload 5 /* cConnection */
            invokeinterface java.sql.Connection.close:()V
        end local 10 // long elapsed
        end local 9 // java.lang.String fname
        25: .line 148
      StackMap locals:
      StackMap stack:
            iinc 8 /* i */ 1
      StackMap locals:
      StackMap stack:
        26: iload 8 /* i */
            aload 6 /* filelist */
            arraylength
            if_icmplt 13
        end local 8 // int i
        end local 7 // java.lang.String absolute
        end local 6 // java.lang.String[] filelist
        end local 5 // java.sql.Connection cConnection
        end local 4 // java.lang.String password
        end local 3 // java.lang.String user
        end local 2 // java.lang.String url
        27: .line 169
            goto 31
      StackMap locals: java.lang.String org.hsqldb.lib.StopWatch
      StackMap stack: java.lang.Exception
        28: astore 2 /* e */
        start local 2 // java.lang.Exception e
        29: .line 170
            aload 2 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        30: .line 171
            new java.lang.StringBuilder
            dup
            ldc "TestUtil init error: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* e */
            invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.hsqldb.test.TestUtil.print:(Ljava/lang/String;)V
        end local 2 // java.lang.Exception e
        31: .line 173
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.hsqldb.lib.StopWatch sw
        end local 0 // java.lang.String directory
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   32     0    directory  Ljava/lang/String;
            0   32     1           sw  Lorg/hsqldb/lib/StopWatch;
            3   27     2          url  Ljava/lang/String;
            4   27     3         user  Ljava/lang/String;
            5   27     4     password  Ljava/lang/String;
            6   27     5  cConnection  Ljava/sql/Connection;
            8   27     6     filelist  [Ljava/lang/String;
            7   27     7     absolute  Ljava/lang/String;
           12   27     8            i  I
           14   25     9        fname  Ljava/lang/String;
           16   25    10      elapsed  J
           29   31     2            e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1    27      28  Class java.lang.Exception
    MethodParameters:
           Name  Flags
      directory  
      sw         

  static void testScript(java.sql.Connection, java.lang.String);
    descriptor: (Ljava/sql/Connection;Ljava/lang/String;)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // java.sql.Connection aConnection
        start local 1 // java.lang.String aPath
         0: .line 182
            new java.io.File
            dup
            aload 1 /* aPath */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 2 /* file */
        start local 2 // java.io.File file
         1: .line 185
            aload 0 /* aConnection */
            aload 2 /* file */
            invokevirtual java.io.File.getAbsolutePath:()Ljava/lang/String;
         2: .line 186
            new java.io.FileReader
            dup
            aload 2 /* file */
            invokespecial java.io.FileReader.<init>:(Ljava/io/File;)V
         3: .line 185
            invokestatic org.hsqldb.test.TestUtil.testScript:(Ljava/sql/Connection;Ljava/lang/String;Ljava/io/Reader;)V
         4: .line 187
            goto 8
      StackMap locals: java.sql.Connection java.lang.String java.io.File
      StackMap stack: java.lang.Exception
         5: astore 3 /* e */
        start local 3 // java.lang.Exception e
         6: .line 188
            aload 3 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
         7: .line 189
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "test script file error: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* e */
            invokevirtual java.lang.Exception.toString:()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
        end local 3 // java.lang.Exception e
         8: .line 191
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.io.File file
        end local 1 // java.lang.String aPath
        end local 0 // java.sql.Connection aConnection
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    9     0  aConnection  Ljava/sql/Connection;
            0    9     1        aPath  Ljava/lang/String;
            1    9     2         file  Ljava/io/File;
            6    8     3            e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1     4       5  Class java.lang.Exception
    MethodParameters:
             Name  Flags
      aConnection  
      aPath        

  public static void testScript(java.sql.Connection, java.lang.String, java.io.Reader);
    descriptor: (Ljava/sql/Connection;Ljava/lang/String;Ljava/io/Reader;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=8, args_size=3
        start local 0 // java.sql.Connection aConnection
        start local 1 // java.lang.String sourceName
        start local 2 // java.io.Reader inReader
         0: .line 209
            aload 0 /* aConnection */
            invokeinterface java.sql.Connection.createStatement:()Ljava/sql/Statement;
            astore 3 /* statement */
        start local 3 // java.sql.Statement statement
         1: .line 210
            new java.io.LineNumberReader
            dup
            aload 2 /* inReader */
            invokespecial java.io.LineNumberReader.<init>:(Ljava/io/Reader;)V
            astore 4 /* reader */
        start local 4 // java.io.LineNumberReader reader
         2: .line 211
            new org.hsqldb.lib.LineGroupReader
            dup
            aload 4 /* reader */
            invokespecial org.hsqldb.lib.LineGroupReader.<init>:(Ljava/io/LineNumberReader;)V
            astore 5 /* sqlReader */
        start local 5 // org.hsqldb.lib.LineGroupReader sqlReader
         3: .line 212
            iconst_0
            istore 6 /* startLine */
        start local 6 // int startLine
         4: .line 214
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Opened test script file: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* sourceName */
            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
         5: .line 225
      StackMap locals: java.sql.Connection java.lang.String java.io.Reader java.sql.Statement java.io.LineNumberReader org.hsqldb.lib.LineGroupReader int
      StackMap stack:
            aload 5 /* sqlReader */
            invokevirtual org.hsqldb.lib.LineGroupReader.getSection:()Lorg/hsqldb/lib/HsqlArrayList;
            astore 7 /* section */
        start local 7 // org.hsqldb.lib.HsqlArrayList section
         6: .line 227
            aload 5 /* sqlReader */
            invokevirtual org.hsqldb.lib.LineGroupReader.getStartLineNumber:()I
            istore 6 /* startLine */
         7: .line 229
            aload 7 /* section */
            invokevirtual org.hsqldb.lib.HsqlArrayList.size:()I
            ifne 9
         8: .line 230
            goto 11
         9: .line 233
      StackMap locals: org.hsqldb.lib.HsqlArrayList
      StackMap stack:
            aload 3 /* statement */
            aload 7 /* section */
            aload 1 /* sourceName */
            iload 6 /* startLine */
            invokestatic org.hsqldb.test.TestUtil.testSection:(Ljava/sql/Statement;Lorg/hsqldb/lib/HsqlArrayList;Ljava/lang/String;I)V
        end local 7 // org.hsqldb.lib.HsqlArrayList section
        10: .line 224
            goto 5
        11: .line 236
      StackMap locals:
      StackMap stack:
            aload 3 /* statement */
            invokeinterface java.sql.Statement.close:()V
        12: .line 240
            goto 23
      StackMap locals:
      StackMap stack: java.sql.SQLException
        13: astore 7 /* se */
        start local 7 // java.sql.SQLException se
        14: .line 241
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Error encountered at command beginning at "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        15: .line 242
            aload 1 /* sourceName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            iload 6 /* startLine */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        16: .line 241
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        17: .line 244
            aload 7 /* se */
            athrow
        end local 7 // java.sql.SQLException se
        18: .line 245
      StackMap locals:
      StackMap stack: java.lang.RuntimeException
            astore 7 /* re */
        start local 7 // java.lang.RuntimeException re
        19: .line 246
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Error encountered at command beginning at "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        20: .line 247
            aload 1 /* sourceName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            iload 6 /* startLine */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        21: .line 246
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        22: .line 249
            aload 7 /* re */
            athrow
        end local 7 // java.lang.RuntimeException re
        23: .line 252
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Processed "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* reader */
            invokevirtual java.io.LineNumberReader.getLineNumber:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        24: .line 253
            ldc " lines from "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* sourceName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        25: .line 252
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        26: .line 254
            return
        end local 6 // int startLine
        end local 5 // org.hsqldb.lib.LineGroupReader sqlReader
        end local 4 // java.io.LineNumberReader reader
        end local 3 // java.sql.Statement statement
        end local 2 // java.io.Reader inReader
        end local 1 // java.lang.String sourceName
        end local 0 // java.sql.Connection aConnection
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   27     0  aConnection  Ljava/sql/Connection;
            0   27     1   sourceName  Ljava/lang/String;
            0   27     2     inReader  Ljava/io/Reader;
            1   27     3    statement  Ljava/sql/Statement;
            2   27     4       reader  Ljava/io/LineNumberReader;
            3   27     5    sqlReader  Lorg/hsqldb/lib/LineGroupReader;
            4   27     6    startLine  I
            6   10     7      section  Lorg/hsqldb/lib/HsqlArrayList;
           14   18     7           se  Ljava/sql/SQLException;
           19   23     7           re  Ljava/lang/RuntimeException;
      Exception table:
        from    to  target  type
           5    12      13  Class java.sql.SQLException
           5    12      18  Class java.lang.RuntimeException
    Exceptions:
      throws java.sql.SQLException, java.io.IOException
    MethodParameters:
             Name  Flags
      aConnection  
      sourceName   
      inReader     

  static void test(java.sql.Statement, java.lang.String, int);
    descriptor: (Ljava/sql/Statement;Ljava/lang/String;I)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // java.sql.Statement stat
        start local 1 // java.lang.String s
        start local 2 // int line
         0: .line 258
            aload 0 /* stat */
            aload 1 /* s */
            aconst_null
            iload 2 /* line */
            invokestatic org.hsqldb.test.TestUtil.test:(Ljava/sql/Statement;Ljava/lang/String;Ljava/lang/String;I)V
         1: .line 259
            return
        end local 2 // int line
        end local 1 // java.lang.String s
        end local 0 // java.sql.Statement stat
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  stat  Ljava/sql/Statement;
            0    2     1     s  Ljava/lang/String;
            0    2     2  line  I
    MethodParameters:
      Name  Flags
      stat  
      s     
      line  

  static void test(java.sql.Statement, java.lang.String, java.lang.String, int);
    descriptor: (Ljava/sql/Statement;Ljava/lang/String;Ljava/lang/String;I)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=5, args_size=4
        start local 0 // java.sql.Statement stat
        start local 1 // java.lang.String s
        start local 2 // java.lang.String sourceName
        start local 3 // int line
         0: .line 272
            new org.hsqldb.lib.HsqlArrayList
            dup
            bipush 8
            anewarray java.lang.String
            iconst_0
            invokespecial org.hsqldb.lib.HsqlArrayList.<init>:([Ljava/lang/Object;I)V
            astore 4 /* section */
        start local 4 // org.hsqldb.lib.HsqlArrayList section
         1: .line 274
            aload 4 /* section */
            aload 1 /* s */
            invokevirtual org.hsqldb.lib.HsqlArrayList.add:(Ljava/lang/Object;)Z
            pop
         2: .line 275
            aload 0 /* stat */
            aload 4 /* section */
            aload 2 /* sourceName */
            iload 3 /* line */
            invokestatic org.hsqldb.test.TestUtil.testSection:(Ljava/sql/Statement;Lorg/hsqldb/lib/HsqlArrayList;Ljava/lang/String;I)V
         3: .line 276
            return
        end local 4 // org.hsqldb.lib.HsqlArrayList section
        end local 3 // int line
        end local 2 // java.lang.String sourceName
        end local 1 // java.lang.String s
        end local 0 // java.sql.Statement stat
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0        stat  Ljava/sql/Statement;
            0    4     1           s  Ljava/lang/String;
            0    4     2  sourceName  Ljava/lang/String;
            0    4     3        line  I
            1    4     4     section  Lorg/hsqldb/lib/HsqlArrayList;
    MethodParameters:
            Name  Flags
      stat        
      s           
      sourceName  
      line        

  static void print(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String s
         0: .line 285
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 0 /* s */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         1: .line 286
            return
        end local 0 // java.lang.String s
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0     s  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      s     

  private static void testSection(java.sql.Statement, org.hsqldb.lib.HsqlArrayList, java.lang.String, int);
    descriptor: (Ljava/sql/Statement;Lorg/hsqldb/lib/HsqlArrayList;Ljava/lang/String;I)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // java.sql.Statement stat
        start local 1 // org.hsqldb.lib.HsqlArrayList section
        start local 2 // java.lang.String scriptName
        start local 3 // int line
         0: .line 305
            aload 1 /* section */
            invokestatic org.hsqldb.test.TestUtil.parsedSectionFactory:(Lorg/hsqldb/lib/HsqlArrayList;)Lorg/hsqldb/test/ParsedSection;
            astore 4 /* pSection */
        start local 4 // org.hsqldb.test.ParsedSection pSection
         1: .line 307
            aload 4 /* pSection */
            ifnonnull 8
         2: .line 308
            getstatic java.lang.System.out:Ljava/io/PrintStream;
         3: .line 309
            new java.lang.StringBuilder
            dup
            ldc "The section starting at "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* scriptName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            iload 3 /* line */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
         4: .line 310
            ldc " could not be parsed, and so was not processed."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic org.hsqldb.test.TestUtil.LS:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         5: .line 309
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         6: .line 308
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         7: .line 312
            return
         8: .line 315
      StackMap locals: org.hsqldb.test.ParsedSection
      StackMap stack:
            aload 4 /* pSection */
            instanceof org.hsqldb.test.IgnoreParsedSection
            ifeq 13
         9: .line 316
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "At "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* scriptName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            iload 3 /* line */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ": "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        10: .line 317
            aload 4 /* pSection */
            invokevirtual org.hsqldb.test.ParsedSection.getResultString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 316
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        12: .line 319
            return
        13: .line 322
      StackMap locals:
      StackMap stack:
            aload 4 /* pSection */
            instanceof org.hsqldb.test.DisplaySection
            ifne 16
        14: .line 323
            aload 4 /* pSection */
            instanceof org.hsqldb.test.WaitSection
            ifne 16
        15: .line 324
            aload 4 /* pSection */
            instanceof org.hsqldb.test.ProceedSection
            ifeq 19
        16: .line 325
      StackMap locals:
      StackMap stack:
            aload 4 /* pSection */
            invokevirtual org.hsqldb.test.ParsedSection.getResultString:()Ljava/lang/String;
            astore 5 /* s */
        start local 5 // java.lang.String s
        17: .line 327
            aload 5 /* s */
            ifnull 19
        18: .line 330
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 4 /* pSection */
            invokevirtual org.hsqldb.test.ParsedSection.getResultString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 5 // java.lang.String s
        19: .line 334
      StackMap locals:
      StackMap stack:
            aload 4 /* pSection */
            instanceof org.hsqldb.test.DisplaySection
            ifeq 21
        20: .line 335
            return
        21: .line 338
      StackMap locals:
      StackMap stack:
            aload 4 /* pSection */
            aload 0 /* stat */
            invokevirtual org.hsqldb.test.ParsedSection.test:(Ljava/sql/Statement;)Z
            ifne 30
        22: .line 339
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Section starting at "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* scriptName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 58
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
        23: .line 340
            iload 3 /* line */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " returned an unexpected result: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        24: .line 341
            aload 4 /* pSection */
            invokevirtual org.hsqldb.test.ParsedSection.getTestResultString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        25: .line 339
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        26: .line 343
            getstatic org.hsqldb.test.TestUtil.abortOnErr:Z
            ifeq 30
        27: .line 344
            new org.hsqldb.test.TestUtil$TestRuntimeException
            dup
            new java.lang.StringBuilder
            dup
            aload 2 /* scriptName */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ": "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 3 /* line */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        28: .line 345
            ldc "pSection"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        29: .line 344
            invokespecial org.hsqldb.test.TestUtil$TestRuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        30: .line 348
      StackMap locals:
      StackMap stack:
            return
        end local 4 // org.hsqldb.test.ParsedSection pSection
        end local 3 // int line
        end local 2 // java.lang.String scriptName
        end local 1 // org.hsqldb.lib.HsqlArrayList section
        end local 0 // java.sql.Statement stat
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   31     0        stat  Ljava/sql/Statement;
            0   31     1     section  Lorg/hsqldb/lib/HsqlArrayList;
            0   31     2  scriptName  Ljava/lang/String;
            0   31     3        line  I
            1   31     4    pSection  Lorg/hsqldb/test/ParsedSection;
           17   19     5           s  Ljava/lang/String;
    MethodParameters:
            Name  Flags
      stat        
      section     
      scriptName  
      line        

  private static org.hsqldb.test.ParsedSection parsedSectionFactory(org.hsqldb.lib.HsqlArrayList);
    descriptor: (Lorg/hsqldb/lib/HsqlArrayList;)Lorg/hsqldb/test/ParsedSection;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // org.hsqldb.lib.HsqlArrayList sectionLines
         0: .line 359
            bipush 32
            istore 1 /* type */
        start local 1 // char type
         1: .line 362
            aload 0 /* sectionLines */
            iconst_0
            invokevirtual org.hsqldb.lib.HsqlArrayList.get:(I)Ljava/lang/Object;
            checkcast java.lang.String
            astore 2 /* topLine */
        start local 2 // java.lang.String topLine
         2: .line 365
            aload 2 /* topLine */
            ldc "/*"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 9
         3: .line 366
            aload 2 /* topLine */
            iconst_2
            invokevirtual java.lang.String.charAt:(I)C
            istore 1 /* type */
         4: .line 370
            iload 1 /* type */
            invokestatic java.lang.Character.isUpperCase:(C)Z
            ifeq 7
         5: .line 371
            ldc "IgnoreCodeCase"
            invokestatic java.lang.Boolean.getBoolean:(Ljava/lang/String;)Z
            ifeq 7
         6: .line 372
            iload 1 /* type */
            invokestatic java.lang.Character.toLowerCase:(C)C
            istore 1 /* type */
         7: .line 376
      StackMap locals: int java.lang.String
      StackMap stack:
            iload 1 /* type */
            invokestatic org.hsqldb.test.ParsedSection.isValidCode:(C)Z
            ifne 9
         8: .line 377
            aconst_null
            areturn
         9: .line 383
      StackMap locals:
      StackMap stack:
            iload 1 /* type */
            lookupswitch { // 10
                   32: 20
                   99: 17
                  100: 18
                  101: 19
                  111: 16
                  112: 14
                  114: 15
                  115: 12
                  117: 10
                  119: 13
              default: 22
          }
        10: .line 386
      StackMap locals:
      StackMap stack:
            new org.hsqldb.test.UpdateParsedSection
            dup
            aload 0 /* sectionLines */
            invokespecial org.hsqldb.test.UpdateParsedSection.<init>:(Lorg/hsqldb/lib/HsqlArrayList;)V
            astore 3 /* section */
        start local 3 // org.hsqldb.test.ParsedSection section
        11: .line 394
            aload 3 /* section */
            areturn
        end local 3 // org.hsqldb.test.ParsedSection section
        12: .line 397
      StackMap locals:
      StackMap stack:
            new org.hsqldb.test.SilentParsedSection
            dup
            aload 0 /* sectionLines */
            invokespecial org.hsqldb.test.SilentParsedSection.<init>:(Lorg/hsqldb/lib/HsqlArrayList;)V
            areturn
        13: .line 400
      StackMap locals:
      StackMap stack:
            new org.hsqldb.test.WaitSection
            dup
            aload 0 /* sectionLines */
            invokespecial org.hsqldb.test.WaitSection.<init>:(Lorg/hsqldb/lib/HsqlArrayList;)V
            areturn
        14: .line 403
      StackMap locals:
      StackMap stack:
            new org.hsqldb.test.ProceedSection
            dup
            aload 0 /* sectionLines */
            invokespecial org.hsqldb.test.ProceedSection.<init>:(Lorg/hsqldb/lib/HsqlArrayList;)V
            areturn
        15: .line 406
      StackMap locals:
      StackMap stack:
            new org.hsqldb.test.ResultSetParsedSection
            dup
            aload 0 /* sectionLines */
            invokespecial org.hsqldb.test.ResultSetParsedSection.<init>:(Lorg/hsqldb/lib/HsqlArrayList;)V
            areturn
        16: .line 409
      StackMap locals:
      StackMap stack:
            new org.hsqldb.test.ResultSetOutputParsedSection
            dup
            aload 0 /* sectionLines */
            invokespecial org.hsqldb.test.ResultSetOutputParsedSection.<init>:(Lorg/hsqldb/lib/HsqlArrayList;)V
            areturn
        17: .line 412
      StackMap locals:
      StackMap stack:
            new org.hsqldb.test.CountParsedSection
            dup
            aload 0 /* sectionLines */
            invokespecial org.hsqldb.test.CountParsedSection.<init>:(Lorg/hsqldb/lib/HsqlArrayList;)V
            areturn
        18: .line 415
      StackMap locals:
      StackMap stack:
            new org.hsqldb.test.DisplaySection
            dup
            aload 0 /* sectionLines */
            invokespecial org.hsqldb.test.DisplaySection.<init>:(Lorg/hsqldb/lib/HsqlArrayList;)V
            areturn
        19: .line 418
      StackMap locals:
      StackMap stack:
            new org.hsqldb.test.ExceptionParsedSection
            dup
            aload 0 /* sectionLines */
            invokespecial org.hsqldb.test.ExceptionParsedSection.<init>:(Lorg/hsqldb/lib/HsqlArrayList;)V
            areturn
        20: .line 421
      StackMap locals:
      StackMap stack:
            new org.hsqldb.test.BlankParsedSection
            dup
            aload 0 /* sectionLines */
            invokespecial org.hsqldb.test.BlankParsedSection.<init>:(Lorg/hsqldb/lib/HsqlArrayList;)V
            astore 3 /* section */
        start local 3 // org.hsqldb.test.ParsedSection section
        21: .line 429
            aload 3 /* section */
            areturn
        end local 3 // org.hsqldb.test.ParsedSection section
        22: .line 436
      StackMap locals:
      StackMap stack:
            new org.hsqldb.test.IgnoreParsedSection
            dup
            aload 0 /* sectionLines */
            iload 1 /* type */
            invokespecial org.hsqldb.test.IgnoreParsedSection.<init>:(Lorg/hsqldb/lib/HsqlArrayList;C)V
            areturn
        end local 2 // java.lang.String topLine
        end local 1 // char type
        end local 0 // org.hsqldb.lib.HsqlArrayList sectionLines
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   23     0  sectionLines  Lorg/hsqldb/lib/HsqlArrayList;
            1   23     1          type  C
            2   23     2       topLine  Ljava/lang/String;
           11   12     3       section  Lorg/hsqldb/test/ParsedSection;
           21   22     3       section  Lorg/hsqldb/test/ParsedSection;
    MethodParameters:
              Name  Flags
      sectionLines  

  public static void setAbortOnErr(boolean);
    descriptor: (Z)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // boolean aoe
         0: .line 446
            iload 0 /* aoe */
            putstatic org.hsqldb.test.TestUtil.abortOnErr:Z
         1: .line 447
            return
        end local 0 // boolean aoe
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0   aoe  Z
    MethodParameters:
      Name  Flags
      aoe   
}
SourceFile: "TestUtil.java"
NestMembers:
  org.hsqldb.test.TestUtil$TestRuntimeException
InnerClasses:
  TestRuntimeException = org.hsqldb.test.TestUtil$TestRuntimeException of org.hsqldb.test.TestUtil