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