public abstract class sun.rmi.runtime.Log
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: sun.rmi.runtime.Log
  super_class: java.lang.Object
{
  public static final java.util.logging.Level BRIEF;
    descriptor: Ljava/util/logging/Level;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  public static final java.util.logging.Level VERBOSE;
    descriptor: Ljava/util/logging/Level;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  private static final sun.rmi.runtime.Log$LogFactory logFactory;
    descriptor: Lsun/rmi/runtime/Log$LogFactory;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 62
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            putstatic sun.rmi.runtime.Log.BRIEF:Ljava/util/logging/Level;
         1: .line 63
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            putstatic sun.rmi.runtime.Log.VERBOSE:Ljava/util/logging/Level;
         2: .line 69
            invokedynamic run()Ljava/security/PrivilegedAction;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()Ljava/lang/Object;
                  sun/rmi/runtime/Log.lambda$0()Ljava/lang/Boolean; (6)
                  ()Ljava/lang/Boolean;
         3: .line 68
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            istore 0 /* useOld */
        start local 0 // boolean useOld
         4: .line 72
            iload 0 /* useOld */
            ifeq 5
            new sun.rmi.runtime.Log$LogStreamLogFactory
            dup
            invokespecial sun.rmi.runtime.Log$LogStreamLogFactory.<init>:()V
            goto 6
         5: .line 73
      StackMap locals: int
      StackMap stack:
            new sun.rmi.runtime.Log$LoggerLogFactory
            dup
            invokespecial sun.rmi.runtime.Log$LoggerLogFactory.<init>:()V
         6: .line 72
      StackMap locals:
      StackMap stack: sun.rmi.runtime.Log$LogFactory
            putstatic sun.rmi.runtime.Log.logFactory:Lsun/rmi/runtime/Log$LogFactory;
        end local 0 // boolean useOld
         7: .line 74
            return
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            4    7     0  useOld  Z

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.rmi.runtime.Log this
         0: .line 59
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // sun.rmi.runtime.Log this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/rmi/runtime/Log;

  public abstract boolean isLoggable(java.util.logging.Level);
    descriptor: (Ljava/util/logging/Level;)Z
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
       Name  Flags
      level  

  public abstract void log(java.util.logging.Level, java.lang.String);
    descriptor: (Ljava/util/logging/Level;Ljava/lang/String;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
         Name  Flags
      level    
      message  

  public abstract 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: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
         Name  Flags
      level    
      message  
      thrown   

  public abstract void setOutputStream(java.io.OutputStream);
    descriptor: (Ljava/io/OutputStream;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    MethodParameters:
        Name  Flags
      stream  

  public abstract java.io.PrintStream getPrintStream();
    descriptor: ()Ljava/io/PrintStream;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public static sun.rmi.runtime.Log getLog(java.lang.String, java.lang.String, int);
    descriptor: (Ljava/lang/String;Ljava/lang/String;I)Lsun/rmi/runtime/Log;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // java.lang.String loggerName
        start local 1 // java.lang.String oldLogName
        start local 2 // int override
         0: .line 117
            iload 2 /* override */
            ifge 3
         1: .line 118
            aconst_null
            astore 3 /* level */
        start local 3 // java.util.logging.Level level
         2: .line 119
            goto 15
        end local 3 // java.util.logging.Level level
      StackMap locals:
      StackMap stack:
         3: iload 2 /* override */
            ifne 6
         4: .line 120
            getstatic java.util.logging.Level.OFF:Ljava/util/logging/Level;
            astore 3 /* level */
        start local 3 // java.util.logging.Level level
         5: .line 121
            goto 15
        end local 3 // java.util.logging.Level level
      StackMap locals:
      StackMap stack:
         6: iload 2 /* override */
            ifle 10
         7: .line 122
            iload 2 /* override */
            bipush 10
            if_icmpgt 10
         8: .line 123
            getstatic sun.rmi.runtime.Log.BRIEF:Ljava/util/logging/Level;
            astore 3 /* level */
        start local 3 // java.util.logging.Level level
         9: .line 124
            goto 15
        end local 3 // java.util.logging.Level level
      StackMap locals:
      StackMap stack:
        10: iload 2 /* override */
            bipush 10
            if_icmple 14
        11: .line 125
            iload 2 /* override */
            bipush 20
            if_icmpgt 14
        12: .line 127
            getstatic sun.rmi.runtime.Log.VERBOSE:Ljava/util/logging/Level;
            astore 3 /* level */
        start local 3 // java.util.logging.Level level
        13: .line 128
            goto 15
        end local 3 // java.util.logging.Level level
        14: .line 129
      StackMap locals:
      StackMap stack:
            getstatic java.util.logging.Level.FINEST:Ljava/util/logging/Level;
            astore 3 /* level */
        start local 3 // java.util.logging.Level level
        15: .line 131
      StackMap locals: java.util.logging.Level
      StackMap stack:
            getstatic sun.rmi.runtime.Log.logFactory:Lsun/rmi/runtime/Log$LogFactory;
            aload 0 /* loggerName */
            aload 1 /* oldLogName */
            aload 3 /* level */
            invokeinterface sun.rmi.runtime.Log$LogFactory.createLog:(Ljava/lang/String;Ljava/lang/String;Ljava/util/logging/Level;)Lsun/rmi/runtime/Log;
            areturn
        end local 3 // java.util.logging.Level level
        end local 2 // int override
        end local 1 // java.lang.String oldLogName
        end local 0 // java.lang.String loggerName
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   16     0  loggerName  Ljava/lang/String;
            0   16     1  oldLogName  Ljava/lang/String;
            0   16     2    override  I
            2    3     3       level  Ljava/util/logging/Level;
            5    6     3       level  Ljava/util/logging/Level;
            9   10     3       level  Ljava/util/logging/Level;
           13   14     3       level  Ljava/util/logging/Level;
           15   16     3       level  Ljava/util/logging/Level;
    MethodParameters:
            Name  Flags
      loggerName  
      oldLogName  
      override    

  public static sun.rmi.runtime.Log getLog(java.lang.String, java.lang.String, boolean);
    descriptor: (Ljava/lang/String;Ljava/lang/String;Z)Lsun/rmi/runtime/Log;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // java.lang.String loggerName
        start local 1 // java.lang.String oldLogName
        start local 2 // boolean override
         0: .line 144
            iload 2 /* override */
            ifeq 1
            getstatic sun.rmi.runtime.Log.VERBOSE:Ljava/util/logging/Level;
            goto 2
      StackMap locals:
      StackMap stack:
         1: aconst_null
      StackMap locals:
      StackMap stack: java.util.logging.Level
         2: astore 3 /* level */
        start local 3 // java.util.logging.Level level
         3: .line 145
            getstatic sun.rmi.runtime.Log.logFactory:Lsun/rmi/runtime/Log$LogFactory;
            aload 0 /* loggerName */
            aload 1 /* oldLogName */
            aload 3 /* level */
            invokeinterface sun.rmi.runtime.Log$LogFactory.createLog:(Ljava/lang/String;Ljava/lang/String;Ljava/util/logging/Level;)Lsun/rmi/runtime/Log;
            areturn
        end local 3 // java.util.logging.Level level
        end local 2 // boolean override
        end local 1 // java.lang.String oldLogName
        end local 0 // java.lang.String loggerName
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0  loggerName  Ljava/lang/String;
            0    4     1  oldLogName  Ljava/lang/String;
            0    4     2    override  Z
            3    4     3       level  Ljava/util/logging/Level;
    MethodParameters:
            Name  Flags
      loggerName  
      oldLogName  
      override    

  private static java.lang.String[] getSource();
    descriptor: ()[Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=1, args_size=0
         0: .line 447
            new java.lang.Exception
            dup
            invokespecial java.lang.Exception.<init>:()V
            invokevirtual java.lang.Exception.getStackTrace:()[Ljava/lang/StackTraceElement;
            astore 0 /* trace */
        start local 0 // java.lang.StackTraceElement[] trace
         1: .line 448
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
         2: .line 449
            aload 0 /* trace */
            iconst_3
            aaload
            invokevirtual java.lang.StackTraceElement.getClassName:()Ljava/lang/String;
            aastore
            dup
            iconst_1
         3: .line 450
            aload 0 /* trace */
            iconst_3
            aaload
            invokevirtual java.lang.StackTraceElement.getMethodName:()Ljava/lang/String;
            aastore
         4: .line 448
            areturn
        end local 0 // java.lang.StackTraceElement[] trace
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            1    5     0  trace  [Ljava/lang/StackTraceElement;

  private static java.lang.Boolean lambda$0();
    descriptor: ()Ljava/lang/Boolean;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 69
            ldc "sun.rmi.log.useOld"
            invokestatic java.lang.Boolean.getBoolean:(Ljava/lang/String;)Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "Log.java"
NestMembers:
  sun.rmi.runtime.Log$InternalStreamHandler  sun.rmi.runtime.Log$LogFactory  sun.rmi.runtime.Log$LogStreamLog  sun.rmi.runtime.Log$LogStreamLogFactory  sun.rmi.runtime.Log$LoggerLog  sun.rmi.runtime.Log$LoggerLog$1  sun.rmi.runtime.Log$LoggerLog$2  sun.rmi.runtime.Log$LoggerLogFactory  sun.rmi.runtime.Log$LoggerPrintStream
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  private InternalStreamHandler = sun.rmi.runtime.Log$InternalStreamHandler of sun.rmi.runtime.Log
  private abstract LogFactory = sun.rmi.runtime.Log$LogFactory of sun.rmi.runtime.Log
  private LogStreamLog = sun.rmi.runtime.Log$LogStreamLog of sun.rmi.runtime.Log
  private LogStreamLogFactory = sun.rmi.runtime.Log$LogStreamLogFactory of sun.rmi.runtime.Log
  private LoggerLog = sun.rmi.runtime.Log$LoggerLog of sun.rmi.runtime.Log
  private LoggerLogFactory = sun.rmi.runtime.Log$LoggerLogFactory of sun.rmi.runtime.Log
  private LoggerPrintStream = sun.rmi.runtime.Log$LoggerPrintStream of sun.rmi.runtime.Log