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