KLog.smali

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


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

.field public static final debugServerUrl:Ljava/lang/String; = "http://recv.bi.ainirobot.com:8088/c/"

.field private static df:Ljava/text/SimpleDateFormat;


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

.field private mbDebug:Z


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

    new-instance v0, Ljava/text/SimpleDateFormat;

    const-string/jumbo 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

    sput-object v0, Lcom/cmcm/support/base/KLog;->df:Ljava/text/SimpleDateFormat;

    return-void
.end method

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

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

    const/4 v0, 0x0

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

    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

    const-string/jumbo 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

    const/4 v0, 0x0

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

    if-eqz v1, :cond_43

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

    move-result v1

    if-eqz v1, :cond_43

    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/jumbo 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

    new-instance v2, Ljava/io/File;

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

    if-eqz v2, :cond_4d

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

    move-result v3

    if-nez v3, :cond_4d

    if-eqz v2, :cond_44

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

    move-result v2

    if-nez v2, :cond_44

    const-string/jumbo v1, "KSupport"

    const-string/jumbo v2, "Create LogDir failed"

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

    :cond_43
    :goto_43
    return-object v0

    :cond_44
    const-string/jumbo v0, "KSupport"

    const-string/jumbo v2, "Create LogDir done"

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

    :cond_4d
    new-instance v0, Ljava/io/File;

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

    goto :goto_43
.end method

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

    const/4 v2, 0x0

    const/4 v0, 0x0

    const/4 v1, 0x0

    :try_start_3
    const-string/jumbo v3, "cmcm_support.log"

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

    move-result-object v3

    if-nez v3, :cond_1c

    if-eqz v2, :cond_11

    :try_start_e
    invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V

    :cond_11
    if-eqz v2, :cond_16

    invoke-virtual {v0}, Ljava/io/PrintWriter;->close()V
    :try_end_16
    .catch Ljava/io/IOException; {:try_start_e .. :try_end_16} :catch_17

    :cond_16
    :goto_16
    return-void

    :catch_17
    move-exception v0

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

    goto :goto_16

    :cond_1c
    :try_start_1c
    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_22
    .catch Ljava/lang/Throwable; {:try_start_1c .. :try_end_22} :catch_b4
    .catchall {:try_start_1c .. :try_end_22} :catchall_cb

    if-eqz v1, :cond_eb

    const-wide/16 v4, 0x0

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

    move-result-object v0

    new-instance v3, Ljava/io/PrintWriter;

    invoke-direct {v3, v1}, Ljava/io/PrintWriter;-><init>(Ljava/io/OutputStream;)V
    :try_end_2f
    .catch Ljava/lang/Throwable; {:try_start_26 .. :try_end_2f} :catch_e6
    .catchall {:try_start_26 .. :try_end_2f} :catchall_de

    :try_start_2f
    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

    new-instance v0, Ljava/lang/StringBuilder;

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

    const-string/jumbo 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_b0

    const-string/jumbo v0, "OK"

    :goto_56
    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

    new-instance v0, Ljava/lang/StringBuilder;

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

    const-string/jumbo 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

    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/jumbo 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

    invoke-virtual {v3}, Ljava/io/PrintWriter;->flush()V
    :try_end_9e
    .catch Ljava/lang/Throwable; {:try_start_2f .. :try_end_9e} :catch_e8
    .catchall {:try_start_2f .. :try_end_9e} :catchall_e1

    :goto_9e
    if-eqz v1, :cond_a3

    :try_start_a0
    invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V

    :cond_a3
    if-eqz v3, :cond_16

    invoke-virtual {v3}, Ljava/io/PrintWriter;->close()V
    :try_end_a8
    .catch Ljava/io/IOException; {:try_start_a0 .. :try_end_a8} :catch_aa

    goto/16 :goto_16

    :catch_aa
    move-exception v0

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

    goto/16 :goto_16

    :cond_b0
    :try_start_b0
    const-string/jumbo v0, "Failed"
    :try_end_b3
    .catch Ljava/lang/Throwable; {:try_start_b0 .. :try_end_b3} :catch_e8
    .catchall {:try_start_b0 .. :try_end_b3} :catchall_e1

    goto :goto_56

    :catch_b4
    move-exception v0

    move-object v1, v2

    :goto_b6
    :try_start_b6
    invoke-virtual {v0}, Ljava/lang/Throwable;->printStackTrace()V
    :try_end_b9
    .catchall {:try_start_b6 .. :try_end_b9} :catchall_e3

    if-eqz v1, :cond_be

    :try_start_bb
    invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V

    :cond_be
    if-eqz v2, :cond_16

    invoke-virtual {v2}, Ljava/io/PrintWriter;->close()V
    :try_end_c3
    .catch Ljava/io/IOException; {:try_start_bb .. :try_end_c3} :catch_c5

    goto/16 :goto_16

    :catch_c5
    move-exception v0

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

    goto/16 :goto_16

    :catchall_cb
    move-exception v0

    move-object v1, v2

    move-object v3, v2

    :goto_ce
    if-eqz v1, :cond_d3

    :try_start_d0
    invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V

    :cond_d3
    if-eqz v3, :cond_d8

    invoke-virtual {v3}, Ljava/io/PrintWriter;->close()V
    :try_end_d8
    .catch Ljava/io/IOException; {:try_start_d0 .. :try_end_d8} :catch_d9

    :cond_d8
    :goto_d8
    throw v0

    :catch_d9
    move-exception v1

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

    goto :goto_d8

    :catchall_de
    move-exception v0

    move-object v3, v2

    goto :goto_ce

    :catchall_e1
    move-exception v0

    goto :goto_ce

    :catchall_e3
    move-exception v0

    move-object v3, v2

    goto :goto_ce

    :catch_e6
    move-exception v0

    goto :goto_b6

    :catch_e8
    move-exception v0

    move-object v2, v3

    goto :goto_b6

    :cond_eb
    move-object v3, v2

    goto :goto_9e
.end method

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

    const-wide/16 v0, 0x0

    cmp-long v0, p0, v0

    if-lez v0, :cond_12

    sget-object v0, Lcom/cmcm/support/base/KLog;->df:Ljava/text/SimpleDateFormat;

    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

    :goto_11
    return-object v0

    :cond_12
    sget-object v0, Lcom/cmcm/support/base/KLog;->df:Ljava/text/SimpleDateFormat;

    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_11
.end method


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

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

    if-eqz v0, :cond_7

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

    :cond_7
    return-void
.end method

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

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

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

    return-void
.end method

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

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

    if-eqz v0, :cond_35

    const-string/jumbo v1, "KSupport"

    new-instance v2, Ljava/lang/StringBuilder;

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

    if-eqz p1, :cond_36

    const-string/jumbo v0, "ParseOK"

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

    move-result-object v0

    const-string/jumbo 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/jumbo 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

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

    :cond_35
    return-void

    :cond_36
    const-string/jumbo v0, "ParseFailed"

    goto :goto_11
.end method