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