public class org.h2.message.TraceSystem implements org.h2.message.TraceWriter
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.h2.message.TraceSystem
  super_class: java.lang.Object
{
  public static final int PARENT;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: -1

  public static final int OFF;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  public static final int ERROR;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 1

  public static final int INFO;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 2

  public static final int DEBUG;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 3

  public static final int ADAPTER;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 4

  public static final int DEFAULT_TRACE_LEVEL_SYSTEM_OUT;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  public static final int DEFAULT_TRACE_LEVEL_FILE;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 1

  private static final int DEFAULT_MAX_FILE_SIZE;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 67108864

  private static final int CHECK_SIZE_EACH_WRITES;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 4096

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

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

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

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

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

  private final java.util.concurrent.atomic.AtomicReferenceArray<org.h2.message.Trace> traces;
    descriptor: Ljava/util/concurrent/atomic/AtomicReferenceArray;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReferenceArray<Lorg/h2/message/Trace;>;

  private java.text.SimpleDateFormat dateFormat;
    descriptor: Ljava/text/SimpleDateFormat;
    flags: (0x0002) ACC_PRIVATE

  private java.io.Writer fileWriter;
    descriptor: Ljava/io/Writer;
    flags: (0x0002) ACC_PRIVATE

  private java.io.PrintWriter printWriter;
    descriptor: Ljava/io/PrintWriter;
    flags: (0x0002) ACC_PRIVATE

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

  private boolean closed;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private boolean writingErrorLogged;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private org.h2.message.TraceWriter writer;
    descriptor: Lorg/h2/message/TraceWriter;
    flags: (0x0002) ACC_PRIVATE

  private java.io.PrintStream sysOut;
    descriptor: Ljava/io/PrintStream;
    flags: (0x0002) ACC_PRIVATE

  public void <init>(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // java.lang.String fileName
         0: .line 100
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 79
            aload 0 /* this */
            iconst_0
            putfield org.h2.message.TraceSystem.levelSystemOut:I
         2: .line 80
            aload 0 /* this */
            iconst_1
            putfield org.h2.message.TraceSystem.levelFile:I
         3: .line 82
            aload 0 /* this */
            ldc 67108864
            putfield org.h2.message.TraceSystem.maxFileSize:I
         4: .line 84
            aload 0 /* this */
         5: .line 85
            new java.util.concurrent.atomic.AtomicReferenceArray
            dup
            getstatic org.h2.message.Trace.MODULE_NAMES:[Ljava/lang/String;
            arraylength
            invokespecial java.util.concurrent.atomic.AtomicReferenceArray.<init>:(I)V
            putfield org.h2.message.TraceSystem.traces:Ljava/util/concurrent/atomic/AtomicReferenceArray;
         6: .line 92
            aload 0 /* this */
            aload 0 /* this */
            putfield org.h2.message.TraceSystem.writer:Lorg/h2/message/TraceWriter;
         7: .line 93
            aload 0 /* this */
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            putfield org.h2.message.TraceSystem.sysOut:Ljava/io/PrintStream;
         8: .line 101
            aload 0 /* this */
            aload 1 /* fileName */
            putfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
         9: .line 102
            aload 0 /* this */
            invokevirtual org.h2.message.TraceSystem.updateLevel:()V
        10: .line 103
            return
        end local 1 // java.lang.String fileName
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   11     0      this  Lorg/h2/message/TraceSystem;
            0   11     1  fileName  Ljava/lang/String;
    MethodParameters:
          Name  Flags
      fileName  

  private void updateLevel();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.h2.message.TraceSystem this
         0: .line 106
            aload 0 /* this */
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.levelSystemOut:I
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.levelFile:I
            invokestatic java.lang.Math.max:(II)I
            putfield org.h2.message.TraceSystem.levelMax:I
         1: .line 107
            return
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/h2/message/TraceSystem;

  public void setSysOut(java.io.PrintStream);
    descriptor: (Ljava/io/PrintStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // java.io.PrintStream out
         0: .line 115
            aload 0 /* this */
            aload 1 /* out */
            putfield org.h2.message.TraceSystem.sysOut:Ljava/io/PrintStream;
         1: .line 116
            return
        end local 1 // java.io.PrintStream out
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/h2/message/TraceSystem;
            0    2     1   out  Ljava/io/PrintStream;
    MethodParameters:
      Name  Flags
      out   

  public org.h2.message.Trace getTrace(int);
    descriptor: (I)Lorg/h2/message/Trace;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // int moduleId
         0: .line 126
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.traces:Ljava/util/concurrent/atomic/AtomicReferenceArray;
            iload 1 /* moduleId */
            invokevirtual java.util.concurrent.atomic.AtomicReferenceArray.get:(I)Ljava/lang/Object;
            checkcast org.h2.message.Trace
            astore 2 /* t */
        start local 2 // org.h2.message.Trace t
         1: .line 127
            aload 2 /* t */
            ifnonnull 5
         2: .line 128
            new org.h2.message.Trace
            dup
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.writer:Lorg/h2/message/TraceWriter;
            iload 1 /* moduleId */
            invokespecial org.h2.message.Trace.<init>:(Lorg/h2/message/TraceWriter;I)V
            astore 2 /* t */
         3: .line 129
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.traces:Ljava/util/concurrent/atomic/AtomicReferenceArray;
            iload 1 /* moduleId */
            aconst_null
            aload 2 /* t */
            invokevirtual java.util.concurrent.atomic.AtomicReferenceArray.compareAndSet:(ILjava/lang/Object;Ljava/lang/Object;)Z
            ifne 5
         4: .line 130
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.traces:Ljava/util/concurrent/atomic/AtomicReferenceArray;
            iload 1 /* moduleId */
            invokevirtual java.util.concurrent.atomic.AtomicReferenceArray.get:(I)Ljava/lang/Object;
            checkcast org.h2.message.Trace
            astore 2 /* t */
         5: .line 133
      StackMap locals: org.h2.message.Trace
      StackMap stack:
            aload 2 /* t */
            areturn
        end local 2 // org.h2.message.Trace t
        end local 1 // int moduleId
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/h2/message/TraceSystem;
            0    6     1  moduleId  I
            1    6     2         t  Lorg/h2/message/Trace;
    MethodParameters:
          Name  Flags
      moduleId  

  public org.h2.message.Trace getTrace(java.lang.String);
    descriptor: (Ljava/lang/String;)Lorg/h2/message/Trace;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // java.lang.String module
         0: .line 144
            new org.h2.message.Trace
            dup
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.writer:Lorg/h2/message/TraceWriter;
            aload 1 /* module */
            invokespecial org.h2.message.Trace.<init>:(Lorg/h2/message/TraceWriter;Ljava/lang/String;)V
            areturn
        end local 1 // java.lang.String module
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lorg/h2/message/TraceSystem;
            0    1     1  module  Ljava/lang/String;
    MethodParameters:
        Name  Flags
      module  

  public boolean isEnabled(int);
    descriptor: (I)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // int level
         0: .line 149
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.levelMax:I
            iconst_4
            if_icmpne 2
         1: .line 150
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.writer:Lorg/h2/message/TraceWriter;
            iload 1 /* level */
            invokeinterface org.h2.message.TraceWriter.isEnabled:(I)Z
            ireturn
         2: .line 152
      StackMap locals:
      StackMap stack:
            iload 1 /* level */
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.levelMax:I
            if_icmpgt 3
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         3: iconst_0
            ireturn
        end local 1 // int level
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lorg/h2/message/TraceSystem;
            0    4     1  level  I
    MethodParameters:
       Name  Flags
      level  

  public void setFileName(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // java.lang.String name
         0: .line 161
            aload 0 /* this */
            aload 1 /* name */
            putfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
         1: .line 162
            return
        end local 1 // java.lang.String name
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/h2/message/TraceSystem;
            0    2     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  

  public void setMaxFileSize(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // int max
         0: .line 170
            aload 0 /* this */
            iload 1 /* max */
            putfield org.h2.message.TraceSystem.maxFileSize:I
         1: .line 171
            return
        end local 1 // int max
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/h2/message/TraceSystem;
            0    2     1   max  I
    MethodParameters:
      Name  Flags
      max   

  public void setLevelSystemOut(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // int level
         0: .line 179
            aload 0 /* this */
            iload 1 /* level */
            putfield org.h2.message.TraceSystem.levelSystemOut:I
         1: .line 180
            aload 0 /* this */
            invokevirtual org.h2.message.TraceSystem.updateLevel:()V
         2: .line 181
            return
        end local 1 // int level
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Lorg/h2/message/TraceSystem;
            0    3     1  level  I
    MethodParameters:
       Name  Flags
      level  

  public void setLevelFile(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=5, args_size=2
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // int level
         0: .line 189
            iload 1 /* level */
            iconst_4
            if_icmpne 16
         1: .line 190
            ldc "org.h2.message.TraceWriterAdapter"
            astore 2 /* adapterClass */
        start local 2 // java.lang.String adapterClass
         2: .line 192
            aload 0 /* this */
            aload 2 /* adapterClass */
            invokestatic java.lang.Class.forName:(Ljava/lang/String;)Ljava/lang/Class;
            iconst_0
            anewarray java.lang.Class
            invokevirtual java.lang.Class.getDeclaredConstructor:([Ljava/lang/Class;)Ljava/lang/reflect/Constructor;
            iconst_0
            anewarray java.lang.Object
            invokevirtual java.lang.reflect.Constructor.newInstance:([Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.h2.message.TraceWriter
            putfield org.h2.message.TraceSystem.writer:Lorg/h2/message/TraceWriter;
         3: .line 193
            goto 8
      StackMap locals: org.h2.message.TraceSystem int java.lang.String
      StackMap stack: java.lang.Throwable
         4: astore 3 /* e */
        start local 3 // java.lang.Throwable e
         5: .line 194
            ldc 90086
            aload 3 /* e */
            iconst_1
            anewarray java.lang.String
            dup
            iconst_0
            aload 2 /* adapterClass */
            aastore
            invokestatic org.h2.message.DbException.get:(ILjava/lang/Throwable;[Ljava/lang/String;)Lorg/h2/message/DbException;
            astore 3 /* e */
         6: .line 195
            aload 0 /* this */
            iconst_1
            iconst_2
            aload 2 /* adapterClass */
            aload 3 /* e */
            invokevirtual org.h2.message.TraceSystem.write:(IILjava/lang/String;Ljava/lang/Throwable;)V
         7: .line 196
            return
        end local 3 // java.lang.Throwable e
         8: .line 198
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
            astore 3 /* name */
        start local 3 // java.lang.String name
         9: .line 199
            aload 3 /* name */
            ifnull 16
        10: .line 200
            aload 3 /* name */
            ldc ".trace.db"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 12
        11: .line 201
            aload 3 /* name */
            iconst_0
            aload 3 /* name */
            invokevirtual java.lang.String.length:()I
            ldc ".trace.db"
            invokevirtual java.lang.String.length:()I
            isub
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 3 /* name */
        12: .line 203
      StackMap locals: java.lang.String
      StackMap stack:
            aload 3 /* name */
            bipush 47
            invokevirtual java.lang.String.lastIndexOf:(I)I
            aload 3 /* name */
            bipush 92
            invokevirtual java.lang.String.lastIndexOf:(I)I
            invokestatic java.lang.Math.max:(II)I
            istore 4 /* idx */
        start local 4 // int idx
        13: .line 204
            iload 4 /* idx */
            iflt 15
        14: .line 205
            aload 3 /* name */
            iload 4 /* idx */
            iconst_1
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 3 /* name */
        15: .line 207
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.writer:Lorg/h2/message/TraceWriter;
            aload 3 /* name */
            invokeinterface org.h2.message.TraceWriter.setName:(Ljava/lang/String;)V
        end local 4 // int idx
        end local 3 // java.lang.String name
        end local 2 // java.lang.String adapterClass
        16: .line 210
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* level */
            putfield org.h2.message.TraceSystem.levelFile:I
        17: .line 211
            aload 0 /* this */
            invokevirtual org.h2.message.TraceSystem.updateLevel:()V
        18: .line 212
            return
        end local 1 // int level
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   19     0          this  Lorg/h2/message/TraceSystem;
            0   19     1         level  I
            2   16     2  adapterClass  Ljava/lang/String;
            5    8     3             e  Ljava/lang/Throwable;
            9   16     3          name  Ljava/lang/String;
           13   16     4           idx  I
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.Throwable
    MethodParameters:
       Name  Flags
      level  

  public int getLevelFile();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.h2.message.TraceSystem this
         0: .line 215
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.levelFile:I
            ireturn
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/h2/message/TraceSystem;

  private synchronized java.lang.String format(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // java.lang.String module
        start local 2 // java.lang.String s
         0: .line 219
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.dateFormat:Ljava/text/SimpleDateFormat;
            ifnonnull 2
         1: .line 220
            aload 0 /* this */
            new java.text.SimpleDateFormat
            dup
            ldc "yyyy-MM-dd HH:mm:ss "
            invokespecial java.text.SimpleDateFormat.<init>:(Ljava/lang/String;)V
            putfield org.h2.message.TraceSystem.dateFormat:Ljava/text/SimpleDateFormat;
         2: .line 222
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.dateFormat:Ljava/text/SimpleDateFormat;
            invokestatic java.lang.System.currentTimeMillis:()J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokevirtual java.text.SimpleDateFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* module */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ": "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* s */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 2 // java.lang.String s
        end local 1 // java.lang.String module
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/h2/message/TraceSystem;
            0    3     1  module  Ljava/lang/String;
            0    3     2       s  Ljava/lang/String;
    MethodParameters:
        Name  Flags
      module  
      s       

  public void write(int, int, java.lang.String, java.lang.Throwable);
    descriptor: (IILjava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=5
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // int level
        start local 2 // int moduleId
        start local 3 // java.lang.String s
        start local 4 // java.lang.Throwable t
         0: .line 227
            aload 0 /* this */
            iload 1 /* level */
            getstatic org.h2.message.Trace.MODULE_NAMES:[Ljava/lang/String;
            iload 2 /* moduleId */
            aaload
            aload 3 /* s */
            aload 4 /* t */
            invokevirtual org.h2.message.TraceSystem.write:(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 228
            return
        end local 4 // java.lang.Throwable t
        end local 3 // java.lang.String s
        end local 2 // int moduleId
        end local 1 // int level
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/h2/message/TraceSystem;
            0    2     1     level  I
            0    2     2  moduleId  I
            0    2     3         s  Ljava/lang/String;
            0    2     4         t  Ljava/lang/Throwable;
    MethodParameters:
          Name  Flags
      level     
      moduleId  
      s         
      t         

  public void write(int, java.lang.String, java.lang.String, java.lang.Throwable);
    descriptor: (ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=5
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // int level
        start local 2 // java.lang.String module
        start local 3 // java.lang.String s
        start local 4 // java.lang.Throwable t
         0: .line 232
            iload 1 /* level */
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.levelSystemOut:I
            if_icmple 1
            iload 1 /* level */
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.levelMax:I
            if_icmple 4
         1: .line 235
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.sysOut:Ljava/io/PrintStream;
            aload 0 /* this */
            aload 2 /* module */
            aload 3 /* s */
            invokevirtual org.h2.message.TraceSystem.format:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 236
            aload 4 /* t */
            ifnull 4
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.levelSystemOut:I
            iconst_3
            if_icmpne 4
         3: .line 237
            aload 4 /* t */
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.sysOut:Ljava/io/PrintStream;
            invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintStream;)V
         4: .line 240
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
            ifnull 7
         5: .line 241
            iload 1 /* level */
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.levelFile:I
            if_icmpgt 7
         6: .line 242
            aload 0 /* this */
            aload 0 /* this */
            aload 2 /* module */
            aload 3 /* s */
            invokevirtual org.h2.message.TraceSystem.format:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
            aload 4 /* t */
            invokevirtual org.h2.message.TraceSystem.writeFile:(Ljava/lang/String;Ljava/lang/Throwable;)V
         7: .line 245
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.lang.Throwable t
        end local 3 // java.lang.String s
        end local 2 // java.lang.String module
        end local 1 // int level
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Lorg/h2/message/TraceSystem;
            0    8     1   level  I
            0    8     2  module  Ljava/lang/String;
            0    8     3       s  Ljava/lang/String;
            0    8     4       t  Ljava/lang/Throwable;
    MethodParameters:
        Name  Flags
      level   
      module  
      s       
      t       

  private synchronized void writeFile(java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=5, args_size=3
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // java.lang.String s
        start local 2 // java.lang.Throwable t
         0: .line 249
            aload 0 /* this */
            dup
            getfield org.h2.message.TraceSystem.checkSize:I
            dup_x1
            iconst_1
            iadd
            putfield org.h2.message.TraceSystem.checkSize:I
            sipush 4096
            if_icmplt 7
         1: .line 250
            aload 0 /* this */
            iconst_0
            putfield org.h2.message.TraceSystem.checkSize:I
         2: .line 251
            aload 0 /* this */
            invokevirtual org.h2.message.TraceSystem.closeWriter:()V
         3: .line 252
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.maxFileSize:I
            ifle 7
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
            invokestatic org.h2.store.fs.FileUtils.size:(Ljava/lang/String;)J
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.maxFileSize:I
            i2l
            lcmp
            ifle 7
         4: .line 253
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ".old"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* old */
        start local 3 // java.lang.String old
         5: .line 254
            aload 3 /* old */
            invokestatic org.h2.store.fs.FileUtils.delete:(Ljava/lang/String;)V
         6: .line 255
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
            aload 3 /* old */
            invokestatic org.h2.store.fs.FileUtils.move:(Ljava/lang/String;Ljava/lang/String;)V
        end local 3 // java.lang.String old
         7: .line 258
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.h2.message.TraceSystem.openWriter:()Z
            ifne 9
         8: .line 259
            return
         9: .line 261
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.printWriter:Ljava/io/PrintWriter;
            aload 1 /* s */
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
        10: .line 262
            aload 2 /* t */
            ifnull 20
        11: .line 263
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.levelFile:I
            iconst_1
            if_icmpne 19
            aload 2 /* t */
            instanceof org.h2.jdbc.JdbcException
            ifeq 19
        12: .line 264
            aload 2 /* t */
            checkcast org.h2.jdbc.JdbcException
            astore 3 /* se */
        start local 3 // org.h2.jdbc.JdbcException se
        13: .line 265
            aload 3 /* se */
            invokeinterface org.h2.jdbc.JdbcException.getErrorCode:()I
            istore 4 /* code */
        start local 4 // int code
        14: .line 266
            iload 4 /* code */
            invokestatic org.h2.api.ErrorCode.isCommon:(I)Z
            ifeq 17
        15: .line 267
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.printWriter:Ljava/io/PrintWriter;
            aload 2 /* t */
            invokevirtual java.lang.Throwable.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintWriter.println:(Ljava/lang/String;)V
        16: .line 268
            goto 20
        17: .line 269
      StackMap locals: org.h2.jdbc.JdbcException int
      StackMap stack:
            aload 2 /* t */
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.printWriter:Ljava/io/PrintWriter;
            invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintWriter;)V
        end local 4 // int code
        end local 3 // org.h2.jdbc.JdbcException se
        18: .line 271
            goto 20
        19: .line 272
      StackMap locals:
      StackMap stack:
            aload 2 /* t */
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.printWriter:Ljava/io/PrintWriter;
            invokevirtual java.lang.Throwable.printStackTrace:(Ljava/io/PrintWriter;)V
        20: .line 275
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.printWriter:Ljava/io/PrintWriter;
            invokevirtual java.io.PrintWriter.flush:()V
        21: .line 276
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.closed:Z
            ifeq 26
        22: .line 277
            aload 0 /* this */
            invokevirtual org.h2.message.TraceSystem.closeWriter:()V
        23: .line 279
            goto 26
      StackMap locals:
      StackMap stack: java.lang.Exception
        24: astore 3 /* e */
        start local 3 // java.lang.Exception e
        25: .line 280
            aload 0 /* this */
            aload 3 /* e */
            invokevirtual org.h2.message.TraceSystem.logWritingError:(Ljava/lang/Exception;)V
        end local 3 // java.lang.Exception e
        26: .line 282
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.String s
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   27     0  this  Lorg/h2/message/TraceSystem;
            0   27     1     s  Ljava/lang/String;
            0   27     2     t  Ljava/lang/Throwable;
            5    7     3   old  Ljava/lang/String;
           13   18     3    se  Lorg/h2/jdbc/JdbcException;
           14   18     4  code  I
           25   26     3     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           0     8      24  Class java.lang.Exception
           9    23      24  Class java.lang.Exception
    MethodParameters:
      Name  Flags
      s     
      t     

  private void logWritingError(java.lang.Exception);
    descriptor: (Ljava/lang/Exception;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=3, args_size=2
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // java.lang.Exception e
         0: .line 285
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.writingErrorLogged:Z
            ifeq 2
         1: .line 286
            return
         2: .line 288
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.h2.message.TraceSystem.writingErrorLogged:Z
         3: .line 290
            ldc 90034
            aload 1 /* e */
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
            aastore
            dup
            iconst_1
            aload 1 /* e */
            invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
            aastore
         4: .line 289
            invokestatic org.h2.message.DbException.get:(ILjava/lang/Throwable;[Ljava/lang/String;)Lorg/h2/message/DbException;
            astore 2 /* se */
        start local 2 // java.lang.Exception se
         5: .line 292
            aload 0 /* this */
            aconst_null
            putfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
         6: .line 293
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.sysOut:Ljava/io/PrintStream;
            aload 2 /* se */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/Object;)V
         7: .line 294
            aload 2 /* se */
            invokevirtual java.lang.Exception.printStackTrace:()V
         8: .line 295
            return
        end local 2 // java.lang.Exception se
        end local 1 // java.lang.Exception e
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lorg/h2/message/TraceSystem;
            0    9     1     e  Ljava/lang/Exception;
            5    9     2    se  Ljava/lang/Exception;
    MethodParameters:
      Name  Flags
      e     

  private boolean openWriter();
    descriptor: ()Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // org.h2.message.TraceSystem this
         0: .line 298
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.printWriter:Ljava/io/PrintWriter;
            ifnonnull 12
         1: .line 300
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
            invokestatic org.h2.store.fs.FileUtils.getParent:(Ljava/lang/String;)Ljava/lang/String;
            invokestatic org.h2.store.fs.FileUtils.createDirectories:(Ljava/lang/String;)V
         2: .line 301
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
            invokestatic org.h2.store.fs.FileUtils.exists:(Ljava/lang/String;)Z
            ifeq 4
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
            invokestatic org.h2.store.fs.FileUtils.canWrite:(Ljava/lang/String;)Z
            ifne 4
         3: .line 304
            iconst_0
            ireturn
         4: .line 306
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
         5: .line 307
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileName:Ljava/lang/String;
            iconst_1
            invokestatic org.h2.store.fs.FileUtils.newOutputStream:(Ljava/lang/String;Z)Ljava/io/OutputStream;
         6: .line 306
            invokestatic org.h2.util.IOUtils.getBufferedWriter:(Ljava/io/OutputStream;)Ljava/io/Writer;
            putfield org.h2.message.TraceSystem.fileWriter:Ljava/io/Writer;
         7: .line 308
            aload 0 /* this */
            new java.io.PrintWriter
            dup
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileWriter:Ljava/io/Writer;
            iconst_1
            invokespecial java.io.PrintWriter.<init>:(Ljava/io/Writer;Z)V
            putfield org.h2.message.TraceSystem.printWriter:Ljava/io/PrintWriter;
         8: .line 309
            goto 12
      StackMap locals:
      StackMap stack: java.lang.Exception
         9: astore 1 /* e */
        start local 1 // java.lang.Exception e
        10: .line 310
            aload 0 /* this */
            aload 1 /* e */
            invokevirtual org.h2.message.TraceSystem.logWritingError:(Ljava/lang/Exception;)V
        11: .line 311
            iconst_0
            ireturn
        end local 1 // java.lang.Exception e
        12: .line 314
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  this  Lorg/h2/message/TraceSystem;
           10   12     1     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1     3       9  Class java.lang.Exception
           4     8       9  Class java.lang.Exception

  private synchronized void closeWriter();
    descriptor: ()V
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.h2.message.TraceSystem this
         0: .line 318
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.printWriter:Ljava/io/PrintWriter;
            ifnull 4
         1: .line 319
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.printWriter:Ljava/io/PrintWriter;
            invokevirtual java.io.PrintWriter.flush:()V
         2: .line 320
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.printWriter:Ljava/io/PrintWriter;
            invokevirtual java.io.PrintWriter.close:()V
         3: .line 321
            aload 0 /* this */
            aconst_null
            putfield org.h2.message.TraceSystem.printWriter:Ljava/io/PrintWriter;
         4: .line 323
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileWriter:Ljava/io/Writer;
            ifnull 9
         5: .line 325
            aload 0 /* this */
            getfield org.h2.message.TraceSystem.fileWriter:Ljava/io/Writer;
            invokevirtual java.io.Writer.close:()V
         6: .line 326
            goto 8
      StackMap locals:
      StackMap stack: java.io.IOException
         7: pop
         8: .line 329
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield org.h2.message.TraceSystem.fileWriter:Ljava/io/Writer;
         9: .line 331
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lorg/h2/message/TraceSystem;
      Exception table:
        from    to  target  type
           5     6       7  Class java.io.IOException

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.h2.message.TraceSystem this
         0: .line 339
            aload 0 /* this */
            invokevirtual org.h2.message.TraceSystem.closeWriter:()V
         1: .line 340
            aload 0 /* this */
            iconst_1
            putfield org.h2.message.TraceSystem.closed:Z
         2: .line 341
            return
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/h2/message/TraceSystem;

  public void setName(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=0, locals=2, args_size=2
        start local 0 // org.h2.message.TraceSystem this
        start local 1 // java.lang.String name
         0: .line 346
            return
        end local 1 // java.lang.String name
        end local 0 // org.h2.message.TraceSystem this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/h2/message/TraceSystem;
            0    1     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  
}
SourceFile: "TraceSystem.java"