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