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