public final class org.slf4j.LoggerFactory
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.slf4j.LoggerFactory
  super_class: java.lang.Object
{
  static final java.lang.String CODES_PREFIX;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "http://www.slf4j.org/codes.html"

  static final java.lang.String NO_STATICLOGGERBINDER_URL;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "http://www.slf4j.org/codes.html#StaticLoggerBinder"

  static final java.lang.String MULTIPLE_BINDINGS_URL;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "http://www.slf4j.org/codes.html#multiple_bindings"

  static final java.lang.String NULL_LF_URL;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "http://www.slf4j.org/codes.html#null_LF"

  static final java.lang.String VERSION_MISMATCH;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "http://www.slf4j.org/codes.html#version_mismatch"

  static final java.lang.String SUBSTITUTE_LOGGER_URL;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "http://www.slf4j.org/codes.html#substituteLogger"

  static final java.lang.String LOGGER_NAME_MISMATCH_URL;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "http://www.slf4j.org/codes.html#loggerNameMismatch"

  static final java.lang.String REPLAY_URL;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "http://www.slf4j.org/codes.html#replay"

  static final java.lang.String UNSUCCESSFUL_INIT_URL;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "http://www.slf4j.org/codes.html#unsuccessfulInit"

  static final java.lang.String UNSUCCESSFUL_INIT_MSG;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "org.slf4j.LoggerFactory in failed state. Original exception was thrown EARLIER. See also http://www.slf4j.org/codes.html#unsuccessfulInit"

  static final int UNINITIALIZED;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  static final int ONGOING_INITIALIZATION;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 1

  static final int FAILED_INITIALIZATION;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 2

  static final int SUCCESSFUL_INITIALIZATION;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 3

  static final int NOP_FALLBACK_INITIALIZATION;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 4

  static volatile int INITIALIZATION_STATE;
    descriptor: I
    flags: (0x0048) ACC_STATIC, ACC_VOLATILE

  static final org.slf4j.helpers.SubstituteLoggerFactory SUBST_FACTORY;
    descriptor: Lorg/slf4j/helpers/SubstituteLoggerFactory;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final org.slf4j.helpers.NOPLoggerFactory NOP_FALLBACK_FACTORY;
    descriptor: Lorg/slf4j/helpers/NOPLoggerFactory;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final java.lang.String DETECT_LOGGER_NAME_MISMATCH_PROPERTY;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "slf4j.detectLoggerNameMismatch"

  static final java.lang.String JAVA_VENDOR_PROPERTY;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "java.vendor.url"

  static boolean DETECT_LOGGER_NAME_MISMATCH;
    descriptor: Z
    flags: (0x0008) ACC_STATIC

  private static final java.lang.String[] API_COMPATIBILITY_LIST;
    descriptor: [Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static java.lang.String STATIC_LOGGER_BINDER_PATH;
    descriptor: Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 85
            iconst_0
            putstatic org.slf4j.LoggerFactory.INITIALIZATION_STATE:I
         1: .line 86
            new org.slf4j.helpers.SubstituteLoggerFactory
            dup
            invokespecial org.slf4j.helpers.SubstituteLoggerFactory.<init>:()V
            putstatic org.slf4j.LoggerFactory.SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
         2: .line 87
            new org.slf4j.helpers.NOPLoggerFactory
            dup
            invokespecial org.slf4j.helpers.NOPLoggerFactory.<init>:()V
            putstatic org.slf4j.LoggerFactory.NOP_FALLBACK_FACTORY:Lorg/slf4j/helpers/NOPLoggerFactory;
         3: .line 93
            ldc "slf4j.detectLoggerNameMismatch"
            invokestatic org.slf4j.helpers.Util.safeGetBooleanSystemProperty:(Ljava/lang/String;)Z
            putstatic org.slf4j.LoggerFactory.DETECT_LOGGER_NAME_MISMATCH:Z
         4: .line 102
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
            ldc "1.6"
            aastore
            dup
            iconst_1
            ldc "1.7"
            aastore
            putstatic org.slf4j.LoggerFactory.API_COMPATIBILITY_LIST:[Ljava/lang/String;
         5: .line 290
            ldc "org/slf4j/impl/StaticLoggerBinder.class"
            putstatic org.slf4j.LoggerFactory.STATIC_LOGGER_BINDER_PATH:Ljava/lang/String;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.slf4j.LoggerFactory this
         0: .line 105
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 106
            return
        end local 0 // org.slf4j.LoggerFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/slf4j/LoggerFactory;

  static void reset();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 120
            iconst_0
            putstatic org.slf4j.LoggerFactory.INITIALIZATION_STATE:I
         1: .line 121
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static final void performInitialization();
    descriptor: ()V
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Code:
      stack=2, locals=0, args_size=0
         0: .line 124
            invokestatic org.slf4j.LoggerFactory.bind:()V
         1: .line 125
            getstatic org.slf4j.LoggerFactory.INITIALIZATION_STATE:I
            iconst_3
            if_icmpne 3
         2: .line 126
            invokestatic org.slf4j.LoggerFactory.versionSanityCheck:()V
         3: .line 128
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static boolean messageContainsOrgSlf4jImplStaticLoggerBinder(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String msg
         0: .line 131
            aload 0 /* msg */
            ifnonnull 2
         1: .line 132
            iconst_0
            ireturn
         2: .line 133
      StackMap locals:
      StackMap stack:
            aload 0 /* msg */
            ldc "org/slf4j/impl/StaticLoggerBinder"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 4
         3: .line 134
            iconst_1
            ireturn
         4: .line 135
      StackMap locals:
      StackMap stack:
            aload 0 /* msg */
            ldc "org.slf4j.impl.StaticLoggerBinder"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 6
         5: .line 136
            iconst_1
            ireturn
         6: .line 137
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 0 // java.lang.String msg
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0   msg  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      msg   

  private static final void bind();
    descriptor: ()V
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Code:
      stack=4, locals=2, args_size=0
         0: .line 142
            aconst_null
            astore 0 /* staticLoggerBinderPathSet */
        start local 0 // java.util.Set staticLoggerBinderPathSet
         1: .line 145
            invokestatic org.slf4j.LoggerFactory.isAndroid:()Z
            ifne 4
         2: .line 146
            invokestatic org.slf4j.LoggerFactory.findPossibleStaticLoggerBinderPathSet:()Ljava/util/Set;
            astore 0 /* staticLoggerBinderPathSet */
         3: .line 147
            aload 0 /* staticLoggerBinderPathSet */
            invokestatic org.slf4j.LoggerFactory.reportMultipleBindingAmbiguity:(Ljava/util/Set;)V
         4: .line 150
      StackMap locals: java.util.Set
      StackMap stack:
            invokestatic org.slf4j.impl.StaticLoggerBinder.getSingleton:()Lorg/slf4j/impl/StaticLoggerBinder;
            pop
         5: .line 151
            iconst_3
            putstatic org.slf4j.LoggerFactory.INITIALIZATION_STATE:I
         6: .line 152
            aload 0 /* staticLoggerBinderPathSet */
            invokestatic org.slf4j.LoggerFactory.reportActualBinding:(Ljava/util/Set;)V
         7: .line 153
            invokestatic org.slf4j.LoggerFactory.fixSubstituteLoggers:()V
         8: .line 154
            invokestatic org.slf4j.LoggerFactory.replayEvents:()V
         9: .line 156
            getstatic org.slf4j.LoggerFactory.SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
            invokevirtual org.slf4j.helpers.SubstituteLoggerFactory.clear:()V
        end local 0 // java.util.Set staticLoggerBinderPathSet
        10: .line 157
            goto 32
      StackMap locals:
      StackMap stack: java.lang.NoClassDefFoundError
        11: astore 0 /* ncde */
        start local 0 // java.lang.NoClassDefFoundError ncde
        12: .line 158
            aload 0 /* ncde */
            invokevirtual java.lang.NoClassDefFoundError.getMessage:()Ljava/lang/String;
            astore 1 /* msg */
        start local 1 // java.lang.String msg
        13: .line 159
            aload 1 /* msg */
            invokestatic org.slf4j.LoggerFactory.messageContainsOrgSlf4jImplStaticLoggerBinder:(Ljava/lang/String;)Z
            ifeq 19
        14: .line 160
            iconst_4
            putstatic org.slf4j.LoggerFactory.INITIALIZATION_STATE:I
        15: .line 161
            ldc "Failed to load class \"org.slf4j.impl.StaticLoggerBinder\"."
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
        16: .line 162
            ldc "Defaulting to no-operation (NOP) logger implementation"
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
        17: .line 163
            ldc "See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details."
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
        18: .line 164
            goto 32
        19: .line 165
      StackMap locals: java.lang.NoClassDefFoundError java.lang.String
      StackMap stack:
            aload 0 /* ncde */
            invokestatic org.slf4j.LoggerFactory.failedBinding:(Ljava/lang/Throwable;)V
        20: .line 166
            aload 0 /* ncde */
            athrow
        end local 1 // java.lang.String msg
        end local 0 // java.lang.NoClassDefFoundError ncde
        21: .line 168
      StackMap locals:
      StackMap stack: java.lang.NoSuchMethodError
            astore 0 /* nsme */
        start local 0 // java.lang.NoSuchMethodError nsme
        22: .line 169
            aload 0 /* nsme */
            invokevirtual java.lang.NoSuchMethodError.getMessage:()Ljava/lang/String;
            astore 1 /* msg */
        start local 1 // java.lang.String msg
        23: .line 170
            aload 1 /* msg */
            ifnull 28
            aload 1 /* msg */
            ldc "org.slf4j.impl.StaticLoggerBinder.getSingleton()"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 28
        24: .line 171
            iconst_2
            putstatic org.slf4j.LoggerFactory.INITIALIZATION_STATE:I
        25: .line 172
            ldc "slf4j-api 1.6.x (or later) is incompatible with this binding."
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
        26: .line 173
            ldc "Your binding is version 1.5.5 or earlier."
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
        27: .line 174
            ldc "Upgrade your binding to version 1.6.x."
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
        28: .line 176
      StackMap locals: java.lang.NoSuchMethodError java.lang.String
      StackMap stack:
            aload 0 /* nsme */
            athrow
        end local 1 // java.lang.String msg
        end local 0 // java.lang.NoSuchMethodError nsme
        29: .line 177
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 0 /* e */
        start local 0 // java.lang.Exception e
        30: .line 178
            aload 0 /* e */
            invokestatic org.slf4j.LoggerFactory.failedBinding:(Ljava/lang/Throwable;)V
        31: .line 179
            new java.lang.IllegalStateException
            dup
            ldc "Unexpected initialization failure"
            aload 0 /* e */
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 0 // java.lang.Exception e
        32: .line 181
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot                       Name  Signature
            1   10     0  staticLoggerBinderPathSet  Ljava/util/Set<Ljava/net/URL;>;
           12   21     0                       ncde  Ljava/lang/NoClassDefFoundError;
           13   21     1                        msg  Ljava/lang/String;
           22   29     0                       nsme  Ljava/lang/NoSuchMethodError;
           23   29     1                        msg  Ljava/lang/String;
           30   32     0                          e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           0    10      11  Class java.lang.NoClassDefFoundError
           0    10      21  Class java.lang.NoSuchMethodError
           0    10      29  Class java.lang.Exception

  private static void fixSubstituteLoggers();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=4, args_size=0
         0: .line 184
            getstatic org.slf4j.LoggerFactory.SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
            dup
            astore 0
            monitorenter
         1: .line 185
            getstatic org.slf4j.LoggerFactory.SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
            invokevirtual org.slf4j.helpers.SubstituteLoggerFactory.postInitialization:()V
         2: .line 186
            getstatic org.slf4j.LoggerFactory.SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
            invokevirtual org.slf4j.helpers.SubstituteLoggerFactory.getLoggers:()Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 2
            goto 6
      StackMap locals: org.slf4j.helpers.SubstituteLoggerFactory top java.util.Iterator
      StackMap stack:
         3: aload 2
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.slf4j.helpers.SubstituteLogger
            astore 1 /* substLogger */
        start local 1 // org.slf4j.helpers.SubstituteLogger substLogger
         4: .line 187
            aload 1 /* substLogger */
            invokevirtual org.slf4j.helpers.SubstituteLogger.getName:()Ljava/lang/String;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/String;)Lorg/slf4j/Logger;
            astore 3 /* logger */
        start local 3 // org.slf4j.Logger logger
         5: .line 188
            aload 1 /* substLogger */
            aload 3 /* logger */
            invokevirtual org.slf4j.helpers.SubstituteLogger.setDelegate:(Lorg/slf4j/Logger;)V
        end local 3 // org.slf4j.Logger logger
        end local 1 // org.slf4j.helpers.SubstituteLogger substLogger
         6: .line 186
      StackMap locals:
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         7: .line 184
            aload 0
            monitorexit
         8: goto 11
      StackMap locals: org.slf4j.helpers.SubstituteLoggerFactory
      StackMap stack: java.lang.Throwable
         9: aload 0
            monitorexit
        10: athrow
        11: .line 192
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            4    6     1  substLogger  Lorg/slf4j/helpers/SubstituteLogger;
            5    6     3       logger  Lorg/slf4j/Logger;
      Exception table:
        from    to  target  type
           1     8       9  any
           9    10       9  any

  static void failedBinding(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.Throwable t
         0: .line 195
            iconst_2
            putstatic org.slf4j.LoggerFactory.INITIALIZATION_STATE:I
         1: .line 196
            ldc "Failed to instantiate SLF4J LoggerFactory"
            aload 0 /* t */
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;Ljava/lang/Throwable;)V
         2: .line 197
            return
        end local 0 // java.lang.Throwable t
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  private static void replayEvents();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=7, args_size=0
         0: .line 200
            getstatic org.slf4j.LoggerFactory.SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
            invokevirtual org.slf4j.helpers.SubstituteLoggerFactory.getEventQueue:()Ljava/util/concurrent/LinkedBlockingQueue;
            astore 0 /* queue */
        start local 0 // java.util.concurrent.LinkedBlockingQueue queue
         1: .line 201
            aload 0 /* queue */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.size:()I
            istore 1 /* queueSize */
        start local 1 // int queueSize
         2: .line 202
            iconst_0
            istore 2 /* count */
        start local 2 // int count
         3: .line 204
            new java.util.ArrayList
            dup
            sipush 128
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 3 /* eventList */
        start local 3 // java.util.List eventList
         4: .line 206
      StackMap locals: java.util.concurrent.LinkedBlockingQueue int int java.util.List
      StackMap stack:
            aload 0 /* queue */
            aload 3 /* eventList */
            sipush 128
            invokevirtual java.util.concurrent.LinkedBlockingQueue.drainTo:(Ljava/util/Collection;I)I
            istore 4 /* numDrained */
        start local 4 // int numDrained
         5: .line 207
            iload 4 /* numDrained */
            ifne 7
         6: .line 208
            goto 15
         7: .line 209
      StackMap locals: int
      StackMap stack:
            aload 3 /* eventList */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 12
      StackMap locals: java.util.concurrent.LinkedBlockingQueue int int java.util.List int top java.util.Iterator
      StackMap stack:
         8: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.slf4j.event.SubstituteLoggingEvent
            astore 5 /* event */
        start local 5 // org.slf4j.event.SubstituteLoggingEvent event
         9: .line 210
            aload 5 /* event */
            invokestatic org.slf4j.LoggerFactory.replaySingleEvent:(Lorg/slf4j/event/SubstituteLoggingEvent;)V
        10: .line 211
            iload 2 /* count */
            iinc 2 /* count */ 1
            ifne 12
        11: .line 212
            aload 5 /* event */
            iload 1 /* queueSize */
            invokestatic org.slf4j.LoggerFactory.emitReplayOrSubstituionWarning:(Lorg/slf4j/event/SubstituteLoggingEvent;I)V
        end local 5 // org.slf4j.event.SubstituteLoggingEvent event
        12: .line 209
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 8
        13: .line 214
            aload 3 /* eventList */
            invokeinterface java.util.List.clear:()V
        end local 4 // int numDrained
        14: .line 205
            goto 4
        15: .line 216
      StackMap locals: java.util.concurrent.LinkedBlockingQueue int int java.util.List
      StackMap stack:
            return
        end local 3 // java.util.List eventList
        end local 2 // int count
        end local 1 // int queueSize
        end local 0 // java.util.concurrent.LinkedBlockingQueue queue
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            1   16     0       queue  Ljava/util/concurrent/LinkedBlockingQueue<Lorg/slf4j/event/SubstituteLoggingEvent;>;
            2   16     1   queueSize  I
            3   16     2       count  I
            4   16     3   eventList  Ljava/util/List<Lorg/slf4j/event/SubstituteLoggingEvent;>;
            5   14     4  numDrained  I
            9   12     5       event  Lorg/slf4j/event/SubstituteLoggingEvent;

  private static void emitReplayOrSubstituionWarning(org.slf4j.event.SubstituteLoggingEvent, int);
    descriptor: (Lorg/slf4j/event/SubstituteLoggingEvent;I)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // org.slf4j.event.SubstituteLoggingEvent event
        start local 1 // int queueSize
         0: .line 219
            aload 0 /* event */
            invokevirtual org.slf4j.event.SubstituteLoggingEvent.getLogger:()Lorg/slf4j/helpers/SubstituteLogger;
            invokevirtual org.slf4j.helpers.SubstituteLogger.isDelegateEventAware:()Z
            ifeq 3
         1: .line 220
            iload 1 /* queueSize */
            invokestatic org.slf4j.LoggerFactory.emitReplayWarning:(I)V
         2: .line 221
            goto 5
      StackMap locals:
      StackMap stack:
         3: aload 0 /* event */
            invokevirtual org.slf4j.event.SubstituteLoggingEvent.getLogger:()Lorg/slf4j/helpers/SubstituteLogger;
            invokevirtual org.slf4j.helpers.SubstituteLogger.isDelegateNOP:()Z
            ifne 5
         4: .line 224
            invokestatic org.slf4j.LoggerFactory.emitSubstitutionWarning:()V
         5: .line 226
      StackMap locals:
      StackMap stack:
            return
        end local 1 // int queueSize
        end local 0 // org.slf4j.event.SubstituteLoggingEvent event
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0      event  Lorg/slf4j/event/SubstituteLoggingEvent;
            0    6     1  queueSize  I
    MethodParameters:
           Name  Flags
      event      
      queueSize  

  private static void replaySingleEvent(org.slf4j.event.SubstituteLoggingEvent);
    descriptor: (Lorg/slf4j/event/SubstituteLoggingEvent;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // org.slf4j.event.SubstituteLoggingEvent event
         0: .line 229
            aload 0 /* event */
            ifnonnull 2
         1: .line 230
            return
         2: .line 232
      StackMap locals:
      StackMap stack:
            aload 0 /* event */
            invokevirtual org.slf4j.event.SubstituteLoggingEvent.getLogger:()Lorg/slf4j/helpers/SubstituteLogger;
            astore 1 /* substLogger */
        start local 1 // org.slf4j.helpers.SubstituteLogger substLogger
         3: .line 233
            aload 1 /* substLogger */
            invokevirtual org.slf4j.helpers.SubstituteLogger.getName:()Ljava/lang/String;
            astore 2 /* loggerName */
        start local 2 // java.lang.String loggerName
         4: .line 234
            aload 1 /* substLogger */
            invokevirtual org.slf4j.helpers.SubstituteLogger.isDelegateNull:()Z
            ifeq 6
         5: .line 235
            new java.lang.IllegalStateException
            dup
            ldc "Delegate logger cannot be null at this state."
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 238
      StackMap locals: org.slf4j.helpers.SubstituteLogger java.lang.String
      StackMap stack:
            aload 1 /* substLogger */
            invokevirtual org.slf4j.helpers.SubstituteLogger.isDelegateNOP:()Z
            ifne 11
         7: .line 240
            aload 1 /* substLogger */
            invokevirtual org.slf4j.helpers.SubstituteLogger.isDelegateEventAware:()Z
            ifeq 10
         8: .line 241
            aload 1 /* substLogger */
            aload 0 /* event */
            invokevirtual org.slf4j.helpers.SubstituteLogger.log:(Lorg/slf4j/event/LoggingEvent;)V
         9: .line 242
            goto 11
        10: .line 243
      StackMap locals:
      StackMap stack:
            aload 2 /* loggerName */
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
        11: .line 245
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String loggerName
        end local 1 // org.slf4j.helpers.SubstituteLogger substLogger
        end local 0 // org.slf4j.event.SubstituteLoggingEvent event
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   12     0        event  Lorg/slf4j/event/SubstituteLoggingEvent;
            3   12     1  substLogger  Lorg/slf4j/helpers/SubstituteLogger;
            4   12     2   loggerName  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      event  

  private static void emitSubstitutionWarning();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 248
            ldc "The following set of substitute loggers may have been accessed"
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         1: .line 249
            ldc "during the initialization phase. Logging calls during this"
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         2: .line 250
            ldc "phase were not honored. However, subsequent logging calls to these"
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         3: .line 251
            ldc "loggers will work as normally expected."
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         4: .line 252
            ldc "See also http://www.slf4j.org/codes.html#substituteLogger"
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         5: .line 253
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static void emitReplayWarning(int);
    descriptor: (I)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // int eventCount
         0: .line 256
            new java.lang.StringBuilder
            dup
            ldc "A number ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 0 /* eventCount */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ") of logging calls during the initialization phase have been intercepted and are"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         1: .line 257
            ldc "now being replayed. These are subject to the filtering rules of the underlying logging system."
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         2: .line 258
            ldc "See also http://www.slf4j.org/codes.html#replay"
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         3: .line 259
            return
        end local 0 // int eventCount
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0  eventCount  I
    MethodParameters:
            Name  Flags
      eventCount  

  private static final void versionSanityCheck();
    descriptor: ()V
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Code:
      stack=3, locals=6, args_size=0
         0: .line 263
            getstatic org.slf4j.impl.StaticLoggerBinder.REQUESTED_API_VERSION:Ljava/lang/String;
            astore 0 /* requested */
        start local 0 // java.lang.String requested
         1: .line 265
            iconst_0
            istore 1 /* match */
        start local 1 // boolean match
         2: .line 266
            getstatic org.slf4j.LoggerFactory.API_COMPATIBILITY_LIST:[Ljava/lang/String;
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 7
      StackMap locals: java.lang.String int top int int java.lang.String[]
      StackMap stack:
         3: aload 5
            iload 3
            aaload
            astore 2 /* aAPI_COMPATIBILITY_LIST */
        start local 2 // java.lang.String aAPI_COMPATIBILITY_LIST
         4: .line 267
            aload 0 /* requested */
            aload 2 /* aAPI_COMPATIBILITY_LIST */
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 6
         5: .line 268
            iconst_1
            istore 1 /* match */
        end local 2 // java.lang.String aAPI_COMPATIBILITY_LIST
         6: .line 266
      StackMap locals:
      StackMap stack:
            iinc 3 1
      StackMap locals:
      StackMap stack:
         7: iload 3
            iload 4
            if_icmplt 3
         8: .line 271
            iload 1 /* match */
            ifne 17
         9: .line 272
            new java.lang.StringBuilder
            dup
            ldc "The requested version "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* requested */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " by your slf4j binding is not compatible with "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        10: .line 273
            getstatic org.slf4j.LoggerFactory.API_COMPATIBILITY_LIST:[Ljava/lang/String;
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        11: .line 272
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
        12: .line 274
            ldc "See http://www.slf4j.org/codes.html#version_mismatch for further details."
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
        end local 1 // boolean match
        end local 0 // java.lang.String requested
        13: .line 276
            goto 17
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        14: pop
            goto 17
        15: .line 281
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 0 /* e */
        start local 0 // java.lang.Throwable e
        16: .line 283
            ldc "Unexpected problem occured during version sanity check"
            aload 0 /* e */
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 0 // java.lang.Throwable e
        17: .line 285
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot                     Name  Signature
            1   13     0                requested  Ljava/lang/String;
            2   13     1                    match  Z
            4    6     2  aAPI_COMPATIBILITY_LIST  Ljava/lang/String;
           16   17     0                        e  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           0    13      14  Class java.lang.NoSuchFieldError
           0    13      15  Class java.lang.Throwable

  static java.util.Set<java.net.URL> findPossibleStaticLoggerBinderPathSet();
    descriptor: ()Ljava/util/Set;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=4, args_size=0
         0: .line 296
            new java.util.LinkedHashSet
            dup
            invokespecial java.util.LinkedHashSet.<init>:()V
            astore 0 /* staticLoggerBinderPathSet */
        start local 0 // java.util.Set staticLoggerBinderPathSet
         1: .line 298
            ldc Lorg/slf4j/LoggerFactory;
            invokevirtual java.lang.Class.getClassLoader:()Ljava/lang/ClassLoader;
            astore 1 /* loggerFactoryClassLoader */
        start local 1 // java.lang.ClassLoader loggerFactoryClassLoader
         2: .line 300
            aload 1 /* loggerFactoryClassLoader */
            ifnonnull 5
         3: .line 301
            getstatic org.slf4j.LoggerFactory.STATIC_LOGGER_BINDER_PATH:Ljava/lang/String;
            invokestatic java.lang.ClassLoader.getSystemResources:(Ljava/lang/String;)Ljava/util/Enumeration;
            astore 2 /* paths */
        start local 2 // java.util.Enumeration paths
         4: .line 302
            goto 9
        end local 2 // java.util.Enumeration paths
         5: .line 303
      StackMap locals: java.util.Set java.lang.ClassLoader
      StackMap stack:
            aload 1 /* loggerFactoryClassLoader */
            getstatic org.slf4j.LoggerFactory.STATIC_LOGGER_BINDER_PATH:Ljava/lang/String;
            invokevirtual java.lang.ClassLoader.getResources:(Ljava/lang/String;)Ljava/util/Enumeration;
            astore 2 /* paths */
        start local 2 // java.util.Enumeration paths
         6: .line 305
            goto 9
         7: .line 306
      StackMap locals: java.util.Enumeration
      StackMap stack:
            aload 2 /* paths */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.net.URL
            astore 3 /* path */
        start local 3 // java.net.URL path
         8: .line 307
            aload 0 /* staticLoggerBinderPathSet */
            aload 3 /* path */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // java.net.URL path
         9: .line 305
      StackMap locals:
      StackMap stack:
            aload 2 /* paths */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 7
        end local 2 // java.util.Enumeration paths
        end local 1 // java.lang.ClassLoader loggerFactoryClassLoader
        10: .line 309
            goto 13
      StackMap locals: java.util.Set
      StackMap stack: java.io.IOException
        11: astore 1 /* ioe */
        start local 1 // java.io.IOException ioe
        12: .line 310
            ldc "Error getting resources from path"
            aload 1 /* ioe */
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 1 // java.io.IOException ioe
        13: .line 312
      StackMap locals:
      StackMap stack:
            aload 0 /* staticLoggerBinderPathSet */
            areturn
        end local 0 // java.util.Set staticLoggerBinderPathSet
      LocalVariableTable:
        Start  End  Slot                       Name  Signature
            1   14     0  staticLoggerBinderPathSet  Ljava/util/Set<Ljava/net/URL;>;
            2   10     1   loggerFactoryClassLoader  Ljava/lang/ClassLoader;
            4    5     2                      paths  Ljava/util/Enumeration<Ljava/net/URL;>;
            6   10     2                      paths  Ljava/util/Enumeration<Ljava/net/URL;>;
            8    9     3                       path  Ljava/net/URL;
           12   13     1                        ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1    10      11  Class java.io.IOException
    Signature: ()Ljava/util/Set<Ljava/net/URL;>;

  private static boolean isAmbiguousStaticLoggerBinderPathSet(java.util.Set<java.net.URL>);
    descriptor: (Ljava/util/Set;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.util.Set binderPathSet
         0: .line 316
            aload 0 /* binderPathSet */
            invokeinterface java.util.Set.size:()I
            iconst_1
            if_icmple 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // java.util.Set binderPathSet
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    2     0  binderPathSet  Ljava/util/Set<Ljava/net/URL;>;
    Signature: (Ljava/util/Set<Ljava/net/URL;>;)Z
    MethodParameters:
               Name  Flags
      binderPathSet  

  private static void reportMultipleBindingAmbiguity(java.util.Set<java.net.URL>);
    descriptor: (Ljava/util/Set;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // java.util.Set binderPathSet
         0: .line 325
            aload 0 /* binderPathSet */
            invokestatic org.slf4j.LoggerFactory.isAmbiguousStaticLoggerBinderPathSet:(Ljava/util/Set;)Z
            ifeq 7
         1: .line 326
            ldc "Class path contains multiple SLF4J bindings."
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         2: .line 327
            aload 0 /* binderPathSet */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 2
            goto 5
      StackMap locals: java.util.Set top java.util.Iterator
      StackMap stack:
         3: aload 2
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.URL
            astore 1 /* path */
        start local 1 // java.net.URL path
         4: .line 328
            new java.lang.StringBuilder
            dup
            ldc "Found binding in ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* path */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc "]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
        end local 1 // java.net.URL path
         5: .line 327
      StackMap locals:
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 330
            ldc "See http://www.slf4j.org/codes.html#multiple_bindings for an explanation."
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         7: .line 332
      StackMap locals: java.util.Set
      StackMap stack:
            return
        end local 0 // java.util.Set binderPathSet
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    8     0  binderPathSet  Ljava/util/Set<Ljava/net/URL;>;
            4    5     1           path  Ljava/net/URL;
    Signature: (Ljava/util/Set<Ljava/net/URL;>;)V
    MethodParameters:
               Name  Flags
      binderPathSet  

  private static boolean isAndroid();
    descriptor: ()Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 335
            ldc "java.vendor.url"
            invokestatic org.slf4j.helpers.Util.safeGetSystemProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 0 /* vendor */
        start local 0 // java.lang.String vendor
         1: .line 336
            aload 0 /* vendor */
            ifnonnull 3
         2: .line 337
            iconst_0
            ireturn
         3: .line 338
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* vendor */
            invokevirtual java.lang.String.toLowerCase:()Ljava/lang/String;
            ldc "android"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ireturn
        end local 0 // java.lang.String vendor
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            1    4     0  vendor  Ljava/lang/String;

  private static void reportActualBinding(java.util.Set<java.net.URL>);
    descriptor: (Ljava/util/Set;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // java.util.Set binderPathSet
         0: .line 343
            aload 0 /* binderPathSet */
            ifnull 2
            aload 0 /* binderPathSet */
            invokestatic org.slf4j.LoggerFactory.isAmbiguousStaticLoggerBinderPathSet:(Ljava/util/Set;)Z
            ifeq 2
         1: .line 344
            new java.lang.StringBuilder
            dup
            ldc "Actual binding is of type ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            invokestatic org.slf4j.impl.StaticLoggerBinder.getSingleton:()Lorg/slf4j/impl/StaticLoggerBinder;
            invokevirtual org.slf4j.impl.StaticLoggerBinder.getLoggerFactoryClassStr:()Ljava/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;
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         2: .line 346
      StackMap locals:
      StackMap stack:
            return
        end local 0 // java.util.Set binderPathSet
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    3     0  binderPathSet  Ljava/util/Set<Ljava/net/URL;>;
    Signature: (Ljava/util/Set<Ljava/net/URL;>;)V
    MethodParameters:
               Name  Flags
      binderPathSet  

  public static org.slf4j.Logger getLogger(java.lang.String);
    descriptor: (Ljava/lang/String;)Lorg/slf4j/Logger;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // java.lang.String name
         0: .line 357
            invokestatic org.slf4j.LoggerFactory.getILoggerFactory:()Lorg/slf4j/ILoggerFactory;
            astore 1 /* iLoggerFactory */
        start local 1 // org.slf4j.ILoggerFactory iLoggerFactory
         1: .line 358
            aload 1 /* iLoggerFactory */
            aload 0 /* name */
            invokeinterface org.slf4j.ILoggerFactory.getLogger:(Ljava/lang/String;)Lorg/slf4j/Logger;
            areturn
        end local 1 // org.slf4j.ILoggerFactory iLoggerFactory
        end local 0 // java.lang.String name
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            name  Ljava/lang/String;
            1    2     1  iLoggerFactory  Lorg/slf4j/ILoggerFactory;
    MethodParameters:
      Name  Flags
      name  

  public static org.slf4j.Logger getLogger(java.lang.Class<?>);
    descriptor: (Ljava/lang/Class;)Lorg/slf4j/Logger;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=1
        start local 0 // java.lang.Class clazz
         0: .line 383
            aload 0 /* clazz */
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/String;)Lorg/slf4j/Logger;
            astore 1 /* logger */
        start local 1 // org.slf4j.Logger logger
         1: .line 384
            getstatic org.slf4j.LoggerFactory.DETECT_LOGGER_NAME_MISMATCH:Z
            ifeq 8
         2: .line 385
            invokestatic org.slf4j.helpers.Util.getCallingClass:()Ljava/lang/Class;
            astore 2 /* autoComputedCallingClass */
        start local 2 // java.lang.Class autoComputedCallingClass
         3: .line 386
            aload 2 /* autoComputedCallingClass */
            ifnull 8
            aload 0 /* clazz */
            aload 2 /* autoComputedCallingClass */
            invokestatic org.slf4j.LoggerFactory.nonMatchingClasses:(Ljava/lang/Class;Ljava/lang/Class;)Z
            ifeq 8
         4: .line 387
            ldc "Detected logger name mismatch. Given name: \"%s\"; computed name: \"%s\"."
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 1 /* logger */
            invokeinterface org.slf4j.Logger.getName:()Ljava/lang/String;
            aastore
            dup
            iconst_1
         5: .line 388
            aload 2 /* autoComputedCallingClass */
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            aastore
         6: .line 387
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
         7: .line 389
            ldc "See http://www.slf4j.org/codes.html#loggerNameMismatch for an explanation"
            invokestatic org.slf4j.helpers.Util.report:(Ljava/lang/String;)V
        end local 2 // java.lang.Class autoComputedCallingClass
         8: .line 392
      StackMap locals: org.slf4j.Logger
      StackMap stack:
            aload 1 /* logger */
            areturn
        end local 1 // org.slf4j.Logger logger
        end local 0 // java.lang.Class clazz
      LocalVariableTable:
        Start  End  Slot                      Name  Signature
            0    9     0                     clazz  Ljava/lang/Class<*>;
            1    9     1                    logger  Lorg/slf4j/Logger;
            3    8     2  autoComputedCallingClass  Ljava/lang/Class<*>;
    Signature: (Ljava/lang/Class<*>;)Lorg/slf4j/Logger;
    MethodParameters:
       Name  Flags
      clazz  

  private static boolean nonMatchingClasses(java.lang.Class<?>, java.lang.Class<?>);
    descriptor: (Ljava/lang/Class;Ljava/lang/Class;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.lang.Class clazz
        start local 1 // java.lang.Class autoComputedCallingClass
         0: .line 396
            aload 1 /* autoComputedCallingClass */
            aload 0 /* clazz */
            invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
            ifeq 1
            iconst_0
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_1
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 1 // java.lang.Class autoComputedCallingClass
        end local 0 // java.lang.Class clazz
      LocalVariableTable:
        Start  End  Slot                      Name  Signature
            0    3     0                     clazz  Ljava/lang/Class<*>;
            0    3     1  autoComputedCallingClass  Ljava/lang/Class<*>;
    Signature: (Ljava/lang/Class<*>;Ljava/lang/Class<*>;)Z
    MethodParameters:
                          Name  Flags
      clazz                     
      autoComputedCallingClass  

  public static org.slf4j.ILoggerFactory getILoggerFactory();
    descriptor: ()Lorg/slf4j/ILoggerFactory;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 408
            getstatic org.slf4j.LoggerFactory.INITIALIZATION_STATE:I
            ifne 9
         1: .line 409
            ldc Lorg/slf4j/LoggerFactory;
            dup
            astore 0
            monitorenter
         2: .line 410
            getstatic org.slf4j.LoggerFactory.INITIALIZATION_STATE:I
            ifne 5
         3: .line 411
            iconst_1
            putstatic org.slf4j.LoggerFactory.INITIALIZATION_STATE:I
         4: .line 412
            invokestatic org.slf4j.LoggerFactory.performInitialization:()V
         5: .line 409
      StackMap locals: java.lang.Class
      StackMap stack:
            aload 0
            monitorexit
         6: goto 9
      StackMap locals:
      StackMap stack: java.lang.Throwable
         7: aload 0
            monitorexit
         8: athrow
         9: .line 416
      StackMap locals:
      StackMap stack:
            getstatic org.slf4j.LoggerFactory.INITIALIZATION_STATE:I
            tableswitch { // 1 - 4
                    1: 13
                    2: 12
                    3: 10
                    4: 11
              default: 14
          }
        10: .line 418
      StackMap locals:
      StackMap stack:
            invokestatic org.slf4j.impl.StaticLoggerBinder.getSingleton:()Lorg/slf4j/impl/StaticLoggerBinder;
            invokevirtual org.slf4j.impl.StaticLoggerBinder.getLoggerFactory:()Lorg/slf4j/ILoggerFactory;
            areturn
        11: .line 420
      StackMap locals:
      StackMap stack:
            getstatic org.slf4j.LoggerFactory.NOP_FALLBACK_FACTORY:Lorg/slf4j/helpers/NOPLoggerFactory;
            areturn
        12: .line 422
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalStateException
            dup
            ldc "org.slf4j.LoggerFactory in failed state. Original exception was thrown EARLIER. See also http://www.slf4j.org/codes.html#unsuccessfulInit"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 426
      StackMap locals:
      StackMap stack:
            getstatic org.slf4j.LoggerFactory.SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
            areturn
        14: .line 428
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalStateException
            dup
            ldc "Unreachable code"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           2     6       7  any
           7     8       7  any
}
SourceFile: "LoggerFactory.java"