FilePrinter.smali
.class public Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;
.super Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;
# static fields
.field private static final TAG:Ljava/lang/String;
# instance fields
.field private mCurFile:Ljava/io/File;
.field private mLogDirPath:Ljava/lang/String;
.field private mLogFileDir:Ljava/io/File;
.field private mLogFileNameGenerator:Lcom/cmcm/xiaobao/phone/commons/log/generator/FileNameGenerator;
.field private mWriter:Ljava/io/BufferedWriter;
# direct methods
.method static constructor <clinit>()V
.registers 1
const-class v0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;
invoke-virtual {v0}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String;
move-result-object v0
sput-object v0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->TAG:Ljava/lang/String;
return-void
.end method
.method public constructor <init>(Ljava/lang/String;Lcom/cmcm/xiaobao/phone/commons/log/generator/FileNameGenerator;)V
.registers 4
const/4 v0, 0x0
invoke-direct {p0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;-><init>()V
iput-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mLogFileDir:Ljava/io/File;
iput-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mWriter:Ljava/io/BufferedWriter;
iput-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mCurFile:Ljava/io/File;
iput-object p1, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mLogDirPath:Ljava/lang/String;
iput-object p2, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mLogFileNameGenerator:Lcom/cmcm/xiaobao/phone/commons/log/generator/FileNameGenerator;
return-void
.end method
.method private checkLogFile()V
.registers 5
invoke-direct {p0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->getCurFileName()Ljava/io/File;
move-result-object v0
iget-object v1, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mCurFile:Ljava/io/File;
invoke-virtual {v0, v1}, Ljava/io/File;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_15
iget-object v1, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mCurFile:Ljava/io/File;
invoke-virtual {v1}, Ljava/io/File;->exists()Z
move-result v1
if-eqz v1, :cond_15
:goto_14
return-void
:cond_15
sget-object v1, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->TAG:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v3, " Switch Log File: From: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
iget-object v3, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mCurFile:Ljava/io/File;
invoke-static {v3}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string/jumbo v3, " TO "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
invoke-direct {p0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->closeWritingFile()V
iput-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mCurFile:Ljava/io/File;
:try_start_48
new-instance v0, Ljava/io/BufferedWriter;
new-instance v1, Ljava/io/FileWriter;
iget-object v2, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mCurFile:Ljava/io/File;
const/4 v3, 0x1
invoke-direct {v1, v2, v3}, Ljava/io/FileWriter;-><init>(Ljava/io/File;Z)V
invoke-direct {v0, v1}, Ljava/io/BufferedWriter;-><init>(Ljava/io/Writer;)V
iput-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mWriter:Ljava/io/BufferedWriter;
:try_end_57
.catch Ljava/io/IOException; {:try_start_48 .. :try_end_57} :catch_58
goto :goto_14
:catch_58
move-exception v0
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
sget-object v1, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->TAG:Ljava/lang/String;
const-string/jumbo v2, "Failed to open FileWriter!"
invoke-static {v1, v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_14
.end method
.method private closeWritingFile()V
.registers 2
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mWriter:Ljava/io/BufferedWriter;
if-eqz v0, :cond_9
:try_start_4
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mWriter:Ljava/io/BufferedWriter;
invoke-virtual {v0}, Ljava/io/BufferedWriter;->close()V
:try_end_9
.catch Ljava/io/IOException; {:try_start_4 .. :try_end_9} :catch_a
:cond_9
:goto_9
return-void
:catch_a
move-exception v0
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
goto :goto_9
.end method
.method private createLogFileDir(Ljava/lang/String;)V
.registers 3
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mLogFileDir:Ljava/io/File;
if-nez v0, :cond_b
new-instance v0, Ljava/io/File;
invoke-direct {v0, p1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
iput-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mLogFileDir:Ljava/io/File;
:cond_b
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mLogFileDir:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v0
if-nez v0, :cond_18
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mLogFileDir:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->mkdirs()Z
:cond_18
return-void
.end method
.method private getCurFileName()Ljava/io/File;
.registers 5
new-instance v0, Ljava/io/File;
iget-object v1, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mLogFileDir:Ljava/io/File;
iget-object v2, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mLogFileNameGenerator:Lcom/cmcm/xiaobao/phone/commons/log/generator/FileNameGenerator;
iget-object v3, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mLogFileDir:Ljava/io/File;
invoke-interface {v2, v3}, Lcom/cmcm/xiaobao/phone/commons/log/generator/FileNameGenerator;->generateFileName(Ljava/io/File;)Ljava/lang/String;
move-result-object v2
invoke-direct {v0, v1, v2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
return-object v0
.end method
.method private writeLog(Ljava/lang/String;)V
.registers 5
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mWriter:Ljava/io/BufferedWriter;
if-nez v0, :cond_5
:goto_4
return-void
:cond_5
:try_start_5
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mWriter:Ljava/io/BufferedWriter;
invoke-virtual {v0, p1}, Ljava/io/BufferedWriter;->write(Ljava/lang/String;)V
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mWriter:Ljava/io/BufferedWriter;
invoke-virtual {v0}, Ljava/io/BufferedWriter;->newLine()V
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mWriter:Ljava/io/BufferedWriter;
invoke-virtual {v0}, Ljava/io/BufferedWriter;->flush()V
:try_end_14
.catch Ljava/io/IOException; {:try_start_5 .. :try_end_14} :catch_15
goto :goto_4
:catch_15
move-exception v0
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
sget-object v1, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->TAG:Ljava/lang/String;
const-string/jumbo v2, "Failed to write Log!"
invoke-static {v1, v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_4
.end method
# virtual methods
.method protected doPrintln(Ljava/lang/String;)V
.registers 3
iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->mLogDirPath:Ljava/lang/String;
invoke-direct {p0, v0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->createLogFileDir(Ljava/lang/String;)V
invoke-direct {p0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->checkLogFile()V
invoke-direct {p0, p1}, Lcom/cmcm/xiaobao/phone/commons/log/printer/FilePrinter;->writeLog(Ljava/lang/String;)V
return-void
.end method