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
|