SimpleFormatter.smali
.class Lcom/baidu/android/common/logging/SimpleFormatter;
.super Ljava/util/logging/Formatter;
# static fields
.field private static b:Ljava/lang/String;
# instance fields
.field a:Ljava/util/Date;
.field private c:Ljava/text/MessageFormat;
.field private d:[Ljava/lang/Object;
# direct methods
.method static constructor <clinit>()V
.registers 1
const-string v0, "{0,date} {0,time}"
sput-object v0, Lcom/baidu/android/common/logging/SimpleFormatter;->b:Ljava/lang/String;
return-void
.end method
.method constructor <init>()V
.registers 2
invoke-direct {p0}, Ljava/util/logging/Formatter;-><init>()V
new-instance v0, Ljava/util/Date;
invoke-direct {v0}, Ljava/util/Date;-><init>()V
iput-object v0, p0, Lcom/baidu/android/common/logging/SimpleFormatter;->a:Ljava/util/Date;
const/4 v0, 0x1
new-array v0, v0, [Ljava/lang/Object;
iput-object v0, p0, Lcom/baidu/android/common/logging/SimpleFormatter;->d:[Ljava/lang/Object;
return-void
.end method
# virtual methods
.method public declared-synchronized format(Ljava/util/logging/LogRecord;)Ljava/lang/String;
.registers 11
const/4 v2, 0x0
const/4 v1, 0x0
monitor-enter p0
:try_start_3
new-instance v0, Ljava/lang/Throwable;
invoke-direct {v0}, Ljava/lang/Throwable;-><init>()V
invoke-virtual {v0}, Ljava/lang/Throwable;->getStackTrace()[Ljava/lang/StackTraceElement;
move-result-object v4
array-length v5, v4
move v3, v1
move v0, v1
:goto_f
if-ge v3, v5, :cond_10e
aget-object v6, v4, v3
invoke-virtual {v6}, Ljava/lang/StackTraceElement;->getClassName()Ljava/lang/String;
move-result-object v7
const-class v8, Lcom/baidu/android/common/logging/Log;
invoke-virtual {v8}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v8
invoke-virtual {v7, v8}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v7
if-eqz v7, :cond_27
const/4 v0, 0x1
:cond_24
add-int/lit8 v3, v3, 0x1
goto :goto_f
:cond_27
if-eqz v0, :cond_24
invoke-virtual {v6}, Ljava/lang/StackTraceElement;->getClassName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v6}, Ljava/lang/StackTraceElement;->getMethodName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v6}, Ljava/lang/StackTraceElement;->getLineNumber()I
move-result v0
:goto_35
invoke-virtual {p1, v2}, Ljava/util/logging/LogRecord;->setSourceClassName(Ljava/lang/String;)V
invoke-virtual {p1, v1}, Ljava/util/logging/LogRecord;->setSourceMethodName(Ljava/lang/String;)V
new-instance v1, Ljava/lang/StringBuffer;
invoke-direct {v1}, Ljava/lang/StringBuffer;-><init>()V
iget-object v2, p0, Lcom/baidu/android/common/logging/SimpleFormatter;->a:Ljava/util/Date;
invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getMillis()J
move-result-wide v4
invoke-virtual {v2, v4, v5}, Ljava/util/Date;->setTime(J)V
iget-object v2, p0, Lcom/baidu/android/common/logging/SimpleFormatter;->d:[Ljava/lang/Object;
const/4 v3, 0x0
iget-object v4, p0, Lcom/baidu/android/common/logging/SimpleFormatter;->a:Ljava/util/Date;
aput-object v4, v2, v3
new-instance v2, Ljava/lang/StringBuffer;
invoke-direct {v2}, Ljava/lang/StringBuffer;-><init>()V
iget-object v3, p0, Lcom/baidu/android/common/logging/SimpleFormatter;->c:Ljava/text/MessageFormat;
if-nez v3, :cond_62
new-instance v3, Ljava/text/MessageFormat;
sget-object v4, Lcom/baidu/android/common/logging/SimpleFormatter;->b:Ljava/lang/String;
invoke-direct {v3, v4}, Ljava/text/MessageFormat;-><init>(Ljava/lang/String;)V
iput-object v3, p0, Lcom/baidu/android/common/logging/SimpleFormatter;->c:Ljava/text/MessageFormat;
:cond_62
iget-object v3, p0, Lcom/baidu/android/common/logging/SimpleFormatter;->c:Ljava/text/MessageFormat;
iget-object v4, p0, Lcom/baidu/android/common/logging/SimpleFormatter;->d:[Ljava/lang/Object;
const/4 v5, 0x0
invoke-virtual {v3, v4, v2, v5}, Ljava/text/MessageFormat;->format([Ljava/lang/Object;Ljava/lang/StringBuffer;Ljava/text/FieldPosition;)Ljava/lang/StringBuffer;
invoke-virtual {v1, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/StringBuffer;)Ljava/lang/StringBuffer;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "."
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getMillis()J
move-result-wide v4
const-wide/16 v6, 0x3e8
rem-long/2addr v4, v6
invoke-virtual {v2, v4, v5}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
const-string v2, " "
invoke-virtual {v1, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getSourceClassName()Ljava/lang/String;
move-result-object v2
if-eqz v2, :cond_fe
invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getSourceClassName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
:goto_9c
invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getSourceMethodName()Ljava/lang/String;
move-result-object v2
if-eqz v2, :cond_ae
const-string v2, " "
invoke-virtual {v1, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getSourceMethodName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
:cond_ae
const-string v2, " "
invoke-virtual {v1, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
invoke-virtual {v1, v0}, Ljava/lang/StringBuffer;->append(I)Ljava/lang/StringBuffer;
const-string v0, " "
invoke-virtual {v1, v0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
invoke-virtual {p0, p1}, Lcom/baidu/android/common/logging/SimpleFormatter;->formatMessage(Ljava/util/logging/LogRecord;)Ljava/lang/String;
move-result-object v0
invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getLevel()Ljava/util/logging/Level;
move-result-object v2
invoke-virtual {v2}, Ljava/util/logging/Level;->getLocalizedName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
const-string v2, ": "
invoke-virtual {v1, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
invoke-virtual {v1, v0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
const-string v0, "\n"
invoke-virtual {v1, v0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getThrown()Ljava/lang/Throwable;
:try_end_da
.catchall {:try_start_3 .. :try_end_da} :catchall_106
move-result-object v0
if-eqz v0, :cond_f8
:try_start_dd
new-instance v0, Ljava/io/StringWriter;
invoke-direct {v0}, Ljava/io/StringWriter;-><init>()V
new-instance v2, Ljava/io/PrintWriter;
invoke-direct {v2, v0}, Ljava/io/PrintWriter;-><init>(Ljava/io/Writer;)V
invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getThrown()Ljava/lang/Throwable;
move-result-object v3
invoke-virtual {v3, v2}, Ljava/lang/Throwable;->printStackTrace(Ljava/io/PrintWriter;)V
invoke-virtual {v2}, Ljava/io/PrintWriter;->close()V
invoke-virtual {v0}, Ljava/io/StringWriter;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
:try_end_f8
.catch Ljava/lang/Exception; {:try_start_dd .. :try_end_f8} :catch_109
.catchall {:try_start_dd .. :try_end_f8} :catchall_106
:cond_f8
:goto_f8
:try_start_f8
invoke-virtual {v1}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;
:try_end_fb
.catchall {:try_start_f8 .. :try_end_fb} :catchall_106
move-result-object v0
monitor-exit p0
return-object v0
:cond_fe
:try_start_fe
invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getLoggerName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
:try_end_105
.catchall {:try_start_fe .. :try_end_105} :catchall_106
goto :goto_9c
:catchall_106
move-exception v0
monitor-exit p0
throw v0
:catch_109
move-exception v0
:try_start_10a
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
:try_end_10d
.catchall {:try_start_10a .. :try_end_10d} :catchall_106
goto :goto_f8
:cond_10e
move v0, v1
move-object v1, v2
goto/16 :goto_35
.end method