KLog.smali

.class public Lcom/cmcm/support/base/KLog;
.super Ljava/lang/Object;
.source "KLog.java"


# static fields
.field private static final InfocLogName:Ljava/lang/String; = "cmcm_support.log"

.field public static final debugServerUrl:Ljava/lang/String; = "http://118.89.55.235/nep/v1/"


# instance fields
.field private mContext:Landroid/content/Context;

.field private mbDebug:Z


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

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

    .line 20
    const/4 v0, 0x0

    iput-boolean v0, p0, Lcom/cmcm/support/base/KLog;->mbDebug:Z

    .line 21
    const/4 v0, 0x0

    iput-object v0, p0, Lcom/cmcm/support/base/KLog;->mContext:Landroid/content/Context;

    return-void
.end method

.method private isExternalStorageMounted()Z
    .registers 3

    .prologue
    .line 79
    const-string v0, "mounted"

    invoke-static {}, Landroid/os/Environment;->getExternalStorageState()Ljava/lang/String;

    move-result-object v1

    invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v0

    return v0
.end method

.method private openFile(Ljava/lang/String;)Ljava/io/File;
    .registers 6

    .prologue
    const/4 v0, 0x0

    .line 82
    iget-object v1, p0, Lcom/cmcm/support/base/KLog;->mContext:Landroid/content/Context;

    if-eqz v1, :cond_40

    invoke-direct {p0}, Lcom/cmcm/support/base/KLog;->isExternalStorageMounted()Z

    move-result v1

    if-eqz v1, :cond_40

    .line 83
    new-instance v1, Ljava/lang/StringBuilder;

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

    iget-object v2, p0, Lcom/cmcm/support/base/KLog;->mContext:Landroid/content/Context;

    invoke-virtual {v2}, Landroid/content/Context;->getFilesDir()Ljava/io/File;

    move-result-object v2

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

    move-result-object v1

    const-string v2, "/Log"

    invoke-virtual {v1, v2}, 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

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

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

    .line 85
    if-eqz v2, :cond_48

    invoke-virtual {v2}, Ljava/io/File;->exists()Z

    move-result v3

    if-nez v3, :cond_48

    .line 86
    if-eqz v2, :cond_41

    invoke-virtual {v2}, Ljava/io/File;->mkdirs()Z

    move-result v2

    if-nez v2, :cond_41

    .line 87
    const-string v1, "KSupport"

    const-string v2, "Create LogDir failed"

    invoke-static {v1, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 94
    :cond_40
    :goto_40
    return-object v0

    .line 90
    :cond_41
    const-string v0, "KSupport"

    const-string v2, "Create LogDir done"

    invoke-static {v0, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 92
    :cond_48
    new-instance v0, Ljava/io/File;

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

    goto :goto_40
.end method

.method private storeInfocLog(ZLjava/lang/String;Ljava/lang/String;)V
    .registers 10

    .prologue
    const/4 v2, 0x0

    .line 43
    const/4 v0, 0x0

    .line 44
    const/4 v1, 0x0

    .line 47
    :try_start_3
    const-string v3, "cmcm_support.log"

    invoke-direct {p0, v3}, Lcom/cmcm/support/base/KLog;->openFile(Ljava/lang/String;)Ljava/io/File;
    :try_end_8
    .catch Ljava/lang/Throwable; {:try_start_3 .. :try_end_8} :catch_ae
    .catchall {:try_start_3 .. :try_end_8} :catchall_c5

    move-result-object v3

    .line 48
    if-nez v3, :cond_1b

    .line 66
    if-eqz v2, :cond_10

    .line 67
    :try_start_d
    invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V

    .line 69
    :cond_10
    if-eqz v2, :cond_15

    .line 70
    invoke-virtual {v0}, Ljava/io/PrintWriter;->close()V
    :try_end_15
    .catch Ljava/io/IOException; {:try_start_d .. :try_end_15} :catch_16

    .line 76
    :cond_15
    :goto_15
    return-void

    .line 72
    :catch_16
    move-exception v0

    .line 73
    invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V

    goto :goto_15

    .line 52
    :cond_1b
    :try_start_1b
    new-instance v1, Ljava/io/FileOutputStream;

    const/4 v0, 0x1

    invoke-direct {v1, v3, v0}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;Z)V
    :try_end_21
    .catch Ljava/lang/Throwable; {:try_start_1b .. :try_end_21} :catch_ae
    .catchall {:try_start_1b .. :try_end_21} :catchall_c5

    .line 53
    if-eqz v1, :cond_e5

    .line 54
    const-wide/16 v4, 0x0

    :try_start_25
    invoke-static {v4, v5}, Lcom/cmcm/support/base/KLog;->timeFormat(J)Ljava/lang/String;

    move-result-object v0

    .line 55
    new-instance v3, Ljava/io/PrintWriter;

    invoke-direct {v3, v1}, Ljava/io/PrintWriter;-><init>(Ljava/io/OutputStream;)V
    :try_end_2e
    .catch Ljava/lang/Throwable; {:try_start_25 .. :try_end_2e} :catch_e0
    .catchall {:try_start_25 .. :try_end_2e} :catchall_d8

    .line 56
    :try_start_2e
    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

    const/16 v2, 0xd

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

    move-result-object v0

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

    move-result-object v0

    invoke-virtual {v3, v0}, Ljava/io/PrintWriter;->println(Ljava/lang/String;)V

    .line 57
    new-instance v0, Ljava/lang/StringBuilder;

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

    const-string v2, "Parse result:"

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

    move-result-object v2

    if-eqz p1, :cond_ab

    const-string v0, "OK"

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

    move-result-object v0

    const/16 v2, 0xd

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

    move-result-object v0

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

    move-result-object v0

    invoke-virtual {v3, v0}, Ljava/io/PrintWriter;->println(Ljava/lang/String;)V

    .line 58
    new-instance v0, Ljava/lang/StringBuilder;

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

    const-string v2, "Table name:"

    invoke-virtual {v0, v2}, 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/16 v2, 0xd

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

    move-result-object v0

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

    move-result-object v0

    invoke-virtual {v3, v0}, Ljava/io/PrintWriter;->println(Ljava/lang/String;)V

    .line 59
    new-instance v0, Ljava/lang/StringBuilder;

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

    invoke-virtual {v0, p3}, 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

    invoke-virtual {v3, v0}, Ljava/io/PrintWriter;->println(Ljava/lang/String;)V

    .line 60
    invoke-virtual {v3}, Ljava/io/PrintWriter;->flush()V
    :try_end_99
    .catch Ljava/lang/Throwable; {:try_start_2e .. :try_end_99} :catch_e2
    .catchall {:try_start_2e .. :try_end_99} :catchall_db

    .line 66
    :goto_99
    if-eqz v1, :cond_9e

    .line 67
    :try_start_9b
    invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V

    .line 69
    :cond_9e
    if-eqz v3, :cond_15

    .line 70
    invoke-virtual {v3}, Ljava/io/PrintWriter;->close()V
    :try_end_a3
    .catch Ljava/io/IOException; {:try_start_9b .. :try_end_a3} :catch_a5

    goto/16 :goto_15

    .line 72
    :catch_a5
    move-exception v0

    .line 73
    invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V

    goto/16 :goto_15

    .line 57
    :cond_ab
    :try_start_ab
    const-string v0, "Failed"
    :try_end_ad
    .catch Ljava/lang/Throwable; {:try_start_ab .. :try_end_ad} :catch_e2
    .catchall {:try_start_ab .. :try_end_ad} :catchall_db

    goto :goto_53

    .line 62
    :catch_ae
    move-exception v0

    move-object v1, v2

    .line 63
    :goto_b0
    :try_start_b0
    invoke-virtual {v0}, Ljava/lang/Throwable;->printStackTrace()V
    :try_end_b3
    .catchall {:try_start_b0 .. :try_end_b3} :catchall_dd

    .line 66
    if-eqz v1, :cond_b8

    .line 67
    :try_start_b5
    invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V

    .line 69
    :cond_b8
    if-eqz v2, :cond_15

    .line 70
    invoke-virtual {v2}, Ljava/io/PrintWriter;->close()V
    :try_end_bd
    .catch Ljava/io/IOException; {:try_start_b5 .. :try_end_bd} :catch_bf

    goto/16 :goto_15

    .line 72
    :catch_bf
    move-exception v0

    .line 73
    invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V

    goto/16 :goto_15

    .line 65
    :catchall_c5
    move-exception v0

    move-object v1, v2

    move-object v3, v2

    .line 66
    :goto_c8
    if-eqz v1, :cond_cd

    .line 67
    :try_start_ca
    invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V

    .line 69
    :cond_cd
    if-eqz v3, :cond_d2

    .line 70
    invoke-virtual {v3}, Ljava/io/PrintWriter;->close()V
    :try_end_d2
    .catch Ljava/io/IOException; {:try_start_ca .. :try_end_d2} :catch_d3

    .line 74
    :cond_d2
    :goto_d2
    throw v0

    .line 72
    :catch_d3
    move-exception v1

    .line 73
    invoke-virtual {v1}, Ljava/io/IOException;->printStackTrace()V

    goto :goto_d2

    .line 65
    :catchall_d8
    move-exception v0

    move-object v3, v2

    goto :goto_c8

    :catchall_db
    move-exception v0

    goto :goto_c8

    :catchall_dd
    move-exception v0

    move-object v3, v2

    goto :goto_c8

    .line 62
    :catch_e0
    move-exception v0

    goto :goto_b0

    :catch_e2
    move-exception v0

    move-object v2, v3

    goto :goto_b0

    :cond_e5
    move-object v3, v2

    goto :goto_99
.end method

.method private static timeFormat(J)Ljava/lang/String;
    .registers 6

    .prologue
    .line 99
    new-instance v0, Ljava/text/SimpleDateFormat;

    const-string v1, "yyyy-MM-dd HH:mm:ss"

    sget-object v2, Ljava/util/Locale;->ENGLISH:Ljava/util/Locale;

    invoke-direct {v0, v1, v2}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V

    .line 100
    const-wide/16 v2, 0x0

    cmp-long v1, p0, v2

    if-lez v1, :cond_19

    .line 101
    new-instance v1, Ljava/util/Date;

    invoke-direct {v1, p0, p1}, Ljava/util/Date;-><init>(J)V

    invoke-virtual {v0, v1}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;

    move-result-object v0

    .line 102
    :goto_18
    return-object v0

    :cond_19
    new-instance v1, Ljava/util/Date;

    invoke-direct {v1}, Ljava/util/Date;-><init>()V

    invoke-virtual {v0, v1}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;

    move-result-object v0

    goto :goto_18
.end method


# virtual methods
.method public D(Ljava/lang/String;Ljava/lang/String;)V
    .registers 4

    .prologue
    .line 37
    iget-boolean v0, p0, Lcom/cmcm/support/base/KLog;->mbDebug:Z

    if-eqz v0, :cond_7

    .line 38
    invoke-static {p1, p2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 40
    :cond_7
    return-void
.end method

.method public Init(ZLandroid/content/Context;)V
    .registers 3

    .prologue
    .line 24
    iput-boolean p1, p0, Lcom/cmcm/support/base/KLog;->mbDebug:Z

    .line 25
    iput-object p2, p0, Lcom/cmcm/support/base/KLog;->mContext:Landroid/content/Context;

    .line 26
    return-void
.end method

.method public Log(ZLjava/lang/String;Ljava/lang/String;)V
    .registers 7

    .prologue
    .line 29
    iget-boolean v0, p0, Lcom/cmcm/support/base/KLog;->mbDebug:Z

    if-eqz v0, :cond_31

    .line 30
    const-string v1, "KSupport"

    new-instance v2, Ljava/lang/StringBuilder;

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

    if-eqz p1, :cond_32

    const-string v0, "ParseOK"

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

    move-result-object v0

    const-string v2, " => ["

    invoke-virtual {v0, v2}, 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, "] "

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

    move-result-object v0

    invoke-virtual {v0, p3}, 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

    invoke-static {v1, v0}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I

    .line 32
    invoke-direct {p0, p1, p2, p3}, Lcom/cmcm/support/base/KLog;->storeInfocLog(ZLjava/lang/String;Ljava/lang/String;)V

    .line 34
    :cond_31
    return-void

    .line 30
    :cond_32
    const-string v0, "ParseFailed"

    goto :goto_f
.end method