public class org.h2.store.RecoverTester implements org.h2.store.fs.Recorder
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.h2.store.RecoverTester
  super_class: java.lang.Object
{
  private static org.h2.store.RecoverTester instance;
    descriptor: Lorg/h2/store/RecoverTester;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private java.lang.String testDatabase;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private int writeCount;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int testEvery;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private final long maxFileSize;
    descriptor: J
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private int verifyCount;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private final java.util.HashSet<java.lang.String> knownErrors;
    descriptor: Ljava/util/HashSet;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/HashSet<Ljava/lang/String;>;

  private volatile boolean testing;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // org.h2.store.RecoverTester this
         0: .line 33
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 37
            aload 0 /* this */
            ldc "memFS:reopen"
            putfield org.h2.store.RecoverTester.testDatabase:Ljava/lang/String;
         2: .line 38
            aload 0 /* this */
            ldc "h2.recoverTestOffset"
            iconst_0
            invokestatic org.h2.util.Utils.getProperty:(Ljava/lang/String;I)I
            putfield org.h2.store.RecoverTester.writeCount:I
         3: .line 39
            aload 0 /* this */
            ldc "h2.recoverTest"
            bipush 64
            invokestatic org.h2.util.Utils.getProperty:(Ljava/lang/String;I)I
            putfield org.h2.store.RecoverTester.testEvery:I
         4: .line 40
            aload 0 /* this */
         5: .line 41
            ldc "h2.recoverTestMaxFileSize"
            ldc 2147483647
         6: .line 40
            invokestatic org.h2.util.Utils.getProperty:(Ljava/lang/String;I)I
            i2l
         7: .line 41
            ldc 1024
         8: .line 40
            lmul
         9: .line 41
            ldc 1024
        10: .line 40
            lmul
            putfield org.h2.store.RecoverTester.maxFileSize:J
        11: .line 43
            aload 0 /* this */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield org.h2.store.RecoverTester.knownErrors:Ljava/util/HashSet;
        12: .line 33
            return
        end local 0 // org.h2.store.RecoverTester this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  this  Lorg/h2/store/RecoverTester;

  public static synchronized void init(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0029) ACC_PUBLIC, ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // java.lang.String recoverTest
         0: .line 52
            invokestatic org.h2.store.RecoverTester.getInstance:()Lorg/h2/store/RecoverTester;
            astore 1 /* tester */
        start local 1 // org.h2.store.RecoverTester tester
         1: .line 53
            aload 0 /* recoverTest */
            invokestatic org.h2.util.StringUtils.isNumber:(Ljava/lang/String;)Z
            ifeq 3
         2: .line 54
            aload 1 /* tester */
            aload 0 /* recoverTest */
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            invokevirtual org.h2.store.RecoverTester.setTestEvery:(I)V
         3: .line 56
      StackMap locals: org.h2.store.RecoverTester
      StackMap stack:
            aload 1 /* tester */
            invokestatic org.h2.store.fs.FilePathRec.setRecorder:(Lorg/h2/store/fs/Recorder;)V
         4: .line 57
            return
        end local 1 // org.h2.store.RecoverTester tester
        end local 0 // java.lang.String recoverTest
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    5     0  recoverTest  Ljava/lang/String;
            1    5     1       tester  Lorg/h2/store/RecoverTester;
    MethodParameters:
             Name  Flags
      recoverTest  

  public static synchronized org.h2.store.RecoverTester getInstance();
    descriptor: ()Lorg/h2/store/RecoverTester;
    flags: (0x0029) ACC_PUBLIC, ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=0, args_size=0
         0: .line 60
            getstatic org.h2.store.RecoverTester.instance:Lorg/h2/store/RecoverTester;
            ifnonnull 2
         1: .line 61
            new org.h2.store.RecoverTester
            dup
            invokespecial org.h2.store.RecoverTester.<init>:()V
            putstatic org.h2.store.RecoverTester.instance:Lorg/h2/store/RecoverTester;
         2: .line 63
      StackMap locals:
      StackMap stack:
            getstatic org.h2.store.RecoverTester.instance:Lorg/h2/store/RecoverTester;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void log(int, java.lang.String, byte[], long);
    descriptor: (ILjava/lang/String;[BJ)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=9, args_size=5
        start local 0 // org.h2.store.RecoverTester this
        start local 1 // int op
        start local 2 // java.lang.String fileName
        start local 3 // byte[] data
        start local 4 // long x
         0: .line 68
            iload 1 /* op */
            bipush 8
            if_icmpeq 2
            iload 1 /* op */
            bipush 7
            if_icmpeq 2
         1: .line 69
            return
         2: .line 71
      StackMap locals:
      StackMap stack:
            aload 2 /* fileName */
            ldc ".h2.db"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifne 5
         3: .line 72
            aload 2 /* fileName */
            ldc ".mv.db"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifne 5
         4: .line 73
            return
         5: .line 75
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield org.h2.store.RecoverTester.writeCount:I
            iconst_1
            iadd
            putfield org.h2.store.RecoverTester.writeCount:I
         6: .line 76
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.writeCount:I
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.testEvery:I
            irem
            ifeq 8
         7: .line 77
            return
         8: .line 79
      StackMap locals:
      StackMap stack:
            aload 2 /* fileName */
            invokestatic org.h2.store.fs.FileUtils.size:(Ljava/lang/String;)J
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.maxFileSize:J
            lcmp
            ifle 10
         9: .line 81
            return
        10: .line 83
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.testing:Z
            ifeq 12
        11: .line 85
            return
        12: .line 87
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.h2.store.RecoverTester.testing:Z
        13: .line 88
            aconst_null
            astore 6 /* out */
        start local 6 // java.io.PrintWriter out
        14: .line 90
            new java.io.PrintWriter
            dup
        15: .line 91
            new java.io.OutputStreamWriter
            dup
        16: .line 92
            new java.lang.StringBuilder
            dup
            aload 2 /* fileName */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ".log"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_1
            invokestatic org.h2.store.fs.FileUtils.newOutputStream:(Ljava/lang/String;Z)Ljava/io/OutputStream;
        17: .line 91
            invokespecial java.io.OutputStreamWriter.<init>:(Ljava/io/OutputStream;)V
        18: .line 90
            invokespecial java.io.PrintWriter.<init>:(Ljava/io/Writer;)V
            astore 6 /* out */
        19: .line 93
            aload 0 /* this */
            aload 2 /* fileName */
            aload 6 /* out */
            invokevirtual org.h2.store.RecoverTester.testDatabase:(Ljava/lang/String;Ljava/io/PrintWriter;)V
        20: .line 94
            goto 27
      StackMap locals: org.h2.store.RecoverTester int java.lang.String byte[] long java.io.PrintWriter
      StackMap stack: java.io.IOException
        21: astore 7 /* e */
        start local 7 // java.io.IOException e
        22: .line 95
            aload 7 /* e */
            aconst_null
            invokestatic org.h2.message.DbException.convertIOException:(Ljava/io/IOException;Ljava/lang/String;)Lorg/h2/message/DbException;
            athrow
        end local 7 // java.io.IOException e
        23: .line 96
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 8
        24: .line 97
            aload 6 /* out */
            invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
        25: .line 98
            aload 0 /* this */
            iconst_0
            putfield org.h2.store.RecoverTester.testing:Z
        26: .line 99
            aload 8
            athrow
        27: .line 97
      StackMap locals:
      StackMap stack:
            aload 6 /* out */
            invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
        28: .line 98
            aload 0 /* this */
            iconst_0
            putfield org.h2.store.RecoverTester.testing:Z
        29: .line 100
            return
        end local 6 // java.io.PrintWriter out
        end local 4 // long x
        end local 3 // byte[] data
        end local 2 // java.lang.String fileName
        end local 1 // int op
        end local 0 // org.h2.store.RecoverTester this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   30     0      this  Lorg/h2/store/RecoverTester;
            0   30     1        op  I
            0   30     2  fileName  Ljava/lang/String;
            0   30     3      data  [B
            0   30     4         x  J
           14   30     6       out  Ljava/io/PrintWriter;
           22   23     7         e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
          14    20      21  Class java.io.IOException
          14    23      23  any
    MethodParameters:
          Name  Flags
      op        
      fileName  
      data      
      x         

  private synchronized void testDatabase(java.lang.String, java.io.PrintWriter);
    descriptor: (Ljava/lang/String;Ljava/io/PrintWriter;)V
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=6, locals=8, args_size=3
        start local 0 // org.h2.store.RecoverTester this
        start local 1 // java.lang.String fileName
        start local 2 // java.io.PrintWriter out
         0: .line 103
            aload 2 /* out */
            new java.lang.StringBuilder
            dup
            ldc "+ write #"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.writeCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " verify #"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.verifyCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
         1: .line 105
            aload 1 /* fileName */
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.testDatabase:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ".h2.db"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.h2.util.IOUtils.copyFiles:(Ljava/lang/String;Ljava/lang/String;)V
         2: .line 106
            new java.lang.StringBuilder
            dup
            aload 1 /* fileName */
            iconst_0
            aload 1 /* fileName */
            invokevirtual java.lang.String.length:()I
         3: .line 107
            ldc ".h2.db"
            invokevirtual java.lang.String.length:()I
            isub
         4: .line 106
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         5: .line 108
            ldc ".mv.db"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         6: .line 106
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* mvFileName */
        start local 3 // java.lang.String mvFileName
         7: .line 109
            aload 3 /* mvFileName */
            invokestatic org.h2.store.fs.FileUtils.exists:(Ljava/lang/String;)Z
            ifeq 9
         8: .line 110
            aload 3 /* mvFileName */
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.testDatabase:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ".mv.db"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.h2.util.IOUtils.copyFiles:(Ljava/lang/String;Ljava/lang/String;)V
         9: .line 112
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* this */
            dup
            getfield org.h2.store.RecoverTester.verifyCount:I
            iconst_1
            iadd
            putfield org.h2.store.RecoverTester.verifyCount:I
        10: .line 114
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 4 /* p */
        start local 4 // java.util.Properties p
        11: .line 115
            aload 4 /* p */
            ldc "user"
            ldc ""
            invokevirtual java.util.Properties.setProperty:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;
            pop
        12: .line 116
            aload 4 /* p */
            ldc "password"
            ldc ""
            invokevirtual java.util.Properties.setProperty:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;
            pop
        13: .line 117
            new org.h2.engine.ConnectionInfo
            dup
            new java.lang.StringBuilder
            dup
            ldc "jdbc:h2:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.testDatabase:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        14: .line 118
            ldc ";FILE_LOCK=NO;TRACE_LEVEL_FILE=0"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 4 /* p */
        15: .line 117
            invokespecial org.h2.engine.ConnectionInfo.<init>:(Ljava/lang/String;Ljava/util/Properties;)V
            astore 5 /* ci */
        start local 5 // org.h2.engine.ConnectionInfo ci
        16: .line 119
            new org.h2.engine.Database
            dup
            aload 5 /* ci */
            aconst_null
            invokespecial org.h2.engine.Database.<init>:(Lorg/h2/engine/ConnectionInfo;Ljava/lang/String;)V
            astore 6 /* database */
        start local 6 // org.h2.engine.Database database
        17: .line 121
            aload 6 /* database */
            invokevirtual org.h2.engine.Database.getSystemSession:()Lorg/h2/engine/Session;
            astore 7 /* sysSession */
        start local 7 // org.h2.engine.Session sysSession
        18: .line 122
            aload 7 /* sysSession */
            new java.lang.StringBuilder
            dup
            ldc "script to '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.testDatabase:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ".sql'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual org.h2.engine.Session.prepare:(Ljava/lang/String;)Lorg/h2/command/Prepared;
            iconst_0
            invokevirtual org.h2.command.Prepared.query:(I)Lorg/h2/result/ResultInterface;
            pop
        19: .line 123
            aload 7 /* sysSession */
            ldc "shutdown immediately"
            invokevirtual org.h2.engine.Session.prepare:(Ljava/lang/String;)Lorg/h2/command/Prepared;
            invokevirtual org.h2.command.Prepared.update:()I
            pop
        20: .line 124
            aload 6 /* database */
            aconst_null
            invokevirtual org.h2.engine.Database.removeSession:(Lorg/h2/engine/Session;)V
        21: .line 126
            return
        end local 7 // org.h2.engine.Session sysSession
        end local 6 // org.h2.engine.Database database
        end local 5 // org.h2.engine.ConnectionInfo ci
        end local 4 // java.util.Properties p
        end local 3 // java.lang.String mvFileName
        22: .line 127
      StackMap locals: org.h2.store.RecoverTester java.lang.String java.io.PrintWriter
      StackMap stack: org.h2.message.DbException
            astore 3 /* e */
        start local 3 // org.h2.message.DbException e
        23: .line 128
            aload 3 /* e */
            invokestatic org.h2.message.DbException.toSQLException:(Ljava/lang/Throwable;)Ljava/sql/SQLException;
            astore 4 /* e2 */
        start local 4 // java.sql.SQLException e2
        24: .line 129
            aload 4 /* e2 */
            invokevirtual java.sql.SQLException.getErrorCode:()I
            istore 5 /* errorCode */
        start local 5 // int errorCode
        25: .line 130
            iload 5 /* errorCode */
            sipush 28000
            if_icmpne 27
        26: .line 131
            return
        27: .line 132
      StackMap locals: org.h2.message.DbException java.sql.SQLException int
      StackMap stack:
            iload 5 /* errorCode */
            ldc 90049
            if_icmpne 29
        28: .line 133
            return
        29: .line 135
      StackMap locals:
      StackMap stack:
            aload 3 /* e */
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual org.h2.message.DbException.printStackTrace:(Ljava/io/PrintStream;)V
        end local 5 // int errorCode
        end local 4 // java.sql.SQLException e2
        end local 3 // org.h2.message.DbException e
        30: goto 40
        31: .line 136
      StackMap locals: org.h2.store.RecoverTester java.lang.String java.io.PrintWriter
      StackMap stack: java.lang.Exception
            astore 3 /* e */
        start local 3 // java.lang.Exception e
        32: .line 138
            iconst_0
            istore 4 /* errorCode */
        start local 4 // int errorCode
        33: .line 139
            aload 3 /* e */
            instanceof java.sql.SQLException
            ifeq 35
        34: .line 140
            aload 3 /* e */
            checkcast java.sql.SQLException
            invokevirtual java.sql.SQLException.getErrorCode:()I
            istore 4 /* errorCode */
        35: .line 142
      StackMap locals: java.lang.Exception int
      StackMap stack:
            iload 4 /* errorCode */
            sipush 28000
            if_icmpne 37
        36: .line 143
            return
        37: .line 144
      StackMap locals:
      StackMap stack:
            iload 4 /* errorCode */
            ldc 90049
            if_icmpne 39
        38: .line 145
            return
        39: .line 147
      StackMap locals:
      StackMap stack:
            aload 3 /* e */
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual java.lang.Exception.printStackTrace:(Ljava/io/PrintStream;)V
        end local 4 // int errorCode
        end local 3 // java.lang.Exception e
        40: .line 149
      StackMap locals:
      StackMap stack:
            aload 2 /* out */
            new java.lang.StringBuilder
            dup
            ldc "begin ------------------------------ "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.writeCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
        41: .line 151
            aload 1 /* fileName */
            iconst_0
            aload 1 /* fileName */
            bipush 47
            invokevirtual java.lang.String.lastIndexOf:(I)I
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            aconst_null
            invokestatic org.h2.tools.Recover.execute:(Ljava/lang/String;Ljava/lang/String;)V
        42: .line 152
            goto 44
      StackMap locals:
      StackMap stack: java.sql.SQLException
        43: pop
        44: .line 155
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield org.h2.store.RecoverTester.testDatabase:Ljava/lang/String;
            new java.lang.StringBuilder
            dup_x1
            swap
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "X"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            putfield org.h2.store.RecoverTester.testDatabase:Ljava/lang/String;
        45: .line 157
            aload 1 /* fileName */
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.testDatabase:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ".h2.db"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.h2.util.IOUtils.copyFiles:(Ljava/lang/String;Ljava/lang/String;)V
        46: .line 159
            new java.util.Properties
            dup
            invokespecial java.util.Properties.<init>:()V
            astore 3 /* p */
        start local 3 // java.util.Properties p
        47: .line 160
            new org.h2.engine.ConnectionInfo
            dup
            new java.lang.StringBuilder
            dup
            ldc "jdbc:h2:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        48: .line 161
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.testDatabase:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ";FILE_LOCK=NO"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 3 /* p */
        49: .line 160
            invokespecial org.h2.engine.ConnectionInfo.<init>:(Ljava/lang/String;Ljava/util/Properties;)V
            astore 4 /* ci */
        start local 4 // org.h2.engine.ConnectionInfo ci
        50: .line 162
            new org.h2.engine.Database
            dup
            aload 4 /* ci */
            aconst_null
            invokespecial org.h2.engine.Database.<init>:(Lorg/h2/engine/ConnectionInfo;Ljava/lang/String;)V
            astore 5 /* database */
        start local 5 // org.h2.engine.Database database
        51: .line 164
            aload 5 /* database */
            aconst_null
            invokevirtual org.h2.engine.Database.removeSession:(Lorg/h2/engine/Session;)V
        end local 5 // org.h2.engine.Database database
        end local 4 // org.h2.engine.ConnectionInfo ci
        end local 3 // java.util.Properties p
        52: .line 165
            goto 76
      StackMap locals:
      StackMap stack: java.lang.Exception
        53: astore 3 /* e */
        start local 3 // java.lang.Exception e
        54: .line 166
            iconst_0
            istore 4 /* errorCode */
        start local 4 // int errorCode
        55: .line 167
            aload 3 /* e */
            instanceof org.h2.message.DbException
            ifeq 58
        56: .line 168
            aload 3 /* e */
            checkcast org.h2.message.DbException
            invokevirtual org.h2.message.DbException.getSQLException:()Ljava/sql/SQLException;
            astore 3 /* e */
        57: .line 169
            aload 3 /* e */
            checkcast java.sql.SQLException
            invokevirtual java.sql.SQLException.getErrorCode:()I
            istore 4 /* errorCode */
        58: .line 171
      StackMap locals: java.lang.Exception int
      StackMap stack:
            iload 4 /* errorCode */
            sipush 28000
            if_icmpne 60
        59: .line 172
            return
        60: .line 173
      StackMap locals:
      StackMap stack:
            iload 4 /* errorCode */
            ldc 90049
            if_icmpne 62
        61: .line 174
            return
        62: .line 176
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 5 /* buff */
        start local 5 // java.lang.StringBuilder buff
        63: .line 177
            aload 3 /* e */
            invokevirtual java.lang.Exception.getStackTrace:()[Ljava/lang/StackTraceElement;
            astore 6 /* list */
        start local 6 // java.lang.StackTraceElement[] list
        64: .line 178
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        65: goto 68
        66: .line 179
      StackMap locals: java.lang.StringBuilder java.lang.StackTraceElement[] int
      StackMap stack:
            aload 5 /* buff */
            aload 6 /* list */
            iload 7 /* i */
            aaload
            invokevirtual java.lang.StackTraceElement.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 10
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        67: .line 178
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        68: iload 7 /* i */
            bipush 10
            if_icmpge 69
            iload 7 /* i */
            aload 6 /* list */
            arraylength
            if_icmplt 66
        end local 7 // int i
        69: .line 181
      StackMap locals:
      StackMap stack:
            aload 5 /* buff */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 7 /* s */
        start local 7 // java.lang.String s
        70: .line 182
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.knownErrors:Ljava/util/HashSet;
            aload 7 /* s */
            invokevirtual java.util.HashSet.contains:(Ljava/lang/Object;)Z
            ifne 75
        71: .line 183
            aload 2 /* out */
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.writeCount:I
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " code: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 4 /* errorCode */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            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.PrintWriter.println:(Ljava/lang/String;)V
        72: .line 184
            aload 3 /* e */
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual java.lang.Exception.printStackTrace:(Ljava/io/PrintStream;)V
        73: .line 185
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.knownErrors:Ljava/util/HashSet;
            aload 7 /* s */
            invokevirtual java.util.HashSet.add:(Ljava/lang/Object;)Z
            pop
        74: .line 186
            goto 76
        75: .line 187
      StackMap locals: java.lang.String
      StackMap stack:
            aload 2 /* out */
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield org.h2.store.RecoverTester.writeCount:I
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " code: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 4 /* errorCode */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
        end local 7 // java.lang.String s
        end local 6 // java.lang.StackTraceElement[] list
        end local 5 // java.lang.StringBuilder buff
        end local 4 // int errorCode
        end local 3 // java.lang.Exception e
        76: .line 190
      StackMap locals: org.h2.store.RecoverTester java.lang.String java.io.PrintWriter
      StackMap stack:
            return
        end local 2 // java.io.PrintWriter out
        end local 1 // java.lang.String fileName
        end local 0 // org.h2.store.RecoverTester this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   77     0        this  Lorg/h2/store/RecoverTester;
            0   77     1    fileName  Ljava/lang/String;
            0   77     2         out  Ljava/io/PrintWriter;
            7   22     3  mvFileName  Ljava/lang/String;
           11   22     4           p  Ljava/util/Properties;
           16   22     5          ci  Lorg/h2/engine/ConnectionInfo;
           17   22     6    database  Lorg/h2/engine/Database;
           18   22     7  sysSession  Lorg/h2/engine/Session;
           23   30     3           e  Lorg/h2/message/DbException;
           24   30     4          e2  Ljava/sql/SQLException;
           25   30     5   errorCode  I
           32   40     3           e  Ljava/lang/Exception;
           33   40     4   errorCode  I
           47   52     3           p  Ljava/util/Properties;
           50   52     4          ci  Lorg/h2/engine/ConnectionInfo;
           51   52     5    database  Lorg/h2/engine/Database;
           54   76     3           e  Ljava/lang/Exception;
           55   76     4   errorCode  I
           63   76     5        buff  Ljava/lang/StringBuilder;
           64   76     6        list  [Ljava/lang/StackTraceElement;
           65   69     7           i  I
           70   76     7           s  Ljava/lang/String;
      Exception table:
        from    to  target  type
           1    21      22  Class org.h2.message.DbException
           1    21      31  Class java.lang.Exception
          41    42      43  Class java.sql.SQLException
          45    52      53  Class java.lang.Exception
    MethodParameters:
          Name  Flags
      fileName  
      out       

  public void setTestEvery(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.h2.store.RecoverTester this
        start local 1 // int testEvery
         0: .line 193
            aload 0 /* this */
            iload 1 /* testEvery */
            putfield org.h2.store.RecoverTester.testEvery:I
         1: .line 194
            return
        end local 1 // int testEvery
        end local 0 // org.h2.store.RecoverTester this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/h2/store/RecoverTester;
            0    2     1  testEvery  I
    MethodParameters:
           Name  Flags
      testEvery  
}
SourceFile: "RecoverTester.java"