public class com.oracle.svm.hosted.LoggingFeature implements org.graalvm.nativeimage.hosted.Feature
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: com.oracle.svm.hosted.LoggingFeature
  super_class: java.lang.Object
{
  private final boolean trace;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.oracle.svm.hosted.LoggingFeature this
         0: .line 40
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 50
            aload 0 /* this */
            getstatic com.oracle.svm.hosted.LoggingFeature$Options.TraceLoggingFeature:Lcom/oracle/svm/core/option/HostedOptionKey;
            invokevirtual com.oracle.svm.core.option.HostedOptionKey.getValue:()Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            putfield com.oracle.svm.hosted.LoggingFeature.trace:Z
         2: .line 52
            aload 0 /* this */
            iconst_0
            putfield com.oracle.svm.hosted.LoggingFeature.reflectionConfigured:Z
         3: .line 40
            return
        end local 0 // com.oracle.svm.hosted.LoggingFeature this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lcom/oracle/svm/hosted/LoggingFeature;

  public boolean isInConfiguration(org.graalvm.nativeimage.hosted.Feature$IsInConfigurationAccess);
    descriptor: (Lorg/graalvm/nativeimage/hosted/Feature$IsInConfigurationAccess;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // com.oracle.svm.hosted.LoggingFeature this
        start local 1 // org.graalvm.nativeimage.hosted.Feature$IsInConfigurationAccess access
         0: .line 56
            getstatic com.oracle.svm.hosted.LoggingFeature$Options.EnableLoggingFeature:Lcom/oracle/svm/core/option/HostedOptionKey;
            invokevirtual com.oracle.svm.core.option.HostedOptionKey.getValue:()Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ireturn
        end local 1 // org.graalvm.nativeimage.hosted.Feature$IsInConfigurationAccess access
        end local 0 // com.oracle.svm.hosted.LoggingFeature this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lcom/oracle/svm/hosted/LoggingFeature;
            0    1     1  access  Lorg/graalvm/nativeimage/hosted/Feature$IsInConfigurationAccess;
    MethodParameters:
        Name  Flags
      access  

  public void duringSetup(org.graalvm.nativeimage.hosted.Feature$DuringSetupAccess);
    descriptor: (Lorg/graalvm/nativeimage/hosted/Feature$DuringSetupAccess;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // com.oracle.svm.hosted.LoggingFeature this
        start local 1 // org.graalvm.nativeimage.hosted.Feature$DuringSetupAccess access
         0: .line 62
            invokestatic java.util.logging.LogManager.getLogManager:()Ljava/util/logging/LogManager;
            pop
         1: .line 63
            return
        end local 1 // org.graalvm.nativeimage.hosted.Feature$DuringSetupAccess access
        end local 0 // com.oracle.svm.hosted.LoggingFeature this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lcom/oracle/svm/hosted/LoggingFeature;
            0    2     1  access  Lorg/graalvm/nativeimage/hosted/Feature$DuringSetupAccess;
    MethodParameters:
        Name  Flags
      access  

  public void duringAnalysis(org.graalvm.nativeimage.hosted.Feature$DuringAnalysisAccess);
    descriptor: (Lorg/graalvm/nativeimage/hosted/Feature$DuringAnalysisAccess;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // com.oracle.svm.hosted.LoggingFeature this
        start local 1 // org.graalvm.nativeimage.hosted.Feature$DuringAnalysisAccess a
         0: .line 67
            aload 1 /* a */
            checkcast com.oracle.svm.hosted.FeatureImpl$DuringAnalysisAccessImpl
            astore 2 /* access */
        start local 2 // com.oracle.svm.hosted.FeatureImpl$DuringAnalysisAccessImpl access
         1: .line 69
            aload 0 /* this */
            getfield com.oracle.svm.hosted.LoggingFeature.reflectionConfigured:Z
            ifne 6
            aload 2 /* access */
            invokevirtual com.oracle.svm.hosted.FeatureImpl$DuringAnalysisAccessImpl.getMetaAccess:()Lcom/oracle/graal/pointsto/meta/AnalysisMetaAccess;
            ldc Ljava/util/logging/Logger;
            invokevirtual com.oracle.graal.pointsto.meta.AnalysisMetaAccess.optionalLookupJavaType:(Ljava/lang/Class;)Ljava/util/Optional;
            invokevirtual java.util.Optional.isPresent:()Z
            ifeq 6
         2: .line 70
            aload 0 /* this */
            ldc Ljava/util/logging/ConsoleHandler;
            invokevirtual com.oracle.svm.hosted.LoggingFeature.registerForReflection:(Ljava/lang/Class;)V
         3: .line 71
            aload 0 /* this */
            ldc Ljava/util/logging/SimpleFormatter;
            invokevirtual com.oracle.svm.hosted.LoggingFeature.registerForReflection:(Ljava/lang/Class;)V
         4: .line 73
            aload 0 /* this */
            iconst_1
            putfield com.oracle.svm.hosted.LoggingFeature.reflectionConfigured:Z
         5: .line 75
            aload 2 /* access */
            invokevirtual com.oracle.svm.hosted.FeatureImpl$DuringAnalysisAccessImpl.requireAnalysisIteration:()V
         6: .line 77
      StackMap locals: com.oracle.svm.hosted.FeatureImpl$DuringAnalysisAccessImpl
      StackMap stack:
            return
        end local 2 // com.oracle.svm.hosted.FeatureImpl$DuringAnalysisAccessImpl access
        end local 1 // org.graalvm.nativeimage.hosted.Feature$DuringAnalysisAccess a
        end local 0 // com.oracle.svm.hosted.LoggingFeature this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    7     0    this  Lcom/oracle/svm/hosted/LoggingFeature;
            0    7     1       a  Lorg/graalvm/nativeimage/hosted/Feature$DuringAnalysisAccess;
            1    7     2  access  Lcom/oracle/svm/hosted/FeatureImpl$DuringAnalysisAccessImpl;
    MethodParameters:
      Name  Flags
      a     

  private void registerForReflection(java.lang.Class<?>);
    descriptor: (Ljava/lang/Class;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // com.oracle.svm.hosted.LoggingFeature this
        start local 1 // java.lang.Class clazz
         0: .line 81
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "Registering "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* clazz */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " for reflection."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual com.oracle.svm.hosted.LoggingFeature.trace:(Ljava/lang/String;)V
            iconst_1
            anewarray java.lang.Class
            dup
            iconst_0
         1: .line 82
            aload 1 /* clazz */
            aastore
            invokestatic org.graalvm.nativeimage.hosted.RuntimeReflection.register:([Ljava/lang/Class;)V
            iconst_1
            anewarray java.lang.reflect.Executable
            dup
            iconst_0
         2: .line 83
            aload 1 /* clazz */
            iconst_0
            anewarray java.lang.Class
            invokevirtual java.lang.Class.getConstructor:([Ljava/lang/Class;)Ljava/lang/reflect/Constructor;
            aastore
            invokestatic org.graalvm.nativeimage.hosted.RuntimeReflection.register:([Ljava/lang/reflect/Executable;)V
         3: .line 84
            goto 6
      StackMap locals:
      StackMap stack: java.lang.NoSuchMethodException
         4: astore 2 /* e */
        start local 2 // java.lang.NoSuchMethodException e
         5: .line 85
            aload 2 /* e */
            invokestatic com.oracle.svm.core.util.VMError.shouldNotReachHere:(Ljava/lang/Throwable;)Ljava/lang/RuntimeException;
            pop
        end local 2 // java.lang.NoSuchMethodException e
         6: .line 87
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Class clazz
        end local 0 // com.oracle.svm.hosted.LoggingFeature this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    7     0   this  Lcom/oracle/svm/hosted/LoggingFeature;
            0    7     1  clazz  Ljava/lang/Class<*>;
            5    6     2      e  Ljava/lang/NoSuchMethodException;
      Exception table:
        from    to  target  type
           0     3       4  Class java.lang.NoSuchMethodException
    Signature: (Ljava/lang/Class<*>;)V
    MethodParameters:
       Name  Flags
      clazz  

  private void trace(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // com.oracle.svm.hosted.LoggingFeature this
        start local 1 // java.lang.String msg
         0: .line 90
            aload 0 /* this */
            getfield com.oracle.svm.hosted.LoggingFeature.trace:Z
            ifeq 2
         1: .line 91
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "LoggingFeature: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* msg */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 93
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String msg
        end local 0 // com.oracle.svm.hosted.LoggingFeature this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/oracle/svm/hosted/LoggingFeature;
            0    3     1   msg  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      msg   
}
SourceFile: "LoggingFeature.java"
NestMembers:
  com.oracle.svm.hosted.LoggingFeature$Options
InnerClasses:
  public DuringAnalysisAccessImpl = com.oracle.svm.hosted.FeatureImpl$DuringAnalysisAccessImpl of com.oracle.svm.hosted.FeatureImpl
  public Options = com.oracle.svm.hosted.LoggingFeature$Options of com.oracle.svm.hosted.LoggingFeature
  public abstract DuringAnalysisAccess = org.graalvm.nativeimage.hosted.Feature$DuringAnalysisAccess of org.graalvm.nativeimage.hosted.Feature
  public abstract DuringSetupAccess = org.graalvm.nativeimage.hosted.Feature$DuringSetupAccess of org.graalvm.nativeimage.hosted.Feature
  public abstract IsInConfigurationAccess = org.graalvm.nativeimage.hosted.Feature$IsInConfigurationAccess of org.graalvm.nativeimage.hosted.Feature
    RuntimeVisibleAnnotations: 
      com.oracle.svm.core.annotate.AutomaticFeature()