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 final NOP_FALLBACK_FACTORY:Lorg/slf4j/helpers/NOPLoggerFactory;
.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 final SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
.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 in failed state. Original exception was thrown EARLIER. 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 3
.prologue
const/4 v2, 0x0
.line 85
sput v2, 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/4 v0, 0x2
new-array v0, v0, [Ljava/lang/String;
const-string v1, "1.6"
aput-object v1, v0, v2
const/4 v1, 0x1
const-string v2, "1.7"
aput-object v2, v0, v1
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
.prologue
.line 105
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 106
return-void
.end method
.method private static final bind()V
.registers 3
.prologue
.line 142
const/4 v0, 0x0
.line 145
:try_start_1
invoke-static {}, Lorg/slf4j/LoggerFactory;->isAndroid()Z
move-result v1
if-nez v1, :cond_e
.line 146
invoke-static {}, Lorg/slf4j/LoggerFactory;->findPossibleStaticLoggerBinderPathSet()Ljava/util/Set;
move-result-object v0
.line 147
invoke-static {v0}, Lorg/slf4j/LoggerFactory;->reportMultipleBindingAmbiguity(Ljava/util/Set;)V
.line 150
:cond_e
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 v0, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLoggerFactory;->clear()V
:try_end_22
.catch Ljava/lang/NoClassDefFoundError; {:try_start_1 .. :try_end_22} :catch_23
.catch Ljava/lang/NoSuchMethodError; {:try_start_1 .. :try_end_22} :catch_45
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_22} :catch_67
.line 180
:goto_22
return-void
.line 157
:catch_23
move-exception v0
.line 158
invoke-virtual {v0}, Ljava/lang/NoClassDefFoundError;->getMessage()Ljava/lang/String;
move-result-object v1
.line 159
invoke-static {v1}, Lorg/slf4j/LoggerFactory;->messageContainsOrgSlf4jImplStaticLoggerBinder(Ljava/lang/String;)Z
move-result v1
if-eqz v1, :cond_41
.line 160
const/4 v0, 0x4
sput v0, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
.line 161
const-string v0, "Failed to load class \"org.slf4j.impl.StaticLoggerBinder\"."
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 162
const-string v0, "Defaulting to no-operation (NOP) logger implementation"
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 163
const-string v0, "See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details."
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
goto :goto_22
.line 165
:cond_41
invoke-static {v0}, Lorg/slf4j/LoggerFactory;->failedBinding(Ljava/lang/Throwable;)V
.line 166
throw v0
.line 168
:catch_45
move-exception v0
.line 169
invoke-virtual {v0}, Ljava/lang/NoSuchMethodError;->getMessage()Ljava/lang/String;
move-result-object v1
.line 170
if-eqz v1, :cond_66
const-string v2, "org.slf4j.impl.StaticLoggerBinder.getSingleton()"
invoke-virtual {v1, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v1
if-eqz v1, :cond_66
.line 171
const/4 v1, 0x2
sput v1, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
.line 172
const-string v1, "slf4j-api 1.6.x (or later) is incompatible with this binding."
invoke-static {v1}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 173
const-string v1, "Your binding is version 1.5.5 or earlier."
invoke-static {v1}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 174
const-string v1, "Upgrade your binding to version 1.6.x."
invoke-static {v1}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 176
:cond_66
throw v0
.line 177
:catch_67
move-exception v0
.line 178
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
.end method
.method private static emitReplayOrSubstituionWarning(Lorg/slf4j/event/SubstituteLoggingEvent;I)V
.registers 3
.prologue
.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
.line 226
:cond_d
:goto_d
return-void
.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-nez v0, :cond_d
.line 224
invoke-static {}, Lorg/slf4j/LoggerFactory;->emitSubstitutionWarning()V
goto :goto_d
.end method
.method private static emitReplayWarning(I)V
.registers 3
.prologue
.line 256
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "A number ("
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
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;
move-result-object v0
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
.prologue
.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
.prologue
.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 3
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Set",
"<",
"Ljava/net/URL;",
">;"
}
.end annotation
.prologue
.line 296
new-instance v2, Ljava/util/LinkedHashSet;
invoke-direct {v2}, Ljava/util/LinkedHashSet;-><init>()V
.line 298
:try_start_5
const-class v0, Lorg/slf4j/LoggerFactory;
invoke-virtual {v0}, Ljava/lang/Class;->getClassLoader()Ljava/lang/ClassLoader;
move-result-object v0
.line 300
if-nez v0, :cond_2b
.line 301
sget-object v0, Lorg/slf4j/LoggerFactory;->STATIC_LOGGER_BINDER_PATH:Ljava/lang/String;
invoke-static {v0}, Ljava/lang/ClassLoader;->getSystemResources(Ljava/lang/String;)Ljava/util/Enumeration;
move-result-object v0
move-object v1, v0
.line 305
:goto_14
invoke-interface {v1}, Ljava/util/Enumeration;->hasMoreElements()Z
move-result v0
if-eqz v0, :cond_2a
.line 306
invoke-interface {v1}, Ljava/util/Enumeration;->nextElement()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/net/URL;
.line 307
invoke-interface {v2, v0}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
:try_end_23
.catch Ljava/io/IOException; {:try_start_5 .. :try_end_23} :catch_24
goto :goto_14
.line 309
:catch_24
move-exception v0
.line 310
const-string v1, "Error getting resources from path"
invoke-static {v1, v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 312
:cond_2a
return-object v2
.line 303
:cond_2b
:try_start_2b
sget-object v1, Lorg/slf4j/LoggerFactory;->STATIC_LOGGER_BINDER_PATH:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/ClassLoader;->getResources(Ljava/lang/String;)Ljava/util/Enumeration;
:try_end_30
.catch Ljava/io/IOException; {:try_start_2b .. :try_end_30} :catch_24
move-result-object v0
move-object v1, v0
goto :goto_14
.end method
.method private static fixSubstituteLoggers()V
.registers 4
.prologue
.line 184
sget-object v1, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
monitor-enter v1
.line 185
:try_start_3
sget-object v0, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLoggerFactory;->postInitialization()V
.line 186
sget-object v0, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLoggerFactory;->getLoggers()Ljava/util/List;
move-result-object v0
invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
:goto_12
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_2d
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/slf4j/helpers/SubstituteLogger;
.line 187
invoke-virtual {v0}, 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
invoke-virtual {v0, v3}, Lorg/slf4j/helpers/SubstituteLogger;->setDelegate(Lorg/slf4j/Logger;)V
goto :goto_12
.line 190
:catchall_2a
move-exception v0
monitor-exit v1
:try_end_2c
.catchall {:try_start_3 .. :try_end_2c} :catchall_2a
throw v0
:cond_2d
:try_start_2d
monitor-exit v1
:try_end_2e
.catchall {:try_start_2d .. :try_end_2e} :catchall_2a
return-void
.end method
.method public static getILoggerFactory()Lorg/slf4j/ILoggerFactory;
.registers 2
.prologue
.line 408
sget v0, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
if-nez v0, :cond_12
.line 409
const-class v1, Lorg/slf4j/LoggerFactory;
monitor-enter v1
.line 410
:try_start_7
sget v0, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
if-nez v0, :cond_11
.line 411
const/4 v0, 0x1
sput v0, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
.line 412
invoke-static {}, Lorg/slf4j/LoggerFactory;->performInitialization()V
.line 414
:cond_11
monitor-exit v1
:try_end_12
.catchall {:try_start_7 .. :try_end_12} :catchall_1f
.line 416
:cond_12
sget v0, Lorg/slf4j/LoggerFactory;->INITIALIZATION_STATE:I
packed-switch v0, :pswitch_data_3a
.line 428
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 414
:catchall_1f
move-exception v0
:try_start_20
monitor-exit v1
:try_end_21
.catchall {:try_start_20 .. :try_end_21} :catchall_1f
throw v0
.line 418
:pswitch_22
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
.line 426
:goto_2a
return-object v0
.line 420
:pswitch_2b
sget-object v0, Lorg/slf4j/LoggerFactory;->NOP_FALLBACK_FACTORY:Lorg/slf4j/helpers/NOPLoggerFactory;
goto :goto_2a
.line 422
:pswitch_2e
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "org.slf4j.LoggerFactory in failed state. Original exception was thrown EARLIER. 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
:pswitch_36
sget-object v0, Lorg/slf4j/LoggerFactory;->SUBST_FACTORY:Lorg/slf4j/helpers/SubstituteLoggerFactory;
goto :goto_2a
.line 416
nop
:pswitch_data_3a
.packed-switch 0x1
:pswitch_36
:pswitch_2e
:pswitch_22
:pswitch_2b
.end packed-switch
.end method
.method public static getLogger(Ljava/lang/Class;)Lorg/slf4j/Logger;
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/Class",
"<*>;)",
"Lorg/slf4j/Logger;"
}
.end annotation
.prologue
.line 383
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
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
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-string v2, "Detected logger name mismatch. Given name: \"%s\"; computed name: \"%s\"."
const/4 v3, 0x2
new-array v3, v3, [Ljava/lang/Object;
const/4 v4, 0x0
invoke-interface {v0}, Lorg/slf4j/Logger;->getName()Ljava/lang/String;
move-result-object v5
aput-object v5, v3, v4
const/4 v4, 0x1
invoke-virtual {v1}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v1
aput-object v1, v3, v4
invoke-static {v2, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-static {v1}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 389
const-string v1, "See http://www.slf4j.org/codes.html#loggerNameMismatch for an explanation"
invoke-static {v1}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
.line 392
:cond_37
return-object v0
.end method
.method public static getLogger(Ljava/lang/String;)Lorg/slf4j/Logger;
.registers 2
.prologue
.line 357
invoke-static {}, Lorg/slf4j/LoggerFactory;->getILoggerFactory()Lorg/slf4j/ILoggerFactory;
move-result-object v0
.line 358
invoke-interface {v0, p0}, Lorg/slf4j/ILoggerFactory;->getLogger(Ljava/lang/String;)Lorg/slf4j/Logger;
move-result-object v0
return-object v0
.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
.prologue
const/4 v0, 0x1
.line 316
invoke-interface {p0}, Ljava/util/Set;->size()I
move-result v1
if-le v1, v0, :cond_8
:goto_7
return v0
:cond_8
const/4 v0, 0x0
goto :goto_7
.end method
.method private static isAndroid()Z
.registers 2
.prologue
.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
if-nez v0, :cond_a
.line 337
const/4 v0, 0x0
.line 338
:goto_9
return v0
:cond_a
invoke-virtual {v0}, Ljava/lang/String;->toLowerCase()Ljava/lang/String;
move-result-object v0
const-string v1, "android"
invoke-virtual {v0, v1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v0
goto :goto_9
.end method
.method private static messageContainsOrgSlf4jImplStaticLoggerBinder(Ljava/lang/String;)Z
.registers 4
.prologue
const/4 v1, 0x1
const/4 v0, 0x0
.line 131
if-nez p0, :cond_5
.line 137
:cond_4
:goto_4
return v0
.line 133
:cond_5
const-string v2, "org/slf4j/impl/StaticLoggerBinder"
invoke-virtual {p0, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_f
move v0, v1
.line 134
goto :goto_4
.line 135
:cond_f
const-string v2, "org.slf4j.impl.StaticLoggerBinder"
invoke-virtual {p0, v2}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_4
move v0, v1
.line 136
goto :goto_4
.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
.prologue
.line 396
invoke-virtual {p1, p0}, Ljava/lang/Class;->isAssignableFrom(Ljava/lang/Class;)Z
move-result v0
if-nez v0, :cond_8
const/4 v0, 0x1
:goto_7
return v0
:cond_8
const/4 v0, 0x0
goto :goto_7
.end method
.method private static final performInitialization()V
.registers 2
.prologue
.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 8
.prologue
const/16 v7, 0x80
.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 v3
.line 201
invoke-virtual {v3}, Ljava/util/concurrent/LinkedBlockingQueue;->size()I
move-result v4
.line 202
const/4 v0, 0x0
.line 204
new-instance v5, Ljava/util/ArrayList;
invoke-direct {v5, v7}, Ljava/util/ArrayList;-><init>(I)V
.line 206
:goto_12
invoke-virtual {v3, v5, v7}, Ljava/util/concurrent/LinkedBlockingQueue;->drainTo(Ljava/util/Collection;I)I
move-result v1
.line 207
if-eqz v1, :cond_3a
.line 209
invoke-interface {v5}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v6
move v1, v0
:goto_1d
invoke-interface {v6}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_35
invoke-interface {v6}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/slf4j/event/SubstituteLoggingEvent;
.line 210
invoke-static {v0}, Lorg/slf4j/LoggerFactory;->replaySingleEvent(Lorg/slf4j/event/SubstituteLoggingEvent;)V
.line 211
add-int/lit8 v2, v1, 0x1
if-nez v1, :cond_33
.line 212
invoke-static {v0, v4}, Lorg/slf4j/LoggerFactory;->emitReplayOrSubstituionWarning(Lorg/slf4j/event/SubstituteLoggingEvent;I)V
:cond_33
move v1, v2
.line 213
goto :goto_1d
.line 214
:cond_35
invoke-interface {v5}, Ljava/util/List;->clear()V
move v0, v1
.line 215
goto :goto_12
.line 216
:cond_3a
return-void
.end method
.method private static replaySingleEvent(Lorg/slf4j/event/SubstituteLoggingEvent;)V
.registers 4
.prologue
.line 229
if-nez p0, :cond_3
.line 245
:cond_2
:goto_2
return-void
.line 232
:cond_3
invoke-virtual {p0}, Lorg/slf4j/event/SubstituteLoggingEvent;->getLogger()Lorg/slf4j/helpers/SubstituteLogger;
move-result-object v0
.line 233
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLogger;->getName()Ljava/lang/String;
move-result-object v1
.line 234
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLogger;->isDelegateNull()Z
move-result v2
if-eqz v2, :cond_19
.line 235
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Delegate logger cannot be null at this state."
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 238
:cond_19
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLogger;->isDelegateNOP()Z
move-result v2
if-nez v2, :cond_2
.line 240
invoke-virtual {v0}, Lorg/slf4j/helpers/SubstituteLogger;->isDelegateEventAware()Z
move-result v2
if-eqz v2, :cond_29
.line 241
invoke-virtual {v0, p0}, Lorg/slf4j/helpers/SubstituteLogger;->log(Lorg/slf4j/event/LoggingEvent;)V
goto :goto_2
.line 243
:cond_29
invoke-static {v1}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
goto :goto_2
.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
.prologue
.line 343
if-eqz p0, :cond_28
invoke-static {p0}, Lorg/slf4j/LoggerFactory;->isAmbiguousStaticLoggerBinderPathSet(Ljava/util/Set;)Z
move-result v0
if-eqz v0, :cond_28
.line 344
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "Actual binding is of type ["
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
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;
move-result-object v0
const-string v1, "]"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
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_28
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
.prologue
.line 325
invoke-static {p0}, Lorg/slf4j/LoggerFactory;->isAmbiguousStaticLoggerBinderPathSet(Ljava/util/Set;)Z
move-result v0
if-eqz v0, :cond_39
.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 v1
:goto_f
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_34
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/net/URL;
.line 328
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Found binding in ["
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v2, "]"
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
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
goto :goto_f
.line 330
:cond_34
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_39
return-void
.end method
.method static reset()V
.registers 1
.prologue
.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 6
.prologue
const/4 v0, 0x0
.line 263
:try_start_1
sget-object v2, Lorg/slf4j/impl/StaticLoggerBinder;->REQUESTED_API_VERSION:Ljava/lang/String;
.line 266
sget-object v3, Lorg/slf4j/LoggerFactory;->API_COMPATIBILITY_LIST:[Ljava/lang/String;
array-length v4, v3
move v1, v0
:goto_7
if-ge v1, v4, :cond_15
aget-object v5, v3, v1
.line 267
invoke-virtual {v2, v5}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v5
if-eqz v5, :cond_12
.line 268
const/4 v0, 0x1
.line 266
:cond_12
add-int/lit8 v1, v1, 0x1
goto :goto_7
.line 271
:cond_15
if-nez v0, :cond_42
.line 272
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "The requested version "
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, " by your slf4j binding is not compatible with "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
sget-object v1, Lorg/slf4j/LoggerFactory;->API_COMPATIBILITY_LIST:[Ljava/lang/String;
invoke-static {v1}, Ljava/util/Arrays;->asList([Ljava/lang/Object;)Ljava/util/List;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
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 274
const-string v0, "See http://www.slf4j.org/codes.html#version_mismatch for further details."
invoke-static {v0}, Lorg/slf4j/helpers/Util;->report(Ljava/lang/String;)V
:try_end_42
.catch Ljava/lang/NoSuchFieldError; {:try_start_1 .. :try_end_42} :catch_4a
.catch Ljava/lang/Throwable; {:try_start_1 .. :try_end_42} :catch_43
.line 285
:cond_42
:goto_42
return-void
.line 281
:catch_43
move-exception v0
.line 283
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_42
.line 284
:catch_4a
move-exception v0
goto :goto_42
.end method