FileLog.smali

.class public Lcom/cleanmaster/util/FileLog;
.super Ljava/lang/Object;
.source "FileLog.java"


# static fields
.field private static LOG_MAX_SIZE:I

.field private static sIns:Lcom/cleanmaster/util/FileLog;


# instance fields
.field private mMyPid:I


# direct methods
.method static constructor <clinit>()V
    .registers 1

    .prologue
    .line 13
    const/high16 v0, 0x400000

    sput v0, Lcom/cleanmaster/util/FileLog;->LOG_MAX_SIZE:I

    .line 22
    const/4 v0, 0x0

    sput-object v0, Lcom/cleanmaster/util/FileLog;->sIns:Lcom/cleanmaster/util/FileLog;

    return-void
.end method

.method public constructor <init>()V
    .registers 2

    .prologue
    .line 11
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 23
    invoke-static {}, Landroid/os/Process;->myPid()I

    move-result v0

    iput v0, p0, Lcom/cleanmaster/util/FileLog;->mMyPid:I

    return-void
.end method

.method private static declared-synchronized chmodFile(Ljava/lang/String;Ljava/lang/String;)V
    .registers 6

    .prologue
    .line 28
    const-class v1, Lcom/cleanmaster/util/FileLog;

    monitor-enter v1

    :try_start_3
    invoke-static {}, Ljava/lang/Runtime;->getRuntime()Ljava/lang/Runtime;

    move-result-object v0

    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    const-string v3, "chmod "

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v2

    invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v2

    const-string v3, " "

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v2

    invoke-virtual {v2, p0}, 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-virtual {v0, v2}, Ljava/lang/Runtime;->exec(Ljava/lang/String;)Ljava/lang/Process;
    :try_end_27
    .catch Ljava/io/IOException; {:try_start_3 .. :try_end_27} :catch_29
    .catchall {:try_start_3 .. :try_end_27} :catchall_2e

    .line 32
    :goto_27
    monitor-exit v1

    return-void

    .line 29
    :catch_29
    move-exception v0

    .line 30
    :try_start_2a
    invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
    :try_end_2d
    .catchall {:try_start_2a .. :try_end_2d} :catchall_2e

    goto :goto_27

    .line 28
    :catchall_2e
    move-exception v0

    monitor-exit v1

    throw v0
.end method

.method public static declared-synchronized getIns()Lcom/cleanmaster/util/FileLog;
    .registers 2

    .prologue
    .line 16
    const-class v1, Lcom/cleanmaster/util/FileLog;

    monitor-enter v1

    :try_start_3
    sget-object v0, Lcom/cleanmaster/util/FileLog;->sIns:Lcom/cleanmaster/util/FileLog;

    if-nez v0, :cond_e

    .line 17
    new-instance v0, Lcom/cleanmaster/util/FileLog;

    invoke-direct {v0}, Lcom/cleanmaster/util/FileLog;-><init>()V

    sput-object v0, Lcom/cleanmaster/util/FileLog;->sIns:Lcom/cleanmaster/util/FileLog;

    .line 19
    :cond_e
    sget-object v0, Lcom/cleanmaster/util/FileLog;->sIns:Lcom/cleanmaster/util/FileLog;
    :try_end_10
    .catchall {:try_start_3 .. :try_end_10} :catchall_12

    monitor-exit v1

    return-object v0

    .line 16
    :catchall_12
    move-exception v0

    monitor-exit v1

    throw v0
.end method


# virtual methods
.method public declared-synchronized writeLogSDCard(Ljava/lang/String;Ljava/lang/String;)V
    .registers 7

    .prologue
    .line 37
    monitor-enter p0

    :try_start_1
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    invoke-static {}, Lcom/keniu/security/h;->f()Ljava/lang/String;

    move-result-object v1

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v0

    const-string v1, "/logs/"

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    .line 38
    new-instance v1, Ljava/io/File;

    invoke-direct {v1, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V

    .line 39
    invoke-virtual {v1}, Ljava/io/File;->mkdir()Z

    .line 41
    const-string v0, ""

    .line 42
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v2

    .line 43
    const-string v0, "[yyyy-MM-dd kk:mm:ss] "

    invoke-static {v0, v2, v3}, Landroid/text/format/DateFormat;->format(Ljava/lang/CharSequence;J)Ljava/lang/CharSequence;

    move-result-object v0

    invoke-interface {v0}, Ljava/lang/CharSequence;->toString()Ljava/lang/String;

    move-result-object v0

    .line 46
    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v0

    invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v0

    const-string v2, "\r\n"

    invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    .line 48
    new-instance v2, Ljava/io/File;

    new-instance v3, Ljava/lang/StringBuilder;

    invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V

    invoke-virtual {v1}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v1

    invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v1

    const-string v3, "/"

    invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v1

    invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v1

    invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v1

    invoke-direct {v2, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V

    .line 50
    new-instance v1, Ljava/io/FileWriter;

    invoke-virtual {v2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v2

    const/4 v3, 0x1

    invoke-direct {v1, v2, v3}, Ljava/io/FileWriter;-><init>(Ljava/lang/String;Z)V

    .line 51
    invoke-virtual {v1, v0}, Ljava/io/FileWriter;->write(Ljava/lang/String;)V

    .line 52
    invoke-virtual {v1}, Ljava/io/FileWriter;->flush()V

    .line 53
    invoke-virtual {v1}, Ljava/io/FileWriter;->close()V
    :try_end_7a
    .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_7a} :catch_7c
    .catchall {:try_start_1 .. :try_end_7a} :catchall_81

    .line 57
    :goto_7a
    monitor-exit p0

    return-void

    .line 54
    :catch_7c
    move-exception v0

    .line 55
    :try_start_7d
    invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
    :try_end_80
    .catchall {:try_start_7d .. :try_end_80} :catchall_81

    goto :goto_7a

    .line 37
    :catchall_81
    move-exception v0

    monitor-exit p0

    throw v0
.end method