SubDexLog.smali
.class public final Lcom/cleanmaster/loader/SubDexLog;
.super Ljava/lang/Object;
.source "SubDexLog.java"
# static fields
.field private static final LOG_TAG:Ljava/lang/String; = "SubDexLog"
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 17
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method private static getLogFilePath(Landroid/content/Context;)Ljava/lang/String;
.registers 5
.prologue
const/4 v0, 0x0
.line 23
invoke-static {}, Landroid/os/Environment;->getExternalStorageState()Ljava/lang/String;
move-result-object v1
const-string v2, "mounted"
invoke-virtual {v1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_13
.line 24
invoke-virtual {p0, v0}, Landroid/content/Context;->getExternalFilesDir(Ljava/lang/String;)Ljava/io/File;
move-result-object v1
.line 25
if-nez v1, :cond_14
.line 41
:cond_13
:goto_13
return-object v0
.line 28
:cond_14
invoke-virtual {v1}, Ljava/io/File;->exists()Z
move-result v2
if-nez v2, :cond_1d
.line 29
invoke-virtual {v1}, Ljava/io/File;->mkdirs()Z
.line 31
:cond_1d
new-instance v2, Ljava/io/File;
const-string v3, "logs"
invoke-direct {v2, v1, v3}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 32
invoke-virtual {v2}, Ljava/io/File;->exists()Z
move-result v1
if-nez v1, :cond_2d
.line 33
invoke-virtual {v2}, Ljava/io/File;->mkdirs()Z
.line 35
:cond_2d
invoke-virtual {v2}, Ljava/io/File;->exists()Z
move-result v1
if-eqz v1, :cond_13
invoke-virtual {v2}, Ljava/io/File;->canWrite()Z
move-result v1
if-eqz v1, :cond_13
.line 38
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v2}, Ljava/io/File;->getAbsolutePath()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
sget-object v1, Ljava/io/File;->separator:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string/jumbo v1, "subdex_debug.log"
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
goto :goto_13
.end method
.method public static log(Landroid/content/Context;Ljava/lang/String;Ljava/lang/String;)V
.registers 8
.prologue
const/4 v2, 0x0
.line 47
new-instance v0, Ljava/text/SimpleDateFormat;
const-string/jumbo v1, "yyyy-MM-dd HH:mm:ss"
invoke-direct {v0, v1}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;)V
.line 48
new-instance v1, Ljava/util/Date;
invoke-direct {v1}, Ljava/util/Date;-><init>()V
.line 49
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0, v1}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, ":["
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v1, "]"
invoke-virtual {v0, v1}, 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
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 50
invoke-static {p0}, Lcom/cleanmaster/loader/SubDexLog;->getLogFilePath(Landroid/content/Context;)Ljava/lang/String;
move-result-object v1
.line 52
if-eqz v1, :cond_59
.line 54
new-instance v4, Ljava/io/File;
invoke-direct {v4, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 58
:try_start_3e
new-instance v3, Ljava/io/FileWriter;
const/4 v1, 0x1
invoke-direct {v3, v4, v1}, Ljava/io/FileWriter;-><init>(Ljava/io/File;Z)V
:try_end_44
.catch Ljava/io/IOException; {:try_start_3e .. :try_end_44} :catch_64
.catchall {:try_start_3e .. :try_end_44} :catchall_85
.line 59
:try_start_44
new-instance v1, Ljava/io/BufferedWriter;
invoke-direct {v1, v3}, Ljava/io/BufferedWriter;-><init>(Ljava/io/Writer;)V
:try_end_49
.catch Ljava/io/IOException; {:try_start_44 .. :try_end_49} :catch_a5
.catchall {:try_start_44 .. :try_end_49} :catchall_9c
.line 60
:try_start_49
invoke-virtual {v1, v0}, Ljava/io/BufferedWriter;->write(Ljava/lang/String;)V
.line 61
invoke-virtual {v1}, Ljava/io/BufferedWriter;->newLine()V
:try_end_4f
.catch Ljava/io/IOException; {:try_start_49 .. :try_end_4f} :catch_a9
.catchall {:try_start_49 .. :try_end_4f} :catchall_a0
.line 66
if-eqz v1, :cond_54
.line 68
:try_start_51
invoke-virtual {v1}, Ljava/io/BufferedWriter;->close()V
:try_end_54
.catch Ljava/io/IOException; {:try_start_51 .. :try_end_54} :catch_5a
.line 73
:cond_54
:goto_54
if-eqz v3, :cond_59
.line 75
:try_start_56
invoke-virtual {v3}, Ljava/io/FileWriter;->close()V
:try_end_59
.catch Ljava/io/IOException; {:try_start_56 .. :try_end_59} :catch_5f
.line 82
:cond_59
:goto_59
return-void
.line 69
:catch_5a
move-exception v0
.line 70
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
goto :goto_54
.line 76
:catch_5f
move-exception v0
.line 77
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
goto :goto_59
.line 62
:catch_64
move-exception v0
move-object v1, v2
.line 63
:goto_66
:try_start_66
const-string v3, "SubDexLog"
const-string v4, "Write log error"
invoke-static {v3, v4}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 64
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
:try_end_70
.catchall {:try_start_66 .. :try_end_70} :catchall_a3
.line 66
if-eqz v1, :cond_75
.line 68
:try_start_72
invoke-virtual {v1}, Ljava/io/BufferedWriter;->close()V
:try_end_75
.catch Ljava/io/IOException; {:try_start_72 .. :try_end_75} :catch_80
.line 73
:cond_75
:goto_75
if-eqz v2, :cond_59
.line 75
:try_start_77
invoke-virtual {v2}, Ljava/io/FileWriter;->close()V
:try_end_7a
.catch Ljava/io/IOException; {:try_start_77 .. :try_end_7a} :catch_7b
goto :goto_59
.line 76
:catch_7b
move-exception v0
.line 77
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
goto :goto_59
.line 69
:catch_80
move-exception v0
.line 70
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
goto :goto_75
.line 66
:catchall_85
move-exception v0
move-object v1, v2
:goto_87
if-eqz v1, :cond_8c
.line 68
:try_start_89
invoke-virtual {v1}, Ljava/io/BufferedWriter;->close()V
:try_end_8c
.catch Ljava/io/IOException; {:try_start_89 .. :try_end_8c} :catch_92
.line 73
:cond_8c
:goto_8c
if-eqz v2, :cond_91
.line 75
:try_start_8e
invoke-virtual {v2}, Ljava/io/FileWriter;->close()V
:try_end_91
.catch Ljava/io/IOException; {:try_start_8e .. :try_end_91} :catch_97
.line 78
:cond_91
:goto_91
throw v0
.line 69
:catch_92
move-exception v1
.line 70
invoke-virtual {v1}, Ljava/io/IOException;->printStackTrace()V
goto :goto_8c
.line 76
:catch_97
move-exception v1
.line 77
invoke-virtual {v1}, Ljava/io/IOException;->printStackTrace()V
goto :goto_91
.line 66
:catchall_9c
move-exception v0
move-object v1, v2
move-object v2, v3
goto :goto_87
:catchall_a0
move-exception v0
move-object v2, v3
goto :goto_87
:catchall_a3
move-exception v0
goto :goto_87
.line 62
:catch_a5
move-exception v0
move-object v1, v2
move-object v2, v3
goto :goto_66
:catch_a9
move-exception v0
move-object v2, v3
goto :goto_66
.end method