tmap/smali/com/amazonaws/logging/LogFactory.smali
2022-06-10 21:38:30 +09:00

225 lines
5.2 KiB
Smali

.class public Lcom/amazonaws/logging/LogFactory;
.super Ljava/lang/Object;
.source "LogFactory.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/amazonaws/logging/LogFactory$Level;
}
.end annotation
# static fields
.field private static final TAG:Ljava/lang/String; = "LogFactory"
.field private static globalLogLevel:Lcom/amazonaws/logging/LogFactory$Level;
.field private static final logMap:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Lcom/amazonaws/logging/Log;",
">;"
}
.end annotation
.end field
# direct methods
.method public static constructor <clinit>()V
.locals 1
.line 1
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
sput-object v0, Lcom/amazonaws/logging/LogFactory;->logMap:Ljava/util/Map;
const/4 v0, 0x0
.line 2
sput-object v0, Lcom/amazonaws/logging/LogFactory;->globalLogLevel:Lcom/amazonaws/logging/LogFactory$Level;
return-void
.end method
.method public constructor <init>()V
.locals 0
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static getLevel()Lcom/amazonaws/logging/LogFactory$Level;
.locals 1
.line 1
sget-object v0, Lcom/amazonaws/logging/LogFactory;->globalLogLevel:Lcom/amazonaws/logging/LogFactory$Level;
return-object v0
.end method
.method public static declared-synchronized getLog(Ljava/lang/Class;)Lcom/amazonaws/logging/Log;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/Class<",
"*>;)",
"Lcom/amazonaws/logging/Log;"
}
.end annotation
const-class v0, Lcom/amazonaws/logging/LogFactory;
monitor-enter v0
.line 1
:try_start_0
invoke-virtual {p0}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String;
move-result-object p0
invoke-static {p0}, Lcom/amazonaws/logging/LogFactory;->getTruncatedLogTag(Ljava/lang/String;)Ljava/lang/String;
move-result-object p0
invoke-static {p0}, Lcom/amazonaws/logging/LogFactory;->getLog(Ljava/lang/String;)Lcom/amazonaws/logging/Log;
move-result-object p0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
monitor-exit v0
return-object p0
:catchall_0
move-exception p0
monitor-exit v0
throw p0
.end method
.method public static declared-synchronized getLog(Ljava/lang/String;)Lcom/amazonaws/logging/Log;
.locals 3
const-class v0, Lcom/amazonaws/logging/LogFactory;
monitor-enter v0
.line 2
:try_start_0
invoke-static {p0}, Lcom/amazonaws/logging/LogFactory;->getTruncatedLogTag(Ljava/lang/String;)Ljava/lang/String;
move-result-object p0
.line 3
sget-object v1, Lcom/amazonaws/logging/LogFactory;->logMap:Ljava/util/Map;
invoke-interface {v1, p0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/amazonaws/logging/Log;
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
if-eqz v2, :cond_0
.line 4
monitor-exit v0
return-object v2
.line 5
:cond_0
:try_start_1
invoke-static {}, Lcom/amazonaws/logging/Environment;->isJUnitTest()Z
move-result v2
if-eqz v2, :cond_1
.line 6
new-instance v2, Lcom/amazonaws/logging/ConsoleLog;
invoke-direct {v2, p0}, Lcom/amazonaws/logging/ConsoleLog;-><init>(Ljava/lang/String;)V
goto :goto_0
.line 7
:cond_1
new-instance v2, Lcom/amazonaws/logging/AndroidLog;
invoke-direct {v2, p0}, Lcom/amazonaws/logging/AndroidLog;-><init>(Ljava/lang/String;)V
.line 8
:goto_0
invoke-interface {v1, p0, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
.line 9
monitor-exit v0
return-object v2
:catchall_0
move-exception p0
monitor-exit v0
throw p0
.end method
.method private static getTruncatedLogTag(Ljava/lang/String;)Ljava/lang/String;
.locals 3
.line 1
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v0
const/16 v1, 0x17
if-le v0, v1, :cond_0
.line 2
sget-object v0, Lcom/amazonaws/logging/LogFactory;->TAG:Ljava/lang/String;
invoke-static {v0}, Lcom/amazonaws/logging/LogFactory;->getLog(Ljava/lang/String;)Lcom/amazonaws/logging/Log;
move-result-object v0
const-string v2, "Truncating log tag length as it exceed 23, the limit imposed by Android on certain API Levels"
invoke-interface {v0, v2}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;)V
const/4 v0, 0x0
.line 3
invoke-virtual {p0, v0, v1}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object p0
:cond_0
return-object p0
.end method
.method public static setLevel(Lcom/amazonaws/logging/LogFactory$Level;)V
.locals 0
.line 1
sput-object p0, Lcom/amazonaws/logging/LogFactory;->globalLogLevel:Lcom/amazonaws/logging/LogFactory$Level;
return-void
.end method