LoggerFactory.smali
.class public final Lorg/slf4j/LoggerFactory;
.super Ljava/lang/Object;
.source "LoggerFactory.java"
# static fields
.field private static final API_COMPATIBILITY_LIST:[Ljava/lang/String;
.field static final CODES_PREFIX:Ljava/lang/String; = "http://www.slf4j.org/codes.html"
.field static DETECT_LOGGER_NAME_MISMATCH:Z = false
.field static final DETECT_LOGGER_NAME_MISMATCH_PROPERTY:Ljava/lang/String; = "slf4j.detectLoggerNameMismatch"
.field static final FAILED_INITIALIZATION:I = 0x2
.field static volatile INITIALIZATION_STATE:I = 0x0
.field static final JAVA_VENDOR_PROPERTY:Ljava/lang/String; = "java.vendor.url"
.field static final LOGGER_NAME_MISMATCH_URL:Ljava/lang/String; = "http://www.slf4j.org/codes.html#loggerNameMismatch"
.field static final MULTIPLE_BINDINGS_URL:Ljava/lang/String; = "http://www.slf4j.org/codes.html#multiple_bindings"
.field static NOP_FALLBACK_FACTORY:Lorg/slf4j/helpers/NOPLoggerFactory; = null
.field static final NOP_FALLBACK_INITIALIZATION:I = 0x4
.field static final NO_STATICLOGGERBINDER_URL:Ljava/lang/String; = "http://www.slf4j.org/codes.html#StaticLoggerBinder"
.field static final NULL_LF_URL:Ljava/lang/String; = "http://www.slf4j.org/codes.html#null_LF"
.field static final ONGOING_INITIALIZATION:I = 0x1
.field static final REPLAY_URL:Ljava/lang/String; = "http://www.slf4j.org/codes.html#replay"
.field private static STATIC_LOGGER_BINDER_PATH:Ljava/lang/String; = null
.field static final SUBSTITUTE_LOGGER_URL:Ljava/lang/String; = "http://www.slf4j.org/codes.html#substituteLogger"
.field static SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory; = null
.field static final SUCCESSFUL_INITIALIZATION:I = 0x3
.field static final UNINITIALIZED:I = 0x0
.field static final UNSUCCESSFUL_INIT_MSG:Ljava/lang/String; = "org.slf4j.LoggerFactory could not be successfully initialized. See also http://www.slf4j.org/codes.html#unsuccessfulInit"
.field static final UNSUCCESSFUL_INIT_URL:Ljava/lang/String; = "http://www.slf4j.org/codes.html#unsuccessfulInit"
.field static final VERSION_MISMATCH:Ljava/lang/String; = "http://www.slf4j.org/codes.html#version_mismatch"
# direct methods
.method static constructor <clinit>()V
.registers 2
.line 85
const/4 v0, 0x0
sput v0, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
.line 86
new-instance v0, Lorg/slf4j/helpers/SubstituteLoggerFactory;
invoke-direct {v0}, Lorg/slf4j/helpers/SubstituteLoggerFactory;-><init>()V
sput-object v0, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
.line 87
new-instance v0, Lorg/slf4j/helpers/NOPLoggerFactory;
invoke-direct {v0}, Lorg/slf4j/helpers/NOPLoggerFactory;-><init>()V
sput-object v0, Lorg/slf4j/LoggerFactory;->NOP_FALLBACK_FACTORY:Lorg/slf4j/helpers/NOPLoggerFactory;
.line 93
const-string v0, "slf4j.detectLoggerNameMismatch"
invoke-static {v0}, Lorg/slf4j/helpers/Util;->safeGetBooleanSystemProperty(Ljava/lang/String;)Z
move-result v0
sput-boolean v0, Lorg/slf4j/LoggerFactory;->DETECT_LOGGER_NAME_MISMATCH:Z
.line 102
const-string v0, "1.6"
const-string v1, "1.7"
filled-new-array {v0, v1}, [Ljava/lang/String;
move-result-object v0
sput-object v0, Lorg/slf4j/LoggerFactory;->API_COMPATIBILITY_LIST:[Ljava/lang/String;
.line 290
const-string v0, "org/slf4j/impl/StaticLoggerBinder.class"
sput-object v0, Lorg/slf4j/LoggerFactory;->STATIC_LOGGER_BINDER_PATH:Ljava/lang/String;
return-void
.end method
.method private constructor <init>()V
.registers 1
.line 105
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 106
return-void
.end method
.method private static final bind()V
.registers 3
.line 142
const/4 v0, 0x0
.line 145
.local v0, "staticLoggerBinderPathSet":Ljava/util/Set;, "Ljava/util/Set<Ljava/net/URL;>;"
:try_start_1
invoke-static {}, Lorg/slf4j/LoggerFactory;->isAndroid()Z
move-result v1
if-nez v1, :cond_f
.line 146
invoke-static {}, Lorg/slf4j/LoggerFactory;->findPossibleStaticLoggerBinderPathSet()Ljava/util/Set;
move-result-object v1
move-object v0, v1
.line 147
invoke-static {v0}, Lorg/slf4j/LoggerFactory;->reportMultipleBindingAmbiguity(Ljava/util/Set;)V
.line 150
:cond_f
invoke-static {}, Lorg/slf4j/impl/StaticLoggerBinder;->getSingleton()Lorg/slf4j/impl/StaticLoggerBinder;
.line 151
const/4 v1, 0x3
sput v1, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
.line 152
invoke-static {v0}, Lorg/slf4j/LoggerFactory;->reportActualBinding(Ljava/util/Set;)V
.line 153
invoke-static {}, Lorg/slf4j/LoggerFactory;->fixSubstituteLoggers()V
.line 154
invoke-static {}, Lorg/slf4j/LoggerFactory;->replayEvents()V
.line 156
sget-object v1, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
invoke-virtual {v1}, Lorg/slf4j/helpers/SubstituteLoggerFactory;->clear()V
:try_end_23
.catch Ljava/lang/NoClassDefFoundError; {:try_start_1 .. :try_end_23} :catch_52
.catch Ljava/lang/NoSuchMethodError; {:try_start_1 .. :try_end_23} :catch_30
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_23} :catch_24
.end local v0 # "staticLoggerBinderPathSet":Ljava/util/Set;, "Ljava/util/Set<Ljava/net/URL;>;"
goto :goto_6f
.line 177
:catch_24
move-exception v0
.line 178
.local v0, "e":Ljava/lang/Exception;
invoke-static {v0}, Lorg/slf4j/LoggerFactory;->failedBinding(Ljava/lang/Throwable;)V
.line 179
new-instance v1, Ljava/lang/IllegalStateException;
const-string v2, "Unexpected initialization failure"
invoke-direct {v1, v2, v0}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.line 168
.end local v0 # "e":Ljava/lang/Exception;
:catch_30
move-exception v0
.line 169
.local v0, "nsme":Ljava/lang/NoSuchMethodError;
invoke-virtual {v0}, Ljava/lang/NoSuchMethodError;->getMessage()Ljava/lang/String;
move-result-object v1
.line 170
.local v1, "msg":Ljava/lang/String;
if-eqz v1, :cond_51
const-string v2, "org.slf4j.impl.StaticLoggerBinder.getSingleton()"
invoke-virtual {v1, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_51
.line 171
const/4 v2, 0x2
sput v2, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
.line 172
const-string v2, "slf4j-api 1.6.x (or later) is incompatible with this binding."
invoke-static {v2}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 173
const-string v2, "Your binding is version 1.5.5 or earlier."
invoke-static {v2}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 174
const-string v2, "Upgrade your binding to version 1.6.x."
invoke-static {v2}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 176
:cond_51
throw v0
.line 157
.end local v0 # "nsme":Ljava/lang/NoSuchMethodError;
.end local v1 # "msg":Ljava/lang/String;
:catch_52
move-exception v0
.line 158
.local v0, "ncde":Ljava/lang/NoClassDefFoundError;
invoke-virtual {v0}, Ljava/lang/NoClassDefFoundError;->getMessage()Ljava/lang/String;
move-result-object v1
.line 159
.restart local v1 # "msg":Ljava/lang/String;
invoke-static {v1}, Lorg/slf4j/LoggerFactory;->messageContainsOrgSlf4jImplStaticLoggerBinder(Ljava/lang/String;)Z
move-result v2
if-eqz v2, :cond_71
.line 160
const/4 v2, 0x4
sput v2, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
.line 161
const-string v2, "Failed to load class \"org.slf4j.impl.StaticLoggerBinder\"."
invoke-static {v2}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 162
const-string v2, "Defaulting to no-operation (NOP) logger implementation"
invoke-static {v2}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 163
const-string v2, "See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details."
invoke-static {v2}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 180
.end local v0 # "ncde":Ljava/lang/NoClassDefFoundError;
.end local v1 # "msg":Ljava/lang/String;
:goto_6f
nop
.line 181
return-void
.line 165
.restart local v0 # "ncde":Ljava/lang/NoClassDefFoundError;
.restart local v1 # "msg":Ljava/lang/String;
:cond_71
invoke-static {v0}, Lorg/slf4j/LoggerFactory;->failedBinding(Ljava/lang/Throwable;)V
.line 166
throw v0
.end method
.method private static emitReplayOrSubstituionWarning(Lorg/slf4j/event/SubstituteLoggingEvent;I)V
.registers 3
.param p0, "event" # Lorg/slf4j/event/SubstituteLoggingEvent;
.param p1, "queueSize" # I
.line 219
invoke-virtual {p0}, Lorg/slf4j/event/SubstituteLoggingEvent;->getLogger()Lorg/slf4j/helpers/SubstituteLogger;
move-result-object v0
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLogger;->isDelegateEventAware()Z
move-result v0
if-eqz v0, :cond_e
.line 220
invoke-static {p1}, Lorg/slf4j/LoggerFactory;->emitReplayWarning(I)V
goto :goto_1c
.line 221
:cond_e
invoke-virtual {p0}, Lorg/slf4j/event/SubstituteLoggingEvent;->getLogger()Lorg/slf4j/helpers/SubstituteLogger;
move-result-object v0
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLogger;->isDelegateNOP()Z
move-result v0
if-eqz v0, :cond_19
goto :goto_1c
.line 224
:cond_19
invoke-static {}, Lorg/slf4j/LoggerFactory;->emitSubstitutionWarning()V
.line 226
:goto_1c
return-void
.end method
.method private static emitReplayWarning(I)V
.registers 3
.param p0, "eventCount" # I
.line 256
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "A number ("
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, ") of logging calls during the initialization phase have been intercepted and are"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 257
const-string v0, "now being replayed. These are subject to the filtering rules of the underlying logging system."
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 258
const-string v0, "See also http://www.slf4j.org/codes.html#replay"
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 259
return-void
.end method
.method private static emitSubstitutionWarning()V
.registers 1
.line 248
const-string v0, "The following set of substitute loggers may have been accessed"
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 249
const-string v0, "during the initialization phase. Logging calls during this"
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 250
const-string v0, "phase were not honored. However, subsequent logging calls to these"
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 251
const-string v0, "loggers will work as normally expected."
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 252
const-string v0, "See also http://www.slf4j.org/codes.html#substituteLogger"
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 253
return-void
.end method
.method static failedBinding(Ljava/lang/Throwable;)V
.registers 2
.param p0, "t" # Ljava/lang/Throwable;
.line 195
const/4 v0, 0x2
sput v0, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
.line 196
const-string v0, "Failed to instantiate SLF4J LoggerFactory"
invoke-static {v0, p0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 197
return-void
.end method
.method static findPossibleStaticLoggerBinderPathSet()Ljava/util/Set;
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Set<",
"Ljava/net/URL;",
">;"
}
.end annotation
.line 296
new-instance v0, Ljava/util/LinkedHashSet;
invoke-direct {v0}, Ljava/util/LinkedHashSet;-><init>()V
.line 298
.local v0, "staticLoggerBinderPathSet":Ljava/util/Set;, "Ljava/util/Set<Ljava/net/URL;>;"
:try_start_5
const-class v1, Lorg/slf4j/LoggerFactory;
invoke-virtual {v1}, Ljava/lang/Class;->getClassLoader()Ljava/lang/ClassLoader;
move-result-object v1
.line 300
.local v1, "loggerFactoryClassLoader":Ljava/lang/ClassLoader;
if-nez v1, :cond_14
.line 301
sget-object v2, Lorg/slf4j/LoggerFactory;->STATIC_LOGGER_BINDER_PATH:Ljava/lang/String;
invoke-static {v2}, Ljava/lang/ClassLoader;->getSystemResources(Ljava/lang/String;)Ljava/util/Enumeration;
move-result-object v2
.local v2, "paths":Ljava/util/Enumeration;, "Ljava/util/Enumeration<Ljava/net/URL;>;"
goto :goto_1a
.line 303
.end local v2 # "paths":Ljava/util/Enumeration;, "Ljava/util/Enumeration<Ljava/net/URL;>;"
:cond_14
sget-object v2, Lorg/slf4j/LoggerFactory;->STATIC_LOGGER_BINDER_PATH:Ljava/lang/String;
invoke-virtual {v1, v2}, Ljava/lang/ClassLoader;->getResources(Ljava/lang/String;)Ljava/util/Enumeration;
move-result-object v2
.line 305
.restart local v2 # "paths":Ljava/util/Enumeration;, "Ljava/util/Enumeration<Ljava/net/URL;>;"
:goto_1a
invoke-interface {v2}, Ljava/util/Enumeration;->hasMoreElements()Z
move-result v3
if-eqz v3, :cond_2b
.line 306
invoke-interface {v2}, Ljava/util/Enumeration;->nextElement()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/net/URL;
.line 307
.local v3, "path":Ljava/net/URL;
invoke-interface {v0, v3}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
:try_end_29
.catch Ljava/io/IOException; {:try_start_5 .. :try_end_29} :catch_2c
.line 308
nop
.end local v3 # "path":Ljava/net/URL;
goto :goto_1a
.line 311
.end local v1 # "loggerFactoryClassLoader":Ljava/lang/ClassLoader;
.end local v2 # "paths":Ljava/util/Enumeration;, "Ljava/util/Enumeration<Ljava/net/URL;>;"
:cond_2b
goto :goto_32
.line 309
:catch_2c
move-exception v1
.line 310
.local v1, "ioe":Ljava/io/IOException;
const-string v2, "Error getting resources from path"
invoke-static {v2, v1}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 312
.end local v1 # "ioe":Ljava/io/IOException;
:goto_32
return-object v0
.end method
.method private static fixSubstituteLoggers()V
.registers 4
.line 184
sget-object v0, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
monitor-enter v0
.line 185
:try_start_3
sget-object v1, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
invoke-virtual {v1}, Lorg/slf4j/helpers/SubstituteLoggerFactory;->postInitialization()V
.line 186
sget-object v1, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
invoke-virtual {v1}, Lorg/slf4j/helpers/SubstituteLoggerFactory;->getLoggers()Ljava/util/List;
move-result-object v1
invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v1
.local v1, "i$":Ljava/util/Iterator;
:goto_12
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_2a
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lorg/slf4j/helpers/SubstituteLogger;
.line 187
.local v2, "substLogger":Lorg/slf4j/helpers/SubstituteLogger;
invoke-virtual {v2}, Lorg/slf4j/helpers/SubstituteLogger;->getName()Ljava/lang/String;
move-result-object v3
invoke-static {v3}, Lorg/slf4j/LoggerFactory;->getLogger(Ljava/lang/String;)Lorg/slf4j/Logger;
move-result-object v3
.line 188
.local v3, "logger":Lorg/slf4j/Logger;
invoke-virtual {v2, v3}, Lorg/slf4j/helpers/SubstituteLogger;->setDelegate(Lorg/slf4j/Logger;)V
.line 189
.end local v2 # "substLogger":Lorg/slf4j/helpers/SubstituteLogger;
.end local v3 # "logger":Lorg/slf4j/Logger;
goto :goto_12
.line 190
.end local v1 # "i$":Ljava/util/Iterator;
:cond_2a
monitor-exit v0
.line 192
return-void
.line 190
:catchall_2c
move-exception v1
monitor-exit v0
:try_end_2e
.catchall {:try_start_3 .. :try_end_2e} :catchall_2c
goto :goto_30
:goto_2f
throw v1
:goto_30
goto :goto_2f
.end method
.method public static getILoggerFactory()Lorg/slf4j/ILoggerFactory;
.registers 3
.line 408
sget v0, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
const/4 v1, 0x1
if-nez v0, :cond_16
.line 409
const-class v0, Lorg/slf4j/LoggerFactory;
monitor-enter v0
.line 410
:try_start_8
sget v2, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
if-nez v2, :cond_11
.line 411
sput v1, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
.line 412
invoke-static {}, Lorg/slf4j/LoggerFactory;->performInitialization()V
.line 414
:cond_11
monitor-exit v0
goto :goto_16
:catchall_13
move-exception v1
monitor-exit v0
:try_end_15
.catchall {:try_start_8 .. :try_end_15} :catchall_13
throw v1
.line 416
:cond_16
:goto_16
sget v0, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
if-eq v0, v1, :cond_3f
const/4 v1, 0x2
if-eq v0, v1, :cond_37
const/4 v1, 0x3
if-eq v0, v1, :cond_2e
const/4 v1, 0x4
if-ne v0, v1, :cond_26
.line 420
sget-object v0, Lorg/slf4j/LoggerFactory;->NOP_FALLBACK_FACTORY:Lorg/slf4j/helpers/NOPLoggerFactory;
return-object v0
.line 428
:cond_26
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Unreachable code"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 418
:cond_2e
invoke-static {}, Lorg/slf4j/impl/StaticLoggerBinder;->getSingleton()Lorg/slf4j/impl/StaticLoggerBinder;
move-result-object v0
invoke-virtual {v0}, Lorg/slf4j/impl/StaticLoggerBinder;->getLoggerFactory()Lorg/slf4j/ILoggerFactory;
move-result-object v0
return-object v0
.line 422
:cond_37
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "org.slf4j.LoggerFactory could not be successfully initialized. See also http://www.slf4j.org/codes.html#unsuccessfulInit"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 426
:cond_3f
sget-object v0, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
return-object v0
.end method
.method public static getLogger(Ljava/lang/Class;)Lorg/slf4j/Logger;
.registers 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/Class<",
"*>;)",
"Lorg/slf4j/Logger;"
}
.end annotation
.line 383
.local p0, "clazz":Ljava/lang/Class;, "Ljava/lang/Class<*>;"
invoke-virtual {p0}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lorg/slf4j/LoggerFactory;->getLogger(Ljava/lang/String;)Lorg/slf4j/Logger;
move-result-object v0
.line 384
.local v0, "logger":Lorg/slf4j/Logger;
sget-boolean v1, Lorg/slf4j/LoggerFactory;->DETECT_LOGGER_NAME_MISMATCH:Z
if-eqz v1, :cond_37
.line 385
invoke-static {}, Lorg/slf4j/helpers/Util;->getCallingClass()Ljava/lang/Class;
move-result-object v1
.line 386
.local v1, "autoComputedCallingClass":Ljava/lang/Class;, "Ljava/lang/Class<*>;"
if-eqz v1, :cond_37
invoke-static {p0, v1}, Lorg/slf4j/LoggerFactory;->nonMatchingClasses(Ljava/lang/Class;Ljava/lang/Class;)Z
move-result v2
if-eqz v2, :cond_37
.line 387
const/4 v2, 0x2
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
invoke-interface {v0}, Lorg/slf4j/Logger;->getName()Ljava/lang/String;
move-result-object v4
aput-object v4, v2, v3
const/4 v3, 0x1
invoke-virtual {v1}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v4
aput-object v4, v2, v3
const-string v3, "Detected logger name mismatch. Given name: \"%s\"; computed name: \"%s\"."
invoke-static {v3, v2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
invoke-static {v2}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 389
const-string v2, "See http://www.slf4j.org/codes.html#loggerNameMismatch for an explanation"
invoke-static {v2}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 392
.end local v1 # "autoComputedCallingClass":Ljava/lang/Class;, "Ljava/lang/Class<*>;"
:cond_37
return-object v0
.end method
.method public static getLogger(Ljava/lang/String;)Lorg/slf4j/Logger;
.registers 3
.param p0, "name" # Ljava/lang/String;
.line 357
invoke-static {}, Lorg/slf4j/LoggerFactory;->getILoggerFactory()Lorg/slf4j/ILoggerFactory;
move-result-object v0
.line 358
.local v0, "iLoggerFactory":Lorg/slf4j/ILoggerFactory;
invoke-interface {v0, p0}, Lorg/slf4j/ILoggerFactory;->getLogger(Ljava/lang/String;)Lorg/slf4j/Logger;
move-result-object v1
return-object v1
.end method
.method private static isAmbiguousStaticLoggerBinderPathSet(Ljava/util/Set;)Z
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Set<",
"Ljava/net/URL;",
">;)Z"
}
.end annotation
.line 316
.local p0, "binderPathSet":Ljava/util/Set;, "Ljava/util/Set<Ljava/net/URL;>;"
invoke-interface {p0}, Ljava/util/Set;->size()I
move-result v0
const/4 v1, 0x1
if-le v0, v1, :cond_8
goto :goto_9
:cond_8
const/4 v1, 0x0
:goto_9
return v1
.end method
.method private static isAndroid()Z
.registers 3
.line 335
const-string v0, "java.vendor.url"
invoke-static {v0}, Lorg/slf4j/helpers/Util;->safeGetSystemProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 336
.local v0, "vendor":Ljava/lang/String;
if-nez v0, :cond_a
.line 337
const/4 v1, 0x0
return v1
.line 338
:cond_a
invoke-virtual {v0}, Ljava/lang/String;->toLowerCase()Ljava/lang/String;
move-result-object v1
const-string v2, "android"
invoke-virtual {v1, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v1
return v1
.end method
.method private static messageContainsOrgSlf4jImplStaticLoggerBinder(Ljava/lang/String;)Z
.registers 4
.param p0, "msg" # Ljava/lang/String;
.line 131
const/4 v0, 0x0
if-nez p0, :cond_4
.line 132
return v0
.line 133
:cond_4
const-string v1, "org/slf4j/impl/StaticLoggerBinder"
invoke-virtual {p0, v1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v1
const/4 v2, 0x1
if-eqz v1, :cond_e
.line 134
return v2
.line 135
:cond_e
const-string v1, "org.slf4j.impl.StaticLoggerBinder"
invoke-virtual {p0, v1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v1
if-eqz v1, :cond_17
.line 136
return v2
.line 137
:cond_17
return v0
.end method
.method private static nonMatchingClasses(Ljava/lang/Class;Ljava/lang/Class;)Z
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/Class<",
"*>;",
"Ljava/lang/Class<",
"*>;)Z"
}
.end annotation
.line 396
.local p0, "clazz":Ljava/lang/Class;, "Ljava/lang/Class<*>;"
.local p1, "autoComputedCallingClass":Ljava/lang/Class;, "Ljava/lang/Class<*>;"
invoke-virtual {p1, p0}, Ljava/lang/Class;->isAssignableFrom(Ljava/lang/Class;)Z
move-result v0
xor-int/lit8 v0, v0, 0x1
return v0
.end method
.method private static final performInitialization()V
.registers 2
.line 124
invoke-static {}, Lorg/slf4j/LoggerFactory;->bind()V
.line 125
sget v0, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
const/4 v1, 0x3
if-ne v0, v1, :cond_b
.line 126
invoke-static {}, Lorg/slf4j/LoggerFactory;->versionSanityCheck()V
.line 128
:cond_b
return-void
.end method
.method private static replayEvents()V
.registers 10
.line 200
sget-object v0, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLoggerFactory;->getEventQueue()Ljava/util/concurrent/LinkedBlockingQueue;
move-result-object v0
.line 201
.local v0, "queue":Ljava/util/concurrent/LinkedBlockingQueue;, "Ljava/util/concurrent/LinkedBlockingQueue<Lorg/slf4j/event/SubstituteLoggingEvent;>;"
invoke-virtual {v0}, Ljava/util/concurrent/LinkedBlockingQueue;->size()I
move-result v1
.line 202
.local v1, "queueSize":I
const/4 v2, 0x0
.line 203
.local v2, "count":I
const/16 v3, 0x80
.line 204
.local v3, "maxDrain":I
new-instance v4, Ljava/util/ArrayList;
const/16 v5, 0x80
invoke-direct {v4, v5}, Ljava/util/ArrayList;-><init>(I)V
.line 206
.local v4, "eventList":Ljava/util/List;, "Ljava/util/List<Lorg/slf4j/event/SubstituteLoggingEvent;>;"
:goto_14
invoke-virtual {v0, v4, v5}, Ljava/util/concurrent/LinkedBlockingQueue;->drainTo(Ljava/util/Collection;I)I
move-result v6
.line 207
.local v6, "numDrained":I
if-nez v6, :cond_1c
.line 208
nop
.line 216
.end local v6 # "numDrained":I
return-void
.line 209
.restart local v6 # "numDrained":I
:cond_1c
invoke-interface {v4}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v7
.local v7, "i$":Ljava/util/Iterator;
:goto_20
invoke-interface {v7}, Ljava/util/Iterator;->hasNext()Z
move-result v8
if-eqz v8, :cond_38
invoke-interface {v7}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v8
check-cast v8, Lorg/slf4j/event/SubstituteLoggingEvent;
.line 210
.local v8, "event":Lorg/slf4j/event/SubstituteLoggingEvent;
invoke-static {v8}, Lorg/slf4j/LoggerFactory;->replaySingleEvent(Lorg/slf4j/event/SubstituteLoggingEvent;)V
.line 211
add-int/lit8 v9, v2, 0x1
.end local v2 # "count":I
.local v9, "count":I
if-nez v2, :cond_36
.line 212
invoke-static {v8, v1}, Lorg/slf4j/LoggerFactory;->emitReplayOrSubstituionWarning(Lorg/slf4j/event/SubstituteLoggingEvent;I)V
.end local v8 # "event":Lorg/slf4j/event/SubstituteLoggingEvent;
:cond_36
move v2, v9
goto :goto_20
.line 214
.end local v7 # "i$":Ljava/util/Iterator;
.end local v9 # "count":I
.restart local v2 # "count":I
:cond_38
invoke-interface {v4}, Ljava/util/List;->clear()V
.line 215
.end local v6 # "numDrained":I
goto :goto_14
.end method
.method private static replaySingleEvent(Lorg/slf4j/event/SubstituteLoggingEvent;)V
.registers 5
.param p0, "event" # Lorg/slf4j/event/SubstituteLoggingEvent;
.line 229
if-nez p0, :cond_3
.line 230
return-void
.line 232
:cond_3
invoke-virtual {p0}, Lorg/slf4j/event/SubstituteLoggingEvent;->getLogger()Lorg/slf4j/helpers/SubstituteLogger;
move-result-object v0
.line 233
.local v0, "substLogger":Lorg/slf4j/helpers/SubstituteLogger;
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLogger;->getName()Ljava/lang/String;
move-result-object v1
.line 234
.local v1, "loggerName":Ljava/lang/String;
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLogger;->isDelegateNull()Z
move-result v2
if-nez v2, :cond_26
.line 238
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLogger;->isDelegateNOP()Z
move-result v2
if-eqz v2, :cond_18
goto :goto_25
.line 240
:cond_18
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLogger;->isDelegateEventAware()Z
move-result v2
if-eqz v2, :cond_22
.line 241
invoke-virtual {v0, p0}, Lorg/slf4j/helpers/SubstituteLogger;->log(Lorg/slf4j/event/LoggingEvent;)V
goto :goto_25
.line 243
:cond_22
invoke-static {v1}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 245
:goto_25
return-void
.line 235
:cond_26
new-instance v2, Ljava/lang/IllegalStateException;
const-string v3, "Delegate logger cannot be null at this state."
invoke-direct {v2, v3}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v2
.end method
.method private static reportActualBinding(Ljava/util/Set;)V
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Set<",
"Ljava/net/URL;",
">;)V"
}
.end annotation
.line 343
.local p0, "binderPathSet":Ljava/util/Set;, "Ljava/util/Set<Ljava/net/URL;>;"
if-eqz p0, :cond_29
invoke-static {p0}, Lorg/slf4j/LoggerFactory;->isAmbiguousStaticLoggerBinderPathSet(Ljava/util/Set;)Z
move-result v0
if-eqz v0, :cond_29
.line 344
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Actual binding is of type ["
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {}, Lorg/slf4j/impl/StaticLoggerBinder;->getSingleton()Lorg/slf4j/impl/StaticLoggerBinder;
move-result-object v1
invoke-virtual {v1}, Lorg/slf4j/impl/StaticLoggerBinder;->getLoggerFactoryClassStr()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, "]"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 346
:cond_29
return-void
.end method
.method private static reportMultipleBindingAmbiguity(Ljava/util/Set;)V
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Set<",
"Ljava/net/URL;",
">;)V"
}
.end annotation
.line 325
.local p0, "binderPathSet":Ljava/util/Set;, "Ljava/util/Set<Ljava/net/URL;>;"
invoke-static {p0}, Lorg/slf4j/LoggerFactory;->isAmbiguousStaticLoggerBinderPathSet(Ljava/util/Set;)Z
move-result v0
if-eqz v0, :cond_3a
.line 326
const-string v0, "Class path contains multiple SLF4J bindings."
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 327
invoke-interface {p0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
.local v0, "i$":Ljava/util/Iterator;
:goto_f
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_35
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/net/URL;
.line 328
.local v1, "path":Ljava/net/URL;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Found binding in ["
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v3, "]"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v2}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.end local v1 # "path":Ljava/net/URL;
goto :goto_f
.line 330
.end local v0 # "i$":Ljava/util/Iterator;
:cond_35
const-string v0, "See http://www.slf4j.org/codes.html#multiple_bindings for an explanation."
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 332
:cond_3a
return-void
.end method
.method static reset()V
.registers 1
.line 120
const/4 v0, 0x0
sput v0, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
.line 121
return-void
.end method
.method private static final versionSanityCheck()V
.registers 7
.line 263
:try_start_0
sget-object v0, Lorg/slf4j/impl/StaticLoggerBinder;->REQUESTED_API_VERSION:Ljava/lang/String;
.line 265
.local v0, "requested":Ljava/lang/String;
const/4 v1, 0x0
.line 266
.local v1, "match":Z
sget-object v2, Lorg/slf4j/LoggerFactory;->API_COMPATIBILITY_LIST:[Ljava/lang/String;
.local v2, "arr$":[Ljava/lang/String;
array-length v3, v2
.local v3, "len$":I
const/4 v4, 0x0
.local v4, "i$":I
:goto_7
if-ge v4, v3, :cond_15
aget-object v5, v2, v4
.line 267
.local v5, "aAPI_COMPATIBILITY_LIST":Ljava/lang/String;
invoke-virtual {v0, v5}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v6
if-eqz v6, :cond_12
.line 268
const/4 v1, 0x1
.line 266
.end local v5 # "aAPI_COMPATIBILITY_LIST":Ljava/lang/String;
:cond_12
add-int/lit8 v4, v4, 0x1
goto :goto_7
.line 271
.end local v2 # "arr$":[Ljava/lang/String;
.end local v3 # "len$":I
.end local v4 # "i$":I
:cond_15
if-nez v1, :cond_4b
.line 272
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "The requested version "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, " by your slf4j binding is not compatible with "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v3, Lorg/slf4j/LoggerFactory;->API_COMPATIBILITY_LIST:[Ljava/lang/String;
invoke-static {v3}, Ljava/util/Arrays;->asList([Ljava/lang/Object;)Ljava/util/List;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v2}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 274
const-string v2, "See http://www.slf4j.org/codes.html#version_mismatch for further details."
invoke-static {v2}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
:try_end_42
.catch Ljava/lang/NoSuchFieldError; {:try_start_0 .. :try_end_42} :catch_4a
.catchall {:try_start_0 .. :try_end_42} :catchall_43
goto :goto_4b
.line 281
.end local v0 # "requested":Ljava/lang/String;
.end local v1 # "match":Z
:catchall_43
move-exception v0
.line 283
.local v0, "e":Ljava/lang/Throwable;
const-string v1, "Unexpected problem occured during version sanity check"
invoke-static {v1, v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_4c
.line 276
.end local v0 # "e":Ljava/lang/Throwable;
:catch_4a
move-exception v0
.line 284
:cond_4b
:goto_4b
nop
.line 285
:goto_4c
return-void
.end method