LogFactory.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 APACHE_COMMONS_LOGGING_LOGFACTORY:Ljava/lang/String; = "org.apache.commons.logging.LogFactory"
.field private static final TAG:Ljava/lang/String; = "LogFactory"
.field private static globalLogLevel:Lcom/amazonaws/logging/LogFactory$Level;
.field private static 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 static constructor <clinit>()V
.registers 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;
return-void
.end method
.method public constructor <init>()V
.registers 1
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method private static checkApacheCommonsLoggingExists()Z
.registers 3
const-string v0, "org.apache.commons.logging.LogFactory"
const/4 v1, 0x0
.line 1
:try_start_3
invoke-static {v0}, Ljava/lang/Class;->forName(Ljava/lang/String;)Ljava/lang/Class;
:try_end_6
.catch Ljava/lang/ClassNotFoundException; {:try_start_3 .. :try_end_6} :catch_12
.catch Ljava/lang/Exception; {:try_start_3 .. :try_end_6} :catch_8
const/4 v0, 0x1
return v0
:catch_8
move-exception v0
.line 2
sget-object v2, Lcom/amazonaws/logging/LogFactory;->TAG:Ljava/lang/String;
invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-static {v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
:catch_12
return v1
.end method
.method public static getLevel()Lcom/amazonaws/logging/LogFactory$Level;
.registers 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;
.registers 2
const-class v0, Lcom/amazonaws/logging/LogFactory;
monitor-enter v0
.line 1
:try_start_3
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_f
.catchall {:try_start_3 .. :try_end_f} :catchall_11
monitor-exit v0
return-object p0
:catchall_11
move-exception p0
monitor-exit v0
throw p0
.end method
.method public static declared-synchronized getLog(Ljava/lang/String;)Lcom/amazonaws/logging/Log;
.registers 7
const-class v0, Lcom/amazonaws/logging/LogFactory;
monitor-enter v0
.line 2
:try_start_3
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 v1
check-cast v1, Lcom/amazonaws/logging/Log;
if-nez v1, :cond_3d
.line 4
invoke-static {}, Lcom/amazonaws/logging/LogFactory;->checkApacheCommonsLoggingExists()Z
move-result v2
:try_end_15
.catchall {:try_start_3 .. :try_end_15} :catchall_3f
if-eqz v2, :cond_31
.line 5
:try_start_17
new-instance v2, Lcom/amazonaws/logging/ApacheCommonsLogging;
invoke-direct {v2, p0}, Lcom/amazonaws/logging/ApacheCommonsLogging;-><init>(Ljava/lang/String;)V
:try_end_1c
.catch Ljava/lang/Exception; {:try_start_17 .. :try_end_1c} :catch_25
.catchall {:try_start_17 .. :try_end_1c} :catchall_3f
.line 6
:try_start_1c
sget-object v1, Lcom/amazonaws/logging/LogFactory;->logMap:Ljava/util/Map;
invoke-interface {v1, p0, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:try_end_21
.catch Ljava/lang/Exception; {:try_start_1c .. :try_end_21} :catch_23
.catchall {:try_start_1c .. :try_end_21} :catchall_3f
:goto_21
move-object v1, v2
goto :goto_31
:catch_23
move-exception v1
goto :goto_29
:catch_25
move-exception v2
move-object v5, v2
move-object v2, v1
move-object v1, v5
.line 7
:goto_29
:try_start_29
sget-object v3, Lcom/amazonaws/logging/LogFactory;->TAG:Ljava/lang/String;
const-string v4, "Could not create log from org.apache.commons.logging.LogFactory"
invoke-static {v3, v4, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_21
:cond_31
:goto_31
if-nez v1, :cond_3d
.line 8
new-instance v1, Lcom/amazonaws/logging/AndroidLog;
invoke-direct {v1, p0}, Lcom/amazonaws/logging/AndroidLog;-><init>(Ljava/lang/String;)V
.line 9
sget-object v2, Lcom/amazonaws/logging/LogFactory;->logMap:Ljava/util/Map;
invoke-interface {v2, p0, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:try_end_3d
.catchall {:try_start_29 .. :try_end_3d} :catchall_3f
.line 10
:cond_3d
monitor-exit v0
return-object v1
:catchall_3f
move-exception p0
monitor-exit v0
goto :goto_43
:goto_42
throw p0
:goto_43
goto :goto_42
.end method
.method private static getTruncatedLogTag(Ljava/lang/String;)Ljava/lang/String;
.registers 5
.line 1
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v0
const/16 v1, 0x17
if-le v0, v1, :cond_25
.line 2
invoke-static {}, Lcom/amazonaws/logging/LogFactory;->checkApacheCommonsLoggingExists()Z
move-result v0
const-string v2, "Truncating log tag length as it exceed 23, the limit imposed by Android on certain API Levels"
if-eqz v0, :cond_1b
.line 3
new-instance v0, Lcom/amazonaws/logging/ApacheCommonsLogging;
sget-object v3, Lcom/amazonaws/logging/LogFactory;->TAG:Ljava/lang/String;
invoke-direct {v0, v3}, Lcom/amazonaws/logging/ApacheCommonsLogging;-><init>(Ljava/lang/String;)V
.line 4
invoke-interface {v0, v2}, Lcom/amazonaws/logging/Log;->warn(Ljava/lang/Object;)V
goto :goto_20
.line 5
:cond_1b
sget-object v0, Lcom/amazonaws/logging/LogFactory;->TAG:Ljava/lang/String;
invoke-static {v0, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:goto_20
const/4 v0, 0x0
.line 6
invoke-virtual {p0, v0, v1}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object p0
:cond_25
return-object p0
.end method
.method public static setLevel(Lcom/amazonaws/logging/LogFactory$Level;)V
.registers 1
.line 1
sput-object p0, Lcom/amazonaws/logging/LogFactory;->globalLogLevel:Lcom/amazonaws/logging/LogFactory$Level;
return-void
.end method