225 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Smali
		
	
	
	
	
	
			
		
		
	
	
			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
 |