public class io.dropwizard.logging.DefaultLoggingFactory implements io.dropwizard.logging.LoggingFactory
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: io.dropwizard.logging.DefaultLoggingFactory
  super_class: java.lang.Object
{
  private static final java.util.concurrent.locks.ReentrantLock MBEAN_REGISTRATION_LOCK;
    descriptor: Ljava/util/concurrent/locks/ReentrantLock;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.util.concurrent.locks.ReentrantLock CHANGE_LOGGER_CONTEXT_LOCK;
    descriptor: Ljava/util/concurrent/locks/ReentrantLock;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private java.lang.String level;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    RuntimeVisibleAnnotations: 
      javax.validation.constraints.NotNull()
    RuntimeVisibleTypeAnnotations: 
      FIELD
        javax.validation.constraints.NotNull()

  private java.util.Map<java.lang.String, com.fasterxml.jackson.databind.JsonNode> loggers;
    descriptor: Ljava/util/Map;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Map<Ljava/lang/String;Lcom/fasterxml/jackson/databind/JsonNode;>;
    RuntimeVisibleAnnotations: 
      javax.validation.constraints.NotNull()
    RuntimeVisibleTypeAnnotations: 
      FIELD
        javax.validation.constraints.NotNull()

  private java.util.List<io.dropwizard.logging.AppenderFactory<ch.qos.logback.classic.spi.ILoggingEvent>> appenders;
    descriptor: Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/List<Lio/dropwizard/logging/AppenderFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;>;
    RuntimeVisibleAnnotations: 
      javax.validation.Valid()
      javax.validation.constraints.NotNull()
    RuntimeVisibleTypeAnnotations: 
      FIELD
        javax.validation.Valid()
      FIELD
        javax.validation.constraints.NotNull()

  private final ch.qos.logback.classic.LoggerContext loggerContext;
    descriptor: Lch/qos/logback/classic/LoggerContext;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonIgnore()

  private final java.io.PrintStream configurationErrorsStream;
    descriptor: Ljava/io/PrintStream;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonIgnore()

  private volatile java.lang.String loggerName;
    descriptor: Ljava/lang/String;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonIgnore()
      javax.annotation.Nullable()

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 54
            new java.util.concurrent.locks.ReentrantLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
            putstatic io.dropwizard.logging.DefaultLoggingFactory.MBEAN_REGISTRATION_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
         1: .line 55
            new java.util.concurrent.locks.ReentrantLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
            putstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
         0: .line 78
            aload 0 /* this */
            invokestatic io.dropwizard.logging.LoggingUtil.getLoggerContext:()Lch/qos/logback/classic/LoggerContext;
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            invokespecial io.dropwizard.logging.DefaultLoggingFactory.<init>:(Lch/qos/logback/classic/LoggerContext;Ljava/io/PrintStream;)V
         1: .line 79
            return
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/dropwizard/logging/DefaultLoggingFactory;

  void <init>(ch.qos.logback.classic.LoggerContext, java.io.PrintStream);
    descriptor: (Lch/qos/logback/classic/LoggerContext;Ljava/io/PrintStream;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
        start local 1 // ch.qos.logback.classic.LoggerContext loggerContext
        start local 2 // java.io.PrintStream configurationErrorsStream
         0: .line 82
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 58
            aload 0 /* this */
            ldc "INFO"
            putfield io.dropwizard.logging.DefaultLoggingFactory.level:Ljava/lang/String;
         2: .line 61
            aload 0 /* this */
            invokestatic java.util.Collections.emptyMap:()Ljava/util/Map;
            putfield io.dropwizard.logging.DefaultLoggingFactory.loggers:Ljava/util/Map;
         3: .line 65
            aload 0 /* this */
            new io.dropwizard.logging.ConsoleAppenderFactory
            dup
            invokespecial io.dropwizard.logging.ConsoleAppenderFactory.<init>:()V
            invokestatic java.util.Collections.singletonList:(Ljava/lang/Object;)Ljava/util/List;
            putfield io.dropwizard.logging.DefaultLoggingFactory.appenders:Ljava/util/List;
         4: .line 83
            aload 0 /* this */
            aconst_null
            putfield io.dropwizard.logging.DefaultLoggingFactory.loggerName:Ljava/lang/String;
         5: .line 84
            aload 0 /* this */
            aload 1 /* loggerContext */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast ch.qos.logback.classic.LoggerContext
            putfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
         6: .line 85
            aload 0 /* this */
            aload 2 /* configurationErrorsStream */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.io.PrintStream
            putfield io.dropwizard.logging.DefaultLoggingFactory.configurationErrorsStream:Ljava/io/PrintStream;
         7: .line 86
            return
        end local 2 // java.io.PrintStream configurationErrorsStream
        end local 1 // ch.qos.logback.classic.LoggerContext loggerContext
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot                       Name  Signature
            0    8     0                       this  Lio/dropwizard/logging/DefaultLoggingFactory;
            0    8     1              loggerContext  Lch/qos/logback/classic/LoggerContext;
            0    8     2  configurationErrorsStream  Ljava/io/PrintStream;
    MethodParameters:
                           Name  Flags
      loggerContext              
      configurationErrorsStream  

  ch.qos.logback.classic.LoggerContext getLoggerContext();
    descriptor: ()Lch/qos/logback/classic/LoggerContext;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
         0: .line 89
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            areturn
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/DefaultLoggingFactory;

  java.io.PrintStream getConfigurationErrorsStream();
    descriptor: ()Ljava/io/PrintStream;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
         0: .line 93
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.configurationErrorsStream:Ljava/io/PrintStream;
            areturn
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/DefaultLoggingFactory;

  void clear();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
         0: .line 102
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerName:Ljava/lang/String;
            astore 1 /* name */
        start local 1 // java.lang.String name
         1: .line 103
            aload 1 /* name */
            ifnull 13
         2: .line 104
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         3: .line 106
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            invokevirtual ch.qos.logback.classic.LoggerContext.stop:()V
         4: .line 108
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            ldc "ROOT"
            invokevirtual ch.qos.logback.classic.LoggerContext.getLogger:(Ljava/lang/String;)Lch/qos/logback/classic/Logger;
            astore 2 /* logger */
        start local 2 // ch.qos.logback.classic.Logger logger
         5: .line 109
            aload 2 /* logger */
            invokevirtual ch.qos.logback.classic.Logger.detachAndStopAllAppenders:()V
         6: .line 112
            aload 0 /* this */
            aload 1 /* name */
            invokevirtual io.dropwizard.logging.DefaultLoggingFactory.configureLoggers:(Ljava/lang/String;)Lch/qos/logback/classic/Logger;
            pop
        end local 2 // ch.qos.logback.classic.Logger logger
         7: .line 113
            goto 11
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory java.lang.String
      StackMap stack: java.lang.Throwable
         8: astore 3
         9: .line 114
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        10: .line 115
            aload 3
            athrow
        11: .line 114
      StackMap locals:
      StackMap stack:
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        12: .line 117
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokestatic ch.qos.logback.core.util.StatusPrinter.setPrintStream:(Ljava/io/PrintStream;)V
        13: .line 119
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String name
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   14     0    this  Lio/dropwizard/logging/DefaultLoggingFactory;
            1   14     1    name  Ljava/lang/String;
            5    7     2  logger  Lch/qos/logback/classic/Logger;
      Exception table:
        from    to  target  type
           3     8       8  any

  public java.lang.String getLevel();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
         0: .line 123
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.level:Ljava/lang/String;
            areturn
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/DefaultLoggingFactory;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()

  public void setLevel(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
        start local 1 // java.lang.String level
         0: .line 128
            aload 0 /* this */
            aload 1 /* level */
            putfield io.dropwizard.logging.DefaultLoggingFactory.level:Ljava/lang/String;
         1: .line 129
            return
        end local 1 // java.lang.String level
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lio/dropwizard/logging/DefaultLoggingFactory;
            0    2     1  level  Ljava/lang/String;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
    MethodParameters:
       Name  Flags
      level  

  public java.util.Map<java.lang.String, com.fasterxml.jackson.databind.JsonNode> getLoggers();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
         0: .line 133
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggers:Ljava/util/Map;
            areturn
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/DefaultLoggingFactory;
    Signature: ()Ljava/util/Map<Ljava/lang/String;Lcom/fasterxml/jackson/databind/JsonNode;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()

  public void setLoggers(java.util.Map<java.lang.String, com.fasterxml.jackson.databind.JsonNode>);
    descriptor: (Ljava/util/Map;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
        start local 1 // java.util.Map loggers
         0: .line 138
            aload 0 /* this */
            new java.util.HashMap
            dup
            aload 1 /* loggers */
            invokespecial java.util.HashMap.<init>:(Ljava/util/Map;)V
            putfield io.dropwizard.logging.DefaultLoggingFactory.loggers:Ljava/util/Map;
         1: .line 139
            return
        end local 1 // java.util.Map loggers
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lio/dropwizard/logging/DefaultLoggingFactory;
            0    2     1  loggers  Ljava/util/Map<Ljava/lang/String;Lcom/fasterxml/jackson/databind/JsonNode;>;
    Signature: (Ljava/util/Map<Ljava/lang/String;Lcom/fasterxml/jackson/databind/JsonNode;>;)V
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
    MethodParameters:
         Name  Flags
      loggers  

  public java.util.List<io.dropwizard.logging.AppenderFactory<ch.qos.logback.classic.spi.ILoggingEvent>> getAppenders();
    descriptor: ()Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
         0: .line 143
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.appenders:Ljava/util/List;
            areturn
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/DefaultLoggingFactory;
    Signature: ()Ljava/util/List<Lio/dropwizard/logging/AppenderFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()

  public void setAppenders(java.util.List<io.dropwizard.logging.AppenderFactory<ch.qos.logback.classic.spi.ILoggingEvent>>);
    descriptor: (Ljava/util/List;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
        start local 1 // java.util.List appenders
         0: .line 148
            aload 0 /* this */
            new java.util.ArrayList
            dup
            aload 1 /* appenders */
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
            putfield io.dropwizard.logging.DefaultLoggingFactory.appenders:Ljava/util/List;
         1: .line 149
            return
        end local 1 // java.util.List appenders
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lio/dropwizard/logging/DefaultLoggingFactory;
            0    2     1  appenders  Ljava/util/List<Lio/dropwizard/logging/AppenderFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;>;
    Signature: (Ljava/util/List<Lio/dropwizard/logging/AppenderFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;>;)V
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
    MethodParameters:
           Name  Flags
      appenders  

  public void configure(com.codahale.metrics.MetricRegistry, java.lang.String);
    descriptor: (Lcom/codahale/metrics/MetricRegistry;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=10, args_size=3
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
        start local 1 // com.codahale.metrics.MetricRegistry metricRegistry
        start local 2 // java.lang.String name
         0: .line 153
            invokestatic io.dropwizard.logging.LoggingUtil.hijackJDKLogging:()V
         1: .line 155
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         2: .line 158
            aload 0 /* this */
            aload 2 /* name */
            invokevirtual io.dropwizard.logging.DefaultLoggingFactory.configureLoggers:(Ljava/lang/String;)Lch/qos/logback/classic/Logger;
            astore 3 /* root */
        start local 3 // ch.qos.logback.classic.Logger root
         3: .line 159
            goto 7
        end local 3 // ch.qos.logback.classic.Logger root
      StackMap locals:
      StackMap stack: java.lang.Throwable
         4: astore 4
         5: .line 160
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         6: .line 161
            aload 4
            athrow
        start local 3 // ch.qos.logback.classic.Logger root
         7: .line 160
      StackMap locals: ch.qos.logback.classic.Logger
      StackMap stack:
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         8: .line 163
            aload 0 /* this */
            aload 2 /* name */
            putfield io.dropwizard.logging.DefaultLoggingFactory.loggerName:Ljava/lang/String;
         9: .line 165
            new io.dropwizard.logging.filter.ThresholdLevelFilterFactory
            dup
            invokespecial io.dropwizard.logging.filter.ThresholdLevelFilterFactory.<init>:()V
            astore 4 /* levelFilterFactory */
        start local 4 // io.dropwizard.logging.filter.LevelFilterFactory levelFilterFactory
        10: .line 166
            new io.dropwizard.logging.async.AsyncLoggingEventAppenderFactory
            dup
            invokespecial io.dropwizard.logging.async.AsyncLoggingEventAppenderFactory.<init>:()V
            astore 5 /* asyncAppenderFactory */
        start local 5 // io.dropwizard.logging.async.AsyncAppenderFactory asyncAppenderFactory
        11: .line 167
            new io.dropwizard.logging.layout.DropwizardLayoutFactory
            dup
            invokespecial io.dropwizard.logging.layout.DropwizardLayoutFactory.<init>:()V
            astore 6 /* layoutFactory */
        start local 6 // io.dropwizard.logging.layout.LayoutFactory layoutFactory
        12: .line 169
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.appenders:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 8
            goto 15
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory com.codahale.metrics.MetricRegistry java.lang.String ch.qos.logback.classic.Logger io.dropwizard.logging.filter.LevelFilterFactory io.dropwizard.logging.async.AsyncAppenderFactory io.dropwizard.logging.layout.LayoutFactory top java.util.Iterator
      StackMap stack:
        13: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.dropwizard.logging.AppenderFactory
            astore 7 /* output */
        start local 7 // io.dropwizard.logging.AppenderFactory output
        14: .line 170
            aload 3 /* root */
            aload 7 /* output */
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            aload 2 /* name */
            aload 6 /* layoutFactory */
            aload 4 /* levelFilterFactory */
            aload 5 /* asyncAppenderFactory */
            invokeinterface io.dropwizard.logging.AppenderFactory.build:(Lch/qos/logback/classic/LoggerContext;Ljava/lang/String;Lio/dropwizard/logging/layout/LayoutFactory;Lio/dropwizard/logging/filter/LevelFilterFactory;Lio/dropwizard/logging/async/AsyncAppenderFactory;)Lch/qos/logback/core/Appender;
            invokevirtual ch.qos.logback.classic.Logger.addAppender:(Lch/qos/logback/core/Appender;)V
        end local 7 // io.dropwizard.logging.AppenderFactory output
        15: .line 169
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 13
        16: .line 173
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.configurationErrorsStream:Ljava/io/PrintStream;
            invokestatic ch.qos.logback.core.util.StatusPrinter.setPrintStream:(Ljava/io/PrintStream;)V
        17: .line 175
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            invokestatic ch.qos.logback.core.util.StatusPrinter.printIfErrorsOccured:(Lch/qos/logback/core/Context;)V
        18: .line 176
            goto 22
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory com.codahale.metrics.MetricRegistry java.lang.String ch.qos.logback.classic.Logger io.dropwizard.logging.filter.LevelFilterFactory io.dropwizard.logging.async.AsyncAppenderFactory io.dropwizard.logging.layout.LayoutFactory
      StackMap stack: java.lang.Throwable
        19: astore 7
        20: .line 177
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokestatic ch.qos.logback.core.util.StatusPrinter.setPrintStream:(Ljava/io/PrintStream;)V
        21: .line 178
            aload 7
            athrow
        22: .line 177
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokestatic ch.qos.logback.core.util.StatusPrinter.setPrintStream:(Ljava/io/PrintStream;)V
        23: .line 180
            invokestatic java.lang.management.ManagementFactory.getPlatformMBeanServer:()Ljavax/management/MBeanServer;
            astore 7 /* server */
        start local 7 // javax.management.MBeanServer server
        24: .line 181
            getstatic io.dropwizard.logging.DefaultLoggingFactory.MBEAN_REGISTRATION_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
        25: .line 183
            new javax.management.ObjectName
            dup
            ldc "io.dropwizard:type=Logging"
            invokespecial javax.management.ObjectName.<init>:(Ljava/lang/String;)V
            astore 8 /* objectName */
        start local 8 // javax.management.ObjectName objectName
        26: .line 184
            aload 7 /* server */
            aload 8 /* objectName */
            invokeinterface javax.management.MBeanServer.isRegistered:(Ljavax/management/ObjectName;)Z
            ifne 38
        27: .line 185
            aload 7 /* server */
            new ch.qos.logback.classic.jmx.JMXConfigurator
            dup
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
        28: .line 186
            aload 7 /* server */
        29: .line 187
            aload 8 /* objectName */
            invokespecial ch.qos.logback.classic.jmx.JMXConfigurator.<init>:(Lch/qos/logback/classic/LoggerContext;Ljavax/management/MBeanServer;Ljavax/management/ObjectName;)V
        30: .line 188
            aload 8 /* objectName */
        31: .line 185
            invokeinterface javax.management.MBeanServer.registerMBean:(Ljava/lang/Object;Ljavax/management/ObjectName;)Ljavax/management/ObjectInstance;
            pop
        end local 8 // javax.management.ObjectName objectName
        32: .line 190
            goto 38
        33: .line 191
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory com.codahale.metrics.MetricRegistry java.lang.String ch.qos.logback.classic.Logger io.dropwizard.logging.filter.LevelFilterFactory io.dropwizard.logging.async.AsyncAppenderFactory io.dropwizard.logging.layout.LayoutFactory javax.management.MBeanServer
      StackMap stack: javax.management.JMException
            astore 8 /* e */
        start local 8 // javax.management.JMException e
        34: .line 192
            new java.lang.RuntimeException
            dup
            aload 8 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 8 // javax.management.JMException e
        35: .line 193
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 9
        36: .line 194
            getstatic io.dropwizard.logging.DefaultLoggingFactory.MBEAN_REGISTRATION_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        37: .line 195
            aload 9
            athrow
        38: .line 194
      StackMap locals:
      StackMap stack:
            getstatic io.dropwizard.logging.DefaultLoggingFactory.MBEAN_REGISTRATION_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        39: .line 197
            aload 0 /* this */
            aload 3 /* root */
            aload 1 /* metricRegistry */
            invokevirtual io.dropwizard.logging.DefaultLoggingFactory.configureInstrumentation:(Lch/qos/logback/classic/Logger;Lcom/codahale/metrics/MetricRegistry;)V
        40: .line 198
            return
        end local 7 // javax.management.MBeanServer server
        end local 6 // io.dropwizard.logging.layout.LayoutFactory layoutFactory
        end local 5 // io.dropwizard.logging.async.AsyncAppenderFactory asyncAppenderFactory
        end local 4 // io.dropwizard.logging.filter.LevelFilterFactory levelFilterFactory
        end local 3 // ch.qos.logback.classic.Logger root
        end local 2 // java.lang.String name
        end local 1 // com.codahale.metrics.MetricRegistry metricRegistry
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   41     0                  this  Lio/dropwizard/logging/DefaultLoggingFactory;
            0   41     1        metricRegistry  Lcom/codahale/metrics/MetricRegistry;
            0   41     2                  name  Ljava/lang/String;
            3    4     3                  root  Lch/qos/logback/classic/Logger;
            7   41     3                  root  Lch/qos/logback/classic/Logger;
           10   41     4    levelFilterFactory  Lio/dropwizard/logging/filter/LevelFilterFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;
           11   41     5  asyncAppenderFactory  Lio/dropwizard/logging/async/AsyncAppenderFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;
           12   41     6         layoutFactory  Lio/dropwizard/logging/layout/LayoutFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;
           14   15     7                output  Lio/dropwizard/logging/AppenderFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;
           24   41     7                server  Ljavax/management/MBeanServer;
           26   32     8            objectName  Ljavax/management/ObjectName;
           34   35     8                     e  Ljavax/management/JMException;
      Exception table:
        from    to  target  type
           2     4       4  any
          17    19      19  any
          25    32      33  Class javax.management.MalformedObjectNameException
          25    32      33  Class javax.management.InstanceAlreadyExistsException
          25    32      33  Class javax.management.NotCompliantMBeanException
          25    32      33  Class javax.management.MBeanRegistrationException
          25    35      35  any
    MethodParameters:
                Name  Flags
      metricRegistry  
      name            

  public void stop();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=6, args_size=1
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
         0: .line 203
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         1: .line 209
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            ldc "ROOT"
            invokevirtual ch.qos.logback.classic.LoggerContext.getLogger:(Ljava/lang/String;)Lch/qos/logback/classic/Logger;
            astore 1 /* logger */
        start local 1 // ch.qos.logback.classic.Logger logger
         2: .line 210
            aload 1 /* logger */
            invokevirtual ch.qos.logback.classic.Logger.iteratorForAppenders:()Ljava/util/Iterator;
            invokestatic io.dropwizard.util.Lists.of:(Ljava/util/Iterator;)Ljava/util/List;
            astore 2 /* appenders */
        start local 2 // java.util.List appenders
         3: .line 211
            aload 2 /* appenders */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 10
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory ch.qos.logback.classic.Logger java.util.List top java.util.Iterator
      StackMap stack:
         4: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast ch.qos.logback.core.Appender
            astore 3 /* appender */
        start local 3 // ch.qos.logback.core.Appender appender
         5: .line 212
            aload 3 /* appender */
            instanceof ch.qos.logback.core.AsyncAppenderBase
            ifeq 8
         6: .line 213
            aload 0 /* this */
            aload 3 /* appender */
            checkcast ch.qos.logback.core.AsyncAppenderBase
            invokevirtual io.dropwizard.logging.DefaultLoggingFactory.flushAppender:(Lch/qos/logback/core/AsyncAppenderBase;)V
         7: .line 214
            goto 10
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory ch.qos.logback.classic.Logger java.util.List ch.qos.logback.core.Appender java.util.Iterator
      StackMap stack:
         8: aload 3 /* appender */
            instanceof io.dropwizard.logback.AsyncAppenderBaseProxy
            ifeq 10
         9: .line 215
            aload 0 /* this */
            aload 3 /* appender */
            checkcast io.dropwizard.logback.AsyncAppenderBaseProxy
            invokeinterface io.dropwizard.logback.AsyncAppenderBaseProxy.getAppender:()Lch/qos/logback/core/AsyncAppenderBase;
            invokevirtual io.dropwizard.logging.DefaultLoggingFactory.flushAppender:(Lch/qos/logback/core/AsyncAppenderBase;)V
        end local 3 // ch.qos.logback.core.Appender appender
        10: .line 211
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory ch.qos.logback.classic.Logger java.util.List top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        end local 2 // java.util.List appenders
        end local 1 // ch.qos.logback.classic.Logger logger
        11: .line 218
            goto 18
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory
      StackMap stack: java.lang.InterruptedException
        12: pop
        13: .line 222
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
        14: .line 224
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
            goto 19
        15: .line 223
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 5
        16: .line 224
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        17: .line 225
            aload 5
            athrow
        18: .line 224
      StackMap locals:
      StackMap stack:
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        19: .line 226
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   20     0       this  Lio/dropwizard/logging/DefaultLoggingFactory;
            2   11     1     logger  Lch/qos/logback/classic/Logger;
            3   11     2  appenders  Ljava/util/List<Lch/qos/logback/core/Appender<Lch/qos/logback/classic/spi/ILoggingEvent;>;>;
            5   10     3   appender  Lch/qos/logback/core/Appender<Lch/qos/logback/classic/spi/ILoggingEvent;>;
      Exception table:
        from    to  target  type
           1    11      12  Class java.lang.InterruptedException
           1    14      15  any

  public void reset();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=1
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
         0: .line 230
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         1: .line 234
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            invokevirtual ch.qos.logback.classic.LoggerContext.stop:()V
         2: .line 235
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            ldc "ROOT"
            invokevirtual ch.qos.logback.classic.LoggerContext.getLogger:(Ljava/lang/String;)Lch/qos/logback/classic/Logger;
            astore 1 /* logger */
        start local 1 // ch.qos.logback.classic.Logger logger
         3: .line 236
            aload 1 /* logger */
            invokevirtual ch.qos.logback.classic.Logger.detachAndStopAllAppenders:()V
         4: .line 237
            new io.dropwizard.logging.DropwizardLayout
            dup
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            invokestatic java.util.TimeZone.getDefault:()Ljava/util/TimeZone;
            invokespecial io.dropwizard.logging.DropwizardLayout.<init>:(Lch/qos/logback/classic/LoggerContext;Ljava/util/TimeZone;)V
            astore 2 /* formatter */
        start local 2 // io.dropwizard.logging.DropwizardLayout formatter
         5: .line 238
            aload 2 /* formatter */
            invokevirtual io.dropwizard.logging.DropwizardLayout.start:()V
         6: .line 239
            new ch.qos.logback.core.encoder.LayoutWrappingEncoder
            dup
            invokespecial ch.qos.logback.core.encoder.LayoutWrappingEncoder.<init>:()V
            astore 3 /* layoutEncoder */
        start local 3 // ch.qos.logback.core.encoder.LayoutWrappingEncoder layoutEncoder
         7: .line 240
            aload 3 /* layoutEncoder */
            aload 2 /* formatter */
            invokevirtual ch.qos.logback.core.encoder.LayoutWrappingEncoder.setLayout:(Lch/qos/logback/core/Layout;)V
         8: .line 241
            new ch.qos.logback.core.ConsoleAppender
            dup
            invokespecial ch.qos.logback.core.ConsoleAppender.<init>:()V
            astore 4 /* consoleAppender */
        start local 4 // ch.qos.logback.core.ConsoleAppender consoleAppender
         9: .line 242
            aload 4 /* consoleAppender */
            new io.dropwizard.logging.filter.ThresholdLevelFilterFactory
            dup
            invokespecial io.dropwizard.logging.filter.ThresholdLevelFilterFactory.<init>:()V
            getstatic ch.qos.logback.classic.Level.INFO:Lch/qos/logback/classic/Level;
            invokevirtual io.dropwizard.logging.filter.ThresholdLevelFilterFactory.build:(Lch/qos/logback/classic/Level;)Lch/qos/logback/core/filter/Filter;
            invokevirtual ch.qos.logback.core.ConsoleAppender.addFilter:(Lch/qos/logback/core/filter/Filter;)V
        10: .line 243
            aload 4 /* consoleAppender */
            aload 3 /* layoutEncoder */
            invokevirtual ch.qos.logback.core.ConsoleAppender.setEncoder:(Lch/qos/logback/core/encoder/Encoder;)V
        11: .line 244
            aload 4 /* consoleAppender */
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            invokevirtual ch.qos.logback.core.ConsoleAppender.setContext:(Lch/qos/logback/core/Context;)V
        12: .line 245
            aload 4 /* consoleAppender */
            invokevirtual ch.qos.logback.core.ConsoleAppender.start:()V
        13: .line 246
            aload 1 /* logger */
            aload 4 /* consoleAppender */
            invokevirtual ch.qos.logback.classic.Logger.addAppender:(Lch/qos/logback/core/Appender;)V
        14: .line 247
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            invokevirtual ch.qos.logback.classic.LoggerContext.start:()V
        end local 4 // ch.qos.logback.core.ConsoleAppender consoleAppender
        end local 3 // ch.qos.logback.core.encoder.LayoutWrappingEncoder layoutEncoder
        end local 2 // io.dropwizard.logging.DropwizardLayout formatter
        end local 1 // ch.qos.logback.classic.Logger logger
        15: .line 248
            goto 19
      StackMap locals:
      StackMap stack: java.lang.Throwable
        16: astore 5
        17: .line 249
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        18: .line 250
            aload 5
            athrow
        19: .line 249
      StackMap locals:
      StackMap stack:
            getstatic io.dropwizard.logging.DefaultLoggingFactory.CHANGE_LOGGER_CONTEXT_LOCK:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        20: .line 251
            return
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   21     0             this  Lio/dropwizard/logging/DefaultLoggingFactory;
            3   15     1           logger  Lch/qos/logback/classic/Logger;
            5   15     2        formatter  Lio/dropwizard/logging/DropwizardLayout;
            7   15     3    layoutEncoder  Lch/qos/logback/core/encoder/LayoutWrappingEncoder<Lch/qos/logback/classic/spi/ILoggingEvent;>;
            9   15     4  consoleAppender  Lch/qos/logback/core/ConsoleAppender<Lch/qos/logback/classic/spi/ILoggingEvent;>;
      Exception table:
        from    to  target  type
           1    16      16  any

  private void flushAppender(ch.qos.logback.core.AsyncAppenderBase<?>);
    descriptor: (Lch/qos/logback/core/AsyncAppenderBase;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
        start local 1 // ch.qos.logback.core.AsyncAppenderBase appender
         0: .line 254
            iconst_0
            istore 2 /* timeWaiting */
        start local 2 // int timeWaiting
         1: .line 255
            goto 4
         2: .line 256
      StackMap locals: int
      StackMap stack:
            ldc 100
            invokestatic java.lang.Thread.sleep:(J)V
         3: .line 257
            iinc 2 /* timeWaiting */ 100
         4: .line 255
      StackMap locals:
      StackMap stack:
            iload 2 /* timeWaiting */
            aload 1 /* appender */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.getMaxFlushTime:()I
            if_icmpge 5
            aload 1 /* appender */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.getNumberOfElementsInQueue:()I
            ifgt 2
         5: .line 260
      StackMap locals:
      StackMap stack:
            aload 1 /* appender */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.getNumberOfElementsInQueue:()I
            ifle 7
         6: .line 264
            aload 1 /* appender */
            new java.lang.StringBuilder
            dup
            aload 1 /* appender */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.getNumberOfElementsInQueue:()I
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " events may be discarded"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.addWarn:(Ljava/lang/String;)V
         7: .line 266
      StackMap locals:
      StackMap stack:
            return
        end local 2 // int timeWaiting
        end local 1 // ch.qos.logback.core.AsyncAppenderBase appender
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    8     0         this  Lio/dropwizard/logging/DefaultLoggingFactory;
            0    8     1     appender  Lch/qos/logback/core/AsyncAppenderBase<*>;
            1    8     2  timeWaiting  I
    Exceptions:
      throws java.lang.InterruptedException
    Signature: (Lch/qos/logback/core/AsyncAppenderBase<*>;)V
    MethodParameters:
          Name  Flags
      appender  

  private void configureInstrumentation(ch.qos.logback.classic.Logger, com.codahale.metrics.MetricRegistry);
    descriptor: (Lch/qos/logback/classic/Logger;Lcom/codahale/metrics/MetricRegistry;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
        start local 1 // ch.qos.logback.classic.Logger root
        start local 2 // com.codahale.metrics.MetricRegistry metricRegistry
         0: .line 269
            new com.codahale.metrics.logback.InstrumentedAppender
            dup
            aload 2 /* metricRegistry */
            invokespecial com.codahale.metrics.logback.InstrumentedAppender.<init>:(Lcom/codahale/metrics/MetricRegistry;)V
            astore 3 /* appender */
        start local 3 // com.codahale.metrics.logback.InstrumentedAppender appender
         1: .line 270
            aload 3 /* appender */
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            invokevirtual com.codahale.metrics.logback.InstrumentedAppender.setContext:(Lch/qos/logback/core/Context;)V
         2: .line 271
            aload 3 /* appender */
            invokevirtual com.codahale.metrics.logback.InstrumentedAppender.start:()V
         3: .line 272
            aload 1 /* root */
            aload 3 /* appender */
            invokevirtual ch.qos.logback.classic.Logger.addAppender:(Lch/qos/logback/core/Appender;)V
         4: .line 273
            return
        end local 3 // com.codahale.metrics.logback.InstrumentedAppender appender
        end local 2 // com.codahale.metrics.MetricRegistry metricRegistry
        end local 1 // ch.qos.logback.classic.Logger root
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    5     0            this  Lio/dropwizard/logging/DefaultLoggingFactory;
            0    5     1            root  Lch/qos/logback/classic/Logger;
            0    5     2  metricRegistry  Lcom/codahale/metrics/MetricRegistry;
            1    5     3        appender  Lcom/codahale/metrics/logback/InstrumentedAppender;
    MethodParameters:
                Name  Flags
      root            
      metricRegistry  

  private ch.qos.logback.classic.Logger configureLoggers(java.lang.String);
    descriptor: (Ljava/lang/String;)Lch/qos/logback/classic/Logger;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=14, args_size=2
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
        start local 1 // java.lang.String name
         0: .line 276
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            ldc "ROOT"
            invokevirtual ch.qos.logback.classic.LoggerContext.getLogger:(Ljava/lang/String;)Lch/qos/logback/classic/Logger;
            astore 2 /* root */
        start local 2 // ch.qos.logback.classic.Logger root
         1: .line 277
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            invokevirtual ch.qos.logback.classic.LoggerContext.reset:()V
         2: .line 279
            new ch.qos.logback.classic.jul.LevelChangePropagator
            dup
            invokespecial ch.qos.logback.classic.jul.LevelChangePropagator.<init>:()V
            astore 3 /* propagator */
        start local 3 // ch.qos.logback.classic.jul.LevelChangePropagator propagator
         3: .line 280
            aload 3 /* propagator */
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            invokevirtual ch.qos.logback.classic.jul.LevelChangePropagator.setContext:(Lch/qos/logback/core/Context;)V
         4: .line 281
            aload 3 /* propagator */
            iconst_1
            invokevirtual ch.qos.logback.classic.jul.LevelChangePropagator.setResetJUL:(Z)V
         5: .line 283
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            aload 3 /* propagator */
            invokevirtual ch.qos.logback.classic.LoggerContext.addListener:(Lch/qos/logback/classic/spi/LoggerContextListener;)V
         6: .line 285
            aload 2 /* root */
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.level:Ljava/lang/String;
            invokestatic io.dropwizard.logging.DefaultLoggingFactory.toLevel:(Ljava/lang/String;)Lch/qos/logback/classic/Level;
            invokevirtual ch.qos.logback.classic.Logger.setLevel:(Lch/qos/logback/classic/Level;)V
         7: .line 287
            new io.dropwizard.logging.filter.ThresholdLevelFilterFactory
            dup
            invokespecial io.dropwizard.logging.filter.ThresholdLevelFilterFactory.<init>:()V
            astore 4 /* levelFilterFactory */
        start local 4 // io.dropwizard.logging.filter.LevelFilterFactory levelFilterFactory
         8: .line 288
            new io.dropwizard.logging.async.AsyncLoggingEventAppenderFactory
            dup
            invokespecial io.dropwizard.logging.async.AsyncLoggingEventAppenderFactory.<init>:()V
            astore 5 /* asyncAppenderFactory */
        start local 5 // io.dropwizard.logging.async.AsyncAppenderFactory asyncAppenderFactory
         9: .line 289
            new io.dropwizard.logging.layout.DropwizardLayoutFactory
            dup
            invokespecial io.dropwizard.logging.layout.DropwizardLayoutFactory.<init>:()V
            astore 6 /* layoutFactory */
        start local 6 // io.dropwizard.logging.layout.LayoutFactory layoutFactory
        10: .line 291
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggers:Ljava/util/Map;
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 8
            goto 30
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory java.lang.String ch.qos.logback.classic.Logger ch.qos.logback.classic.jul.LevelChangePropagator io.dropwizard.logging.filter.LevelFilterFactory io.dropwizard.logging.async.AsyncAppenderFactory io.dropwizard.logging.layout.LayoutFactory top java.util.Iterator
      StackMap stack:
        11: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 7 /* entry */
        start local 7 // java.util.Map$Entry entry
        12: .line 292
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            aload 7 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            invokevirtual ch.qos.logback.classic.LoggerContext.getLogger:(Ljava/lang/String;)Lch/qos/logback/classic/Logger;
            astore 9 /* logger */
        start local 9 // ch.qos.logback.classic.Logger logger
        13: .line 293
            aload 7 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast com.fasterxml.jackson.databind.JsonNode
            astore 10 /* jsonNode */
        start local 10 // com.fasterxml.jackson.databind.JsonNode jsonNode
        14: .line 294
            aload 10 /* jsonNode */
            invokevirtual com.fasterxml.jackson.databind.JsonNode.isTextual:()Z
            ifne 15
            aload 10 /* jsonNode */
            invokevirtual com.fasterxml.jackson.databind.JsonNode.isBoolean:()Z
            ifeq 17
        15: .line 296
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory java.lang.String ch.qos.logback.classic.Logger ch.qos.logback.classic.jul.LevelChangePropagator io.dropwizard.logging.filter.LevelFilterFactory io.dropwizard.logging.async.AsyncAppenderFactory io.dropwizard.logging.layout.LayoutFactory java.util.Map$Entry java.util.Iterator ch.qos.logback.classic.Logger com.fasterxml.jackson.databind.JsonNode
      StackMap stack:
            aload 9 /* logger */
            aload 10 /* jsonNode */
            invokevirtual com.fasterxml.jackson.databind.JsonNode.asText:()Ljava/lang/String;
            invokestatic io.dropwizard.logging.DefaultLoggingFactory.toLevel:(Ljava/lang/String;)Lch/qos/logback/classic/Level;
            invokevirtual ch.qos.logback.classic.Logger.setLevel:(Lch/qos/logback/classic/Level;)V
        16: .line 297
            goto 30
      StackMap locals:
      StackMap stack:
        17: aload 10 /* jsonNode */
            invokevirtual com.fasterxml.jackson.databind.JsonNode.isObject:()Z
            ifeq 29
        18: .line 301
            invokestatic io.dropwizard.jackson.Jackson.newObjectMapper:()Lcom/fasterxml/jackson/databind/ObjectMapper;
            aload 10 /* jsonNode */
            ldc Lio/dropwizard/logging/LoggerConfiguration;
            invokevirtual com.fasterxml.jackson.databind.ObjectMapper.treeToValue:(Lcom/fasterxml/jackson/core/TreeNode;Ljava/lang/Class;)Ljava/lang/Object;
            checkcast io.dropwizard.logging.LoggerConfiguration
            astore 11 /* configuration */
        start local 11 // io.dropwizard.logging.LoggerConfiguration configuration
        19: .line 302
            goto 22
        end local 11 // io.dropwizard.logging.LoggerConfiguration configuration
      StackMap locals:
      StackMap stack: com.fasterxml.jackson.core.JsonProcessingException
        20: astore 12 /* e */
        start local 12 // com.fasterxml.jackson.core.JsonProcessingException e
        21: .line 303
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Wrong format of logger '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 12 /* e */
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 12 // com.fasterxml.jackson.core.JsonProcessingException e
        start local 11 // io.dropwizard.logging.LoggerConfiguration configuration
        22: .line 305
      StackMap locals: io.dropwizard.logging.LoggerConfiguration
      StackMap stack:
            aload 9 /* logger */
            aload 11 /* configuration */
            invokevirtual io.dropwizard.logging.LoggerConfiguration.getLevel:()Ljava/lang/String;
            invokestatic io.dropwizard.logging.DefaultLoggingFactory.toLevel:(Ljava/lang/String;)Lch/qos/logback/classic/Level;
            invokevirtual ch.qos.logback.classic.Logger.setLevel:(Lch/qos/logback/classic/Level;)V
        23: .line 306
            aload 9 /* logger */
            aload 11 /* configuration */
            invokevirtual io.dropwizard.logging.LoggerConfiguration.isAdditive:()Z
            invokevirtual ch.qos.logback.classic.Logger.setAdditive:(Z)V
        24: .line 308
            aload 11 /* configuration */
            invokevirtual io.dropwizard.logging.LoggerConfiguration.getAppenders:()Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 13
            goto 27
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory java.lang.String ch.qos.logback.classic.Logger ch.qos.logback.classic.jul.LevelChangePropagator io.dropwizard.logging.filter.LevelFilterFactory io.dropwizard.logging.async.AsyncAppenderFactory io.dropwizard.logging.layout.LayoutFactory java.util.Map$Entry java.util.Iterator ch.qos.logback.classic.Logger com.fasterxml.jackson.databind.JsonNode io.dropwizard.logging.LoggerConfiguration top java.util.Iterator
      StackMap stack:
        25: aload 13
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.dropwizard.logging.AppenderFactory
            astore 12 /* appender */
        start local 12 // io.dropwizard.logging.AppenderFactory appender
        26: .line 309
            aload 9 /* logger */
            aload 12 /* appender */
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggerContext:Lch/qos/logback/classic/LoggerContext;
            aload 1 /* name */
            aload 6 /* layoutFactory */
            aload 4 /* levelFilterFactory */
            aload 5 /* asyncAppenderFactory */
            invokeinterface io.dropwizard.logging.AppenderFactory.build:(Lch/qos/logback/classic/LoggerContext;Ljava/lang/String;Lio/dropwizard/logging/layout/LayoutFactory;Lio/dropwizard/logging/filter/LevelFilterFactory;Lio/dropwizard/logging/async/AsyncAppenderFactory;)Lch/qos/logback/core/Appender;
            invokevirtual ch.qos.logback.classic.Logger.addAppender:(Lch/qos/logback/core/Appender;)V
        end local 12 // io.dropwizard.logging.AppenderFactory appender
        27: .line 308
      StackMap locals:
      StackMap stack:
            aload 13
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 25
        end local 11 // io.dropwizard.logging.LoggerConfiguration configuration
        28: .line 311
            goto 30
        29: .line 312
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory java.lang.String ch.qos.logback.classic.Logger ch.qos.logback.classic.jul.LevelChangePropagator io.dropwizard.logging.filter.LevelFilterFactory io.dropwizard.logging.async.AsyncAppenderFactory io.dropwizard.logging.layout.LayoutFactory java.util.Map$Entry java.util.Iterator ch.qos.logback.classic.Logger com.fasterxml.jackson.databind.JsonNode
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unsupported format of logger '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 10 // com.fasterxml.jackson.databind.JsonNode jsonNode
        end local 9 // ch.qos.logback.classic.Logger logger
        end local 7 // java.util.Map$Entry entry
        30: .line 291
      StackMap locals: io.dropwizard.logging.DefaultLoggingFactory java.lang.String ch.qos.logback.classic.Logger ch.qos.logback.classic.jul.LevelChangePropagator io.dropwizard.logging.filter.LevelFilterFactory io.dropwizard.logging.async.AsyncAppenderFactory io.dropwizard.logging.layout.LayoutFactory top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 11
        31: .line 316
            aload 2 /* root */
            areturn
        end local 6 // io.dropwizard.logging.layout.LayoutFactory layoutFactory
        end local 5 // io.dropwizard.logging.async.AsyncAppenderFactory asyncAppenderFactory
        end local 4 // io.dropwizard.logging.filter.LevelFilterFactory levelFilterFactory
        end local 3 // ch.qos.logback.classic.jul.LevelChangePropagator propagator
        end local 2 // ch.qos.logback.classic.Logger root
        end local 1 // java.lang.String name
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   32     0                  this  Lio/dropwizard/logging/DefaultLoggingFactory;
            0   32     1                  name  Ljava/lang/String;
            1   32     2                  root  Lch/qos/logback/classic/Logger;
            3   32     3            propagator  Lch/qos/logback/classic/jul/LevelChangePropagator;
            8   32     4    levelFilterFactory  Lio/dropwizard/logging/filter/LevelFilterFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;
            9   32     5  asyncAppenderFactory  Lio/dropwizard/logging/async/AsyncAppenderFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;
           10   32     6         layoutFactory  Lio/dropwizard/logging/layout/LayoutFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;
           12   30     7                 entry  Ljava/util/Map$Entry<Ljava/lang/String;Lcom/fasterxml/jackson/databind/JsonNode;>;
           13   30     9                logger  Lch/qos/logback/classic/Logger;
           14   30    10              jsonNode  Lcom/fasterxml/jackson/databind/JsonNode;
           19   20    11         configuration  Lio/dropwizard/logging/LoggerConfiguration;
           22   28    11         configuration  Lio/dropwizard/logging/LoggerConfiguration;
           21   22    12                     e  Lcom/fasterxml/jackson/core/JsonProcessingException;
           26   27    12              appender  Lio/dropwizard/logging/AppenderFactory<Lch/qos/logback/classic/spi/ILoggingEvent;>;
      Exception table:
        from    to  target  type
          18    19      20  Class com.fasterxml.jackson.core.JsonProcessingException
    MethodParameters:
      Name  Flags
      name  

  static ch.qos.logback.classic.Level toLevel(java.lang.String);
    descriptor: (Ljava/lang/String;)Lch/qos/logback/classic/Level;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String text
         0: .line 320
            ldc "false"
            aload 0 /* text */
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 2
         1: .line 322
            getstatic ch.qos.logback.classic.Level.OFF:Lch/qos/logback/classic/Level;
            areturn
         2: .line 323
      StackMap locals:
      StackMap stack:
            ldc "true"
            aload 0 /* text */
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 4
         3: .line 325
            getstatic ch.qos.logback.classic.Level.ALL:Lch/qos/logback/classic/Level;
            areturn
         4: .line 327
      StackMap locals:
      StackMap stack:
            aload 0 /* text */
            getstatic ch.qos.logback.classic.Level.INFO:Lch/qos/logback/classic/Level;
            invokestatic ch.qos.logback.classic.Level.toLevel:(Ljava/lang/String;Lch/qos/logback/classic/Level;)Lch/qos/logback/classic/Level;
            areturn
        end local 0 // java.lang.String text
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  text  Ljava/lang/String;
    RuntimeVisibleTypeAnnotations: 
      METHOD_FORMAL_PARAMETER
        javax.annotation.Nullable()
    RuntimeVisibleParameterAnnotations: 
      0:
        javax.annotation.Nullable()
    MethodParameters:
      Name  Flags
      text  

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.DefaultLoggingFactory this
         0: .line 332
            new java.lang.StringBuilder
            dup
            ldc "DefaultLoggingFactory{level="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         1: .line 333
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.level:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         2: .line 334
            ldc ", loggers="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.loggers:Ljava/util/Map;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         3: .line 335
            ldc ", appenders="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield io.dropwizard.logging.DefaultLoggingFactory.appenders:Ljava/util/List;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         4: .line 336
            bipush 125
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
         5: .line 332
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 0 // io.dropwizard.logging.DefaultLoggingFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lio/dropwizard/logging/DefaultLoggingFactory;
}
SourceFile: "DefaultLoggingFactory.java"
InnerClasses:
  public abstract Entry = java.util.Map$Entry of java.util.Map
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonTypeName(value = "default")