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