Util.smali
.class public final Lorg/slf4j/helpers/Util;
.super Ljava/lang/Object;
.source "Util.java"
# static fields
.field private static SECURITY_MANAGER:Lorg/slf4j/helpers/Util$ClassContextSecurityManager;
.field private static SECURITY_MANAGER_CREATION_ALREADY_ATTEMPTED:Z
# direct methods
.method static constructor <clinit>()V
.registers 1
.prologue
.line 72
const/4 v0, 0x0
sput-boolean v0, Lorg/slf4j/helpers/Util;->SECURITY_MANAGER_CREATION_ALREADY_ATTEMPTED:Z
return-void
.end method
.method private constructor <init>()V
.registers 1
.prologue
.line 36
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 37
return-void
.end method
.method public static getCallingClass()Ljava/lang/Class;
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/lang/Class",
"<*>;"
}
.end annotation
.prologue
.line 100
invoke-static {}, Lorg/slf4j/helpers/Util;->getSecurityManager()Lorg/slf4j/helpers/Util$ClassContextSecurityManager;
move-result-object v0
.line 101
if-nez v0, :cond_8
.line 102
const/4 v0, 0x0
.line 118
:goto_7
return-object v0
.line 103
:cond_8
invoke-virtual {v0}, Lorg/slf4j/helpers/Util$ClassContextSecurityManager;->getClassContext()[Ljava/lang/Class;
move-result-object v1
.line 104
const-class v0, Lorg/slf4j/helpers/Util;
invoke-virtual {v0}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v2
.line 108
const/4 v0, 0x0
:goto_13
array-length v3, v1
if-ge v0, v3, :cond_25
.line 109
aget-object v3, v1, v0
invoke-virtual {v3}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v3
if-nez v3, :cond_25
.line 108
add-int/lit8 v0, v0, 0x1
goto :goto_13
.line 114
:cond_25
array-length v2, v1
if-ge v0, v2, :cond_2d
add-int/lit8 v2, v0, 0x2
array-length v3, v1
if-lt v2, v3, :cond_35
.line 115
:cond_2d
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Failed to find org.slf4j.helpers.Util or its caller in the stack; this should not happen"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 118
:cond_35
add-int/lit8 v0, v0, 0x2
aget-object v0, v1, v0
goto :goto_7
.end method
.method private static getSecurityManager()Lorg/slf4j/helpers/Util$ClassContextSecurityManager;
.registers 1
.prologue
.line 75
sget-object v0, Lorg/slf4j/helpers/Util;->SECURITY_MANAGER:Lorg/slf4j/helpers/Util$ClassContextSecurityManager;
if-eqz v0, :cond_7
.line 76
sget-object v0, Lorg/slf4j/helpers/Util;->SECURITY_MANAGER:Lorg/slf4j/helpers/Util$ClassContextSecurityManager;
.line 82
:goto_6
return-object v0
.line 77
:cond_7
sget-boolean v0, Lorg/slf4j/helpers/Util;->SECURITY_MANAGER_CREATION_ALREADY_ATTEMPTED:Z
if-eqz v0, :cond_d
.line 78
const/4 v0, 0x0
goto :goto_6
.line 80
:cond_d
invoke-static {}, Lorg/slf4j/helpers/Util;->safeCreateSecurityManager()Lorg/slf4j/helpers/Util$ClassContextSecurityManager;
move-result-object v0
sput-object v0, Lorg/slf4j/helpers/Util;->SECURITY_MANAGER:Lorg/slf4j/helpers/Util$ClassContextSecurityManager;
.line 81
const/4 v0, 0x1
sput-boolean v0, Lorg/slf4j/helpers/Util;->SECURITY_MANAGER_CREATION_ALREADY_ATTEMPTED:Z
.line 82
sget-object v0, Lorg/slf4j/helpers/Util;->SECURITY_MANAGER:Lorg/slf4j/helpers/Util$ClassContextSecurityManager;
goto :goto_6
.end method
.method public static final report(Ljava/lang/String;)V
.registers 4
.prologue
.line 128
sget-object v0, Ljava/lang/System;->err:Ljava/io/PrintStream;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "SLF4J: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 129
return-void
.end method
.method public static final report(Ljava/lang/String;Ljava/lang/Throwable;)V
.registers 4
.prologue
.line 122
sget-object v0, Ljava/lang/System;->err:Ljava/io/PrintStream;
invoke-virtual {v0, p0}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 123
sget-object v0, Ljava/lang/System;->err:Ljava/io/PrintStream;
const-string v1, "Reported exception:"
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 124
invoke-virtual {p1}, Ljava/lang/Throwable;->printStackTrace()V
.line 125
return-void
.end method
.method private static safeCreateSecurityManager()Lorg/slf4j/helpers/Util$ClassContextSecurityManager;
.registers 3
.prologue
const/4 v1, 0x0
.line 88
:try_start_1
new-instance v0, Lorg/slf4j/helpers/Util$ClassContextSecurityManager;
const/4 v2, 0x0
invoke-direct {v0, v2}, Lorg/slf4j/helpers/Util$ClassContextSecurityManager;-><init>(Lorg/slf4j/helpers/Util$1;)V
:try_end_7
.catch Ljava/lang/SecurityException; {:try_start_1 .. :try_end_7} :catch_8
.line 90
:goto_7
return-object v0
:catch_8
move-exception v0
move-object v0, v1
goto :goto_7
.end method
.method public static safeGetBooleanSystemProperty(Ljava/lang/String;)Z
.registers 3
.prologue
.line 53
invoke-static {p0}, Lorg/slf4j/helpers/Util;->safeGetSystemProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 54
if-nez v0, :cond_8
.line 55
const/4 v0, 0x0
.line 57
:goto_7
return v0
:cond_8
const-string v1, "true"
invoke-virtual {v0, v1}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z
move-result v0
goto :goto_7
.end method
.method public static safeGetSystemProperty(Ljava/lang/String;)Ljava/lang/String;
.registers 3
.prologue
.line 40
if-nez p0, :cond_a
.line 41
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "null input"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 43
:cond_a
const/4 v0, 0x0
.line 45
:try_start_b
invoke-static {p0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
:try_end_e
.catch Ljava/lang/SecurityException; {:try_start_b .. :try_end_e} :catch_10
move-result-object v0
.line 49
:goto_f
return-object v0
:catch_10
move-exception v1
goto :goto_f
.end method