379 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			Smali
		
	
	
	
	
	
			
		
		
	
	
			379 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			Smali
		
	
	
	
	
	
| .class public Lorg/apache/commons/logging/LogSource;
 | |
| .super Ljava/lang/Object;
 | |
| .source "LogSource.java"
 | |
| 
 | |
| 
 | |
| # static fields
 | |
| .field public static jdk14IsAvailable:Z
 | |
| 
 | |
| .field public static log4jIsAvailable:Z
 | |
| 
 | |
| .field public static logImplctor:Ljava/lang/reflect/Constructor;
 | |
| 
 | |
| .field public static logs:Ljava/util/Hashtable;
 | |
| 
 | |
| 
 | |
| # direct methods
 | |
| .method public static constructor <clinit>()V
 | |
|     .locals 4
 | |
| 
 | |
|     .line 1
 | |
|     new-instance v0, Ljava/util/Hashtable;
 | |
| 
 | |
|     invoke-direct {v0}, Ljava/util/Hashtable;-><init>()V
 | |
| 
 | |
|     sput-object v0, Lorg/apache/commons/logging/LogSource;->logs:Ljava/util/Hashtable;
 | |
| 
 | |
|     const/4 v0, 0x0
 | |
| 
 | |
|     .line 2
 | |
|     sput-boolean v0, Lorg/apache/commons/logging/LogSource;->log4jIsAvailable:Z
 | |
| 
 | |
|     .line 3
 | |
|     sput-boolean v0, Lorg/apache/commons/logging/LogSource;->jdk14IsAvailable:Z
 | |
| 
 | |
|     const/4 v1, 0x0
 | |
| 
 | |
|     .line 4
 | |
|     sput-object v1, Lorg/apache/commons/logging/LogSource;->logImplctor:Ljava/lang/reflect/Constructor;
 | |
| 
 | |
|     const/4 v2, 0x1
 | |
| 
 | |
|     :try_start_0
 | |
|     const-string v3, "org.apache.log4j.Logger"
 | |
| 
 | |
|     .line 5
 | |
|     invoke-static {v3}, Ljava/lang/Class;->forName(Ljava/lang/String;)Ljava/lang/Class;
 | |
| 
 | |
|     .line 6
 | |
|     sput-boolean v2, Lorg/apache/commons/logging/LogSource;->log4jIsAvailable:Z
 | |
|     :try_end_0
 | |
|     .catchall {:try_start_0 .. :try_end_0} :catchall_0
 | |
| 
 | |
|     goto :goto_0
 | |
| 
 | |
|     .line 7
 | |
|     :catchall_0
 | |
|     sput-boolean v0, Lorg/apache/commons/logging/LogSource;->log4jIsAvailable:Z
 | |
| 
 | |
|     :goto_0
 | |
|     :try_start_1
 | |
|     const-string v3, "java.util.logging.Logger"
 | |
| 
 | |
|     .line 8
 | |
|     invoke-static {v3}, Ljava/lang/Class;->forName(Ljava/lang/String;)Ljava/lang/Class;
 | |
| 
 | |
|     const-string v3, "org.apache.commons.logging.impl.Jdk14Logger"
 | |
| 
 | |
|     invoke-static {v3}, Ljava/lang/Class;->forName(Ljava/lang/String;)Ljava/lang/Class;
 | |
| 
 | |
|     .line 9
 | |
|     sput-boolean v2, Lorg/apache/commons/logging/LogSource;->jdk14IsAvailable:Z
 | |
|     :try_end_1
 | |
|     .catchall {:try_start_1 .. :try_end_1} :catchall_1
 | |
| 
 | |
|     goto :goto_1
 | |
| 
 | |
|     .line 10
 | |
|     :catchall_1
 | |
|     sput-boolean v0, Lorg/apache/commons/logging/LogSource;->jdk14IsAvailable:Z
 | |
| 
 | |
|     :goto_1
 | |
|     :try_start_2
 | |
|     const-string v0, "org.apache.commons.logging.log"
 | |
| 
 | |
|     .line 11
 | |
|     invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
 | |
| 
 | |
|     move-result-object v1
 | |
| 
 | |
|     if-nez v1, :cond_0
 | |
| 
 | |
|     const-string v0, "org.apache.commons.logging.Log"
 | |
| 
 | |
|     .line 12
 | |
|     invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
 | |
| 
 | |
|     move-result-object v1
 | |
|     :try_end_2
 | |
|     .catchall {:try_start_2 .. :try_end_2} :catchall_2
 | |
| 
 | |
|     :catchall_2
 | |
|     :cond_0
 | |
|     const-string v0, "org.apache.commons.logging.impl.NoOpLog"
 | |
| 
 | |
|     if-eqz v1, :cond_1
 | |
| 
 | |
|     .line 13
 | |
|     :try_start_3
 | |
|     invoke-static {v1}, Lorg/apache/commons/logging/LogSource;->setLogImplementation(Ljava/lang/String;)V
 | |
|     :try_end_3
 | |
|     .catchall {:try_start_3 .. :try_end_3} :catchall_3
 | |
| 
 | |
|     goto :goto_2
 | |
| 
 | |
|     .line 14
 | |
|     :catchall_3
 | |
|     :try_start_4
 | |
|     invoke-static {v0}, Lorg/apache/commons/logging/LogSource;->setLogImplementation(Ljava/lang/String;)V
 | |
|     :try_end_4
 | |
|     .catchall {:try_start_4 .. :try_end_4} :catchall_5
 | |
| 
 | |
|     goto :goto_2
 | |
| 
 | |
|     .line 15
 | |
|     :cond_1
 | |
|     :try_start_5
 | |
|     sget-boolean v1, Lorg/apache/commons/logging/LogSource;->log4jIsAvailable:Z
 | |
| 
 | |
|     if-eqz v1, :cond_2
 | |
| 
 | |
|     const-string v1, "org.apache.commons.logging.impl.Log4JLogger"
 | |
| 
 | |
|     .line 16
 | |
|     invoke-static {v1}, Lorg/apache/commons/logging/LogSource;->setLogImplementation(Ljava/lang/String;)V
 | |
| 
 | |
|     goto :goto_2
 | |
| 
 | |
|     .line 17
 | |
|     :cond_2
 | |
|     sget-boolean v1, Lorg/apache/commons/logging/LogSource;->jdk14IsAvailable:Z
 | |
| 
 | |
|     if-eqz v1, :cond_3
 | |
| 
 | |
|     const-string v1, "org.apache.commons.logging.impl.Jdk14Logger"
 | |
| 
 | |
|     .line 18
 | |
|     invoke-static {v1}, Lorg/apache/commons/logging/LogSource;->setLogImplementation(Ljava/lang/String;)V
 | |
| 
 | |
|     goto :goto_2
 | |
| 
 | |
|     .line 19
 | |
|     :cond_3
 | |
|     invoke-static {v0}, Lorg/apache/commons/logging/LogSource;->setLogImplementation(Ljava/lang/String;)V
 | |
|     :try_end_5
 | |
|     .catchall {:try_start_5 .. :try_end_5} :catchall_4
 | |
| 
 | |
|     goto :goto_2
 | |
| 
 | |
|     .line 20
 | |
|     :catchall_4
 | |
|     :try_start_6
 | |
|     invoke-static {v0}, Lorg/apache/commons/logging/LogSource;->setLogImplementation(Ljava/lang/String;)V
 | |
|     :try_end_6
 | |
|     .catchall {:try_start_6 .. :try_end_6} :catchall_5
 | |
| 
 | |
|     :catchall_5
 | |
|     :goto_2
 | |
|     return-void
 | |
| .end method
 | |
| 
 | |
| .method private constructor <init>()V
 | |
|     .locals 0
 | |
| 
 | |
|     .line 1
 | |
|     invoke-direct {p0}, Ljava/lang/Object;-><init>()V
 | |
| 
 | |
|     return-void
 | |
| .end method
 | |
| 
 | |
| .method public static getInstance(Ljava/lang/Class;)Lorg/apache/commons/logging/Log;
 | |
|     .locals 0
 | |
| 
 | |
|     .line 4
 | |
|     invoke-virtual {p0}, Ljava/lang/Class;->getName()Ljava/lang/String;
 | |
| 
 | |
|     move-result-object p0
 | |
| 
 | |
|     invoke-static {p0}, Lorg/apache/commons/logging/LogSource;->getInstance(Ljava/lang/String;)Lorg/apache/commons/logging/Log;
 | |
| 
 | |
|     move-result-object p0
 | |
| 
 | |
|     return-object p0
 | |
| .end method
 | |
| 
 | |
| .method public static getInstance(Ljava/lang/String;)Lorg/apache/commons/logging/Log;
 | |
|     .locals 2
 | |
| 
 | |
|     .line 1
 | |
|     sget-object v0, Lorg/apache/commons/logging/LogSource;->logs:Ljava/util/Hashtable;
 | |
| 
 | |
|     invoke-virtual {v0, p0}, Ljava/util/Hashtable;->get(Ljava/lang/Object;)Ljava/lang/Object;
 | |
| 
 | |
|     move-result-object v0
 | |
| 
 | |
|     check-cast v0, Lorg/apache/commons/logging/Log;
 | |
| 
 | |
|     if-nez v0, :cond_0
 | |
| 
 | |
|     .line 2
 | |
|     invoke-static {p0}, Lorg/apache/commons/logging/LogSource;->makeNewLogInstance(Ljava/lang/String;)Lorg/apache/commons/logging/Log;
 | |
| 
 | |
|     move-result-object v0
 | |
| 
 | |
|     .line 3
 | |
|     sget-object v1, Lorg/apache/commons/logging/LogSource;->logs:Ljava/util/Hashtable;
 | |
| 
 | |
|     invoke-virtual {v1, p0, v0}, Ljava/util/Hashtable;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
 | |
| 
 | |
|     :cond_0
 | |
|     return-object v0
 | |
| .end method
 | |
| 
 | |
| .method public static getLogNames()[Ljava/lang/String;
 | |
|     .locals 2
 | |
| 
 | |
|     .line 1
 | |
|     sget-object v0, Lorg/apache/commons/logging/LogSource;->logs:Ljava/util/Hashtable;
 | |
| 
 | |
|     invoke-virtual {v0}, Ljava/util/Hashtable;->keySet()Ljava/util/Set;
 | |
| 
 | |
|     move-result-object v0
 | |
| 
 | |
|     sget-object v1, Lorg/apache/commons/logging/LogSource;->logs:Ljava/util/Hashtable;
 | |
| 
 | |
|     invoke-virtual {v1}, Ljava/util/Hashtable;->size()I
 | |
| 
 | |
|     move-result v1
 | |
| 
 | |
|     new-array v1, v1, [Ljava/lang/String;
 | |
| 
 | |
|     invoke-interface {v0, v1}, Ljava/util/Set;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;
 | |
| 
 | |
|     move-result-object v0
 | |
| 
 | |
|     check-cast v0, [Ljava/lang/String;
 | |
| 
 | |
|     return-object v0
 | |
| .end method
 | |
| 
 | |
| .method public static makeNewLogInstance(Ljava/lang/String;)Lorg/apache/commons/logging/Log;
 | |
|     .locals 2
 | |
| 
 | |
|     const/4 v0, 0x1
 | |
| 
 | |
|     :try_start_0
 | |
|     new-array v0, v0, [Ljava/lang/Object;
 | |
| 
 | |
|     const/4 v1, 0x0
 | |
| 
 | |
|     aput-object p0, v0, v1
 | |
| 
 | |
|     .line 1
 | |
|     sget-object v1, Lorg/apache/commons/logging/LogSource;->logImplctor:Ljava/lang/reflect/Constructor;
 | |
| 
 | |
|     invoke-virtual {v1, v0}, Ljava/lang/reflect/Constructor;->newInstance([Ljava/lang/Object;)Ljava/lang/Object;
 | |
| 
 | |
|     move-result-object v0
 | |
| 
 | |
|     check-cast v0, Lorg/apache/commons/logging/Log;
 | |
|     :try_end_0
 | |
|     .catchall {:try_start_0 .. :try_end_0} :catchall_0
 | |
| 
 | |
|     goto :goto_0
 | |
| 
 | |
|     :catchall_0
 | |
|     const/4 v0, 0x0
 | |
| 
 | |
|     :goto_0
 | |
|     if-nez v0, :cond_0
 | |
| 
 | |
|     .line 2
 | |
|     new-instance v0, Lorg/apache/commons/logging/impl/NoOpLog;
 | |
| 
 | |
|     invoke-direct {v0, p0}, Lorg/apache/commons/logging/impl/NoOpLog;-><init>(Ljava/lang/String;)V
 | |
| 
 | |
|     :cond_0
 | |
|     return-object v0
 | |
| .end method
 | |
| 
 | |
| .method public static setLogImplementation(Ljava/lang/Class;)V
 | |
|     .locals 3
 | |
|     .annotation system Ldalvik/annotation/Throws;
 | |
|         value = {
 | |
|             Ljava/lang/LinkageError;,
 | |
|             Ljava/lang/ExceptionInInitializerError;,
 | |
|             Ljava/lang/NoSuchMethodException;,
 | |
|             Ljava/lang/SecurityException;
 | |
|         }
 | |
|     .end annotation
 | |
| 
 | |
|     const/4 v0, 0x1
 | |
| 
 | |
|     new-array v0, v0, [Ljava/lang/Class;
 | |
| 
 | |
|     const-string v1, ""
 | |
| 
 | |
|     .line 5
 | |
|     invoke-virtual {v1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
 | |
| 
 | |
|     move-result-object v1
 | |
| 
 | |
|     const/4 v2, 0x0
 | |
| 
 | |
|     aput-object v1, v0, v2
 | |
| 
 | |
|     .line 6
 | |
|     invoke-virtual {p0, v0}, Ljava/lang/Class;->getConstructor([Ljava/lang/Class;)Ljava/lang/reflect/Constructor;
 | |
| 
 | |
|     move-result-object p0
 | |
| 
 | |
|     sput-object p0, Lorg/apache/commons/logging/LogSource;->logImplctor:Ljava/lang/reflect/Constructor;
 | |
| 
 | |
|     return-void
 | |
| .end method
 | |
| 
 | |
| .method public static setLogImplementation(Ljava/lang/String;)V
 | |
|     .locals 3
 | |
|     .annotation system Ldalvik/annotation/Throws;
 | |
|         value = {
 | |
|             Ljava/lang/LinkageError;,
 | |
|             Ljava/lang/ExceptionInInitializerError;,
 | |
|             Ljava/lang/NoSuchMethodException;,
 | |
|             Ljava/lang/SecurityException;,
 | |
|             Ljava/lang/ClassNotFoundException;
 | |
|         }
 | |
|     .end annotation
 | |
| 
 | |
|     .line 1
 | |
|     :try_start_0
 | |
|     invoke-static {p0}, Ljava/lang/Class;->forName(Ljava/lang/String;)Ljava/lang/Class;
 | |
| 
 | |
|     move-result-object p0
 | |
| 
 | |
|     const/4 v0, 0x1
 | |
| 
 | |
|     new-array v0, v0, [Ljava/lang/Class;
 | |
| 
 | |
|     const/4 v1, 0x0
 | |
| 
 | |
|     const-string v2, ""
 | |
| 
 | |
|     .line 2
 | |
|     invoke-virtual {v2}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
 | |
| 
 | |
|     move-result-object v2
 | |
| 
 | |
|     aput-object v2, v0, v1
 | |
| 
 | |
|     .line 3
 | |
|     invoke-virtual {p0, v0}, Ljava/lang/Class;->getConstructor([Ljava/lang/Class;)Ljava/lang/reflect/Constructor;
 | |
| 
 | |
|     move-result-object p0
 | |
| 
 | |
|     sput-object p0, Lorg/apache/commons/logging/LogSource;->logImplctor:Ljava/lang/reflect/Constructor;
 | |
|     :try_end_0
 | |
|     .catchall {:try_start_0 .. :try_end_0} :catchall_0
 | |
| 
 | |
|     goto :goto_0
 | |
| 
 | |
|     :catchall_0
 | |
|     const/4 p0, 0x0
 | |
| 
 | |
|     .line 4
 | |
|     sput-object p0, Lorg/apache/commons/logging/LogSource;->logImplctor:Ljava/lang/reflect/Constructor;
 | |
| 
 | |
|     :goto_0
 | |
|     return-void
 | |
| .end method
 |