public class org.mongodb.morphia.logging.jdk.JDKLogger implements org.mongodb.morphia.logging.Logger
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.mongodb.morphia.logging.jdk.JDKLogger
  super_class: java.lang.Object
{
  private final transient java.util.logging.Logger logger;
    descriptor: Ljava/util/logging/Logger;
    flags: (0x0092) ACC_PRIVATE, ACC_FINAL, ACC_TRANSIENT

  public void <init>(java.lang.Class);
    descriptor: (Ljava/lang/Class;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.Class c
         0: .line 18
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 19
            aload 0 /* this */
            aload 1 /* c */
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokestatic java.util.logging.Logger.getLogger:(Ljava/lang/String;)Ljava/util/logging/Logger;
            putfield org.mongodb.morphia.logging.jdk.JDKLogger.logger:Ljava/util/logging/Logger;
         2: .line 20
            return
        end local 1 // java.lang.Class c
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    3     1     c  Ljava/lang/Class;
    MethodParameters:
      Name  Flags
      c     final

  public void debug(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String msg
         0: .line 24
            aload 0 /* this */
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            aload 1 /* msg */
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 25
            return
        end local 1 // java.lang.String msg
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1   msg  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      msg   final

  public void debug(java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String format
        start local 2 // java.lang.Object[] arg
         0: .line 29
            aload 0 /* this */
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            aload 1 /* format */
            aload 2 /* arg */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 30
            return
        end local 2 // java.lang.Object[] arg
        end local 1 // java.lang.String format
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1  format  Ljava/lang/String;
            0    2     2     arg  [Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      format  final
      arg     final

  public void debug(java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String msg
        start local 2 // java.lang.Throwable t
         0: .line 34
            aload 0 /* this */
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            aload 1 /* msg */
            aload 2 /* t */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 36
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.String msg
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1   msg  Ljava/lang/String;
            0    2     2     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      msg   final
      t     final

  public void error(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String msg
         0: .line 40
            aload 0 /* this */
            getstatic java.util.logging.Level.SEVERE:Ljava/util/logging/Level;
            aload 1 /* msg */
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 42
            return
        end local 1 // java.lang.String msg
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1   msg  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      msg   final

  public void error(java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String format
        start local 2 // java.lang.Object[] arg
         0: .line 46
            aload 0 /* this */
            getstatic java.util.logging.Level.SEVERE:Ljava/util/logging/Level;
            aload 1 /* format */
            aload 2 /* arg */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 48
            return
        end local 2 // java.lang.Object[] arg
        end local 1 // java.lang.String format
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1  format  Ljava/lang/String;
            0    2     2     arg  [Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      format  final
      arg     final

  public void error(java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String msg
        start local 2 // java.lang.Throwable t
         0: .line 52
            aload 0 /* this */
            getstatic java.util.logging.Level.SEVERE:Ljava/util/logging/Level;
            aload 1 /* msg */
            aload 2 /* t */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 53
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.String msg
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1   msg  Ljava/lang/String;
            0    2     2     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      msg   final
      t     final

  public void info(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String msg
         0: .line 57
            aload 0 /* this */
            getstatic java.util.logging.Level.INFO:Ljava/util/logging/Level;
            aload 1 /* msg */
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 58
            return
        end local 1 // java.lang.String msg
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1   msg  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      msg   final

  public void info(java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String format
        start local 2 // java.lang.Object[] arg
         0: .line 62
            aload 0 /* this */
            getstatic java.util.logging.Level.INFO:Ljava/util/logging/Level;
            aload 1 /* format */
            aload 2 /* arg */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 63
            return
        end local 2 // java.lang.Object[] arg
        end local 1 // java.lang.String format
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1  format  Ljava/lang/String;
            0    2     2     arg  [Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      format  final
      arg     final

  public void info(java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String msg
        start local 2 // java.lang.Throwable t
         0: .line 67
            aload 0 /* this */
            getstatic java.util.logging.Level.INFO:Ljava/util/logging/Level;
            aload 1 /* msg */
            aload 2 /* t */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 68
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.String msg
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1   msg  Ljava/lang/String;
            0    2     2     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      msg   final
      t     final

  public boolean isDebugEnabled();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
         0: .line 72
            aload 0 /* this */
            getfield org.mongodb.morphia.logging.jdk.JDKLogger.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ireturn
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;

  public boolean isErrorEnabled();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
         0: .line 77
            aload 0 /* this */
            getfield org.mongodb.morphia.logging.jdk.JDKLogger.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.SEVERE:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ireturn
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;

  public boolean isInfoEnabled();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
         0: .line 82
            aload 0 /* this */
            getfield org.mongodb.morphia.logging.jdk.JDKLogger.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.INFO:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ireturn
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;

  public boolean isTraceEnabled();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
         0: .line 87
            aload 0 /* this */
            getfield org.mongodb.morphia.logging.jdk.JDKLogger.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ireturn
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;

  public boolean isWarningEnabled();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
         0: .line 92
            aload 0 /* this */
            getfield org.mongodb.morphia.logging.jdk.JDKLogger.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.WARNING:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ireturn
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;

  public void trace(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String msg
         0: .line 97
            aload 0 /* this */
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            aload 1 /* msg */
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 98
            return
        end local 1 // java.lang.String msg
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1   msg  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      msg   final

  public void trace(java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String format
        start local 2 // java.lang.Object[] arg
         0: .line 102
            aload 0 /* this */
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            aload 1 /* format */
            aload 2 /* arg */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 103
            return
        end local 2 // java.lang.Object[] arg
        end local 1 // java.lang.String format
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1  format  Ljava/lang/String;
            0    2     2     arg  [Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      format  final
      arg     final

  public void trace(java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String msg
        start local 2 // java.lang.Throwable t
         0: .line 107
            aload 0 /* this */
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            aload 1 /* msg */
            aload 2 /* t */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 108
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.String msg
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1   msg  Ljava/lang/String;
            0    2     2     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      msg   final
      t     final

  public void warning(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String msg
         0: .line 112
            aload 0 /* this */
            getstatic java.util.logging.Level.WARNING:Ljava/util/logging/Level;
            aload 1 /* msg */
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 113
            return
        end local 1 // java.lang.String msg
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1   msg  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      msg   final

  public void warning(java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String format
        start local 2 // java.lang.Object[] arg
         0: .line 117
            aload 0 /* this */
            getstatic java.util.logging.Level.WARNING:Ljava/util/logging/Level;
            aload 1 /* format */
            aload 2 /* arg */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
         1: .line 118
            return
        end local 2 // java.lang.Object[] arg
        end local 1 // java.lang.String format
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1  format  Ljava/lang/String;
            0    2     2     arg  [Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      format  final
      arg     final

  public void warning(java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.lang.String msg
        start local 2 // java.lang.Throwable t
         0: .line 122
            aload 0 /* this */
            getstatic java.util.logging.Level.WARNING:Ljava/util/logging/Level;
            aload 1 /* msg */
            aload 2 /* t */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
         1: .line 123
            return
        end local 2 // java.lang.Throwable t
        end local 1 // java.lang.String msg
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    2     1   msg  Ljava/lang/String;
            0    2     2     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      msg   final
      t     final

  protected java.lang.String[] getCaller();
    descriptor: ()[Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=8, args_size=1
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
         0: .line 129
            new java.lang.Throwable
            dup
            invokespecial java.lang.Throwable.<init>:()V
            invokevirtual java.lang.Throwable.getStackTrace:()[Ljava/lang/StackTraceElement;
            astore 1 /* stack */
        start local 1 // java.lang.StackTraceElement[] stack
         1: .line 130
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            astore 2 /* loggerClassname */
        start local 2 // java.lang.String loggerClassname
         2: .line 135
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         3: .line 136
            goto 9
         4: .line 137
      StackMap locals: org.mongodb.morphia.logging.jdk.JDKLogger java.lang.StackTraceElement[] java.lang.String top top int
      StackMap stack:
            aload 1 /* stack */
            iload 5 /* i */
            aaload
            astore 6 /* ste */
        start local 6 // java.lang.StackTraceElement ste
         5: .line 138
            aload 6 /* ste */
            invokevirtual java.lang.StackTraceElement.getClassName:()Ljava/lang/String;
            astore 7 /* fc */
        start local 7 // java.lang.String fc
         6: .line 139
            aload 7 /* fc */
            aload 2 /* loggerClassname */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 8
         7: .line 140
            goto 10
         8: .line 143
      StackMap locals: java.lang.StackTraceElement java.lang.String
      StackMap stack:
            iinc 5 /* i */ 1
        end local 7 // java.lang.String fc
        end local 6 // java.lang.StackTraceElement ste
         9: .line 136
      StackMap locals:
      StackMap stack:
            iload 5 /* i */
            aload 1 /* stack */
            arraylength
            if_icmplt 4
        10: .line 147
      StackMap locals:
      StackMap stack:
            iinc 5 /* i */ 1
        11: .line 149
            goto 19
        12: .line 150
      StackMap locals:
      StackMap stack:
            aload 1 /* stack */
            iload 5 /* i */
            aaload
            astore 6 /* ste */
        start local 6 // java.lang.StackTraceElement ste
        13: .line 151
            aload 6 /* ste */
            invokevirtual java.lang.StackTraceElement.getClassName:()Ljava/lang/String;
            astore 7 /* fc */
        start local 7 // java.lang.String fc
        14: .line 152
            aload 7 /* fc */
            aload 2 /* loggerClassname */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 18
        15: .line 153
            aload 6 /* ste */
            invokevirtual java.lang.StackTraceElement.getMethodName:()Ljava/lang/String;
            astore 4 /* callerMethod */
        start local 4 // java.lang.String callerMethod
        16: .line 154
            aload 7 /* fc */
            astore 3 /* callerName */
        start local 3 // java.lang.String callerName
        17: .line 155
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
            aload 3 /* callerName */
            aastore
            dup
            iconst_1
            aload 4 /* callerMethod */
            aastore
            areturn
        end local 4 // java.lang.String callerMethod
        end local 3 // java.lang.String callerName
        18: .line 157
      StackMap locals: java.lang.StackTraceElement java.lang.String
      StackMap stack:
            iinc 5 /* i */ 1
        end local 7 // java.lang.String fc
        end local 6 // java.lang.StackTraceElement ste
        19: .line 149
      StackMap locals:
      StackMap stack:
            iload 5 /* i */
            aload 1 /* stack */
            arraylength
            if_icmplt 12
        20: .line 159
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
            ldc ""
            aastore
            dup
            iconst_1
            ldc ""
            aastore
            areturn
        end local 5 // int i
        end local 2 // java.lang.String loggerClassname
        end local 1 // java.lang.StackTraceElement[] stack
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   21     0             this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            1   21     1            stack  [Ljava/lang/StackTraceElement;
            2   21     2  loggerClassname  Ljava/lang/String;
           17   18     3       callerName  Ljava/lang/String;
           16   18     4     callerMethod  Ljava/lang/String;
            3   21     5                i  I
            5    9     6              ste  Ljava/lang/StackTraceElement;
            6    9     7               fc  Ljava/lang/String;
           13   19     6              ste  Ljava/lang/StackTraceElement;
           14   19     7               fc  Ljava/lang/String;

  protected void log(java.util.logging.Level, java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0084) ACC_PROTECTED, ACC_VARARGS
    Code:
      stack=6, locals=5, args_size=4
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.util.logging.Level l
        start local 2 // java.lang.String f
        start local 3 // java.lang.Object[] a
         0: .line 163
            aload 0 /* this */
            getfield org.mongodb.morphia.logging.jdk.JDKLogger.logger:Ljava/util/logging/Logger;
            aload 1 /* l */
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 3
         1: .line 164
            aload 0 /* this */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.getCaller:()[Ljava/lang/String;
            astore 4 /* callerInfo */
        start local 4 // java.lang.String[] callerInfo
         2: .line 165
            aload 0 /* this */
            getfield org.mongodb.morphia.logging.jdk.JDKLogger.logger:Ljava/util/logging/Logger;
            aload 1 /* l */
            aload 4 /* callerInfo */
            iconst_0
            aaload
            aload 4 /* callerInfo */
            iconst_1
            aaload
            aload 2 /* f */
            aload 3 /* a */
            invokevirtual java.util.logging.Logger.logp:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
        end local 4 // java.lang.String[] callerInfo
         3: .line 167
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.Object[] a
        end local 2 // java.lang.String f
        end local 1 // java.util.logging.Level l
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0        this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    4     1           l  Ljava/util/logging/Level;
            0    4     2           f  Ljava/lang/String;
            0    4     3           a  [Ljava/lang/Object;
            2    3     4  callerInfo  [Ljava/lang/String;
    MethodParameters:
      Name  Flags
      l     final
      f     final
      a     final

  protected void log(java.util.logging.Level, java.lang.String, java.lang.Throwable);
    descriptor: (Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=5, args_size=4
        start local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
        start local 1 // java.util.logging.Level l
        start local 2 // java.lang.String m
        start local 3 // java.lang.Throwable t
         0: .line 170
            aload 0 /* this */
            getfield org.mongodb.morphia.logging.jdk.JDKLogger.logger:Ljava/util/logging/Logger;
            aload 1 /* l */
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 3
         1: .line 171
            aload 0 /* this */
            invokevirtual org.mongodb.morphia.logging.jdk.JDKLogger.getCaller:()[Ljava/lang/String;
            astore 4 /* callerInfo */
        start local 4 // java.lang.String[] callerInfo
         2: .line 172
            aload 0 /* this */
            getfield org.mongodb.morphia.logging.jdk.JDKLogger.logger:Ljava/util/logging/Logger;
            aload 1 /* l */
            aload 4 /* callerInfo */
            iconst_0
            aaload
            aload 4 /* callerInfo */
            iconst_1
            aaload
            aload 2 /* m */
            aload 3 /* t */
            invokevirtual java.util.logging.Logger.logp:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 4 // java.lang.String[] callerInfo
         3: .line 174
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.Throwable t
        end local 2 // java.lang.String m
        end local 1 // java.util.logging.Level l
        end local 0 // org.mongodb.morphia.logging.jdk.JDKLogger this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0        this  Lorg/mongodb/morphia/logging/jdk/JDKLogger;
            0    4     1           l  Ljava/util/logging/Level;
            0    4     2           m  Ljava/lang/String;
            0    4     3           t  Ljava/lang/Throwable;
            2    3     4  callerInfo  [Ljava/lang/String;
    MethodParameters:
      Name  Flags
      l     final
      m     final
      t     final
}
SourceFile: "JDKLogger.java"