.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 ()V .locals 1 .line 1 new-instance v0, Ljava/util/HashMap; invoke-direct {v0}, Ljava/util/HashMap;->()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 ()V .locals 0 .line 1 invoke-direct {p0}, Ljava/lang/Object;->()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;->(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;->(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