Logger.smali

.class public Lio/dcloud/common/adapter/util/Logger;
.super Ljava/lang/Object;


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lio/dcloud/common/adapter/util/Logger$WriteLogToSdCardThreadHandler;
    }
.end annotation


# static fields
.field public static final ANIMATION_TAG:Ljava/lang/String; = "Animation_Path"

.field public static final AUTO_POP_PUSH_TAG:Ljava/lang/String; = "Auto_Pop_Push_Path"

.field public static final Android_System_TAG:Ljava/lang/String; = "Android_System_Path"

.field public static final AppMgr_TAG:Ljava/lang/String; = "appmgr"

.field public static final AutoGC_TAG:Ljava/lang/String; = "AutoGC_Path"

.field public static final Capture_TAG:Ljava/lang/String; = "Capture_Tag"

.field protected static D:Ljava/lang/String; = "D"

.field protected static E:Ljava/lang/String; = "E"

.field private static final EXCEPTION_TAG:Ljava/lang/String; = "DCloud_Exception"

.field public static final Event_TAG:Ljava/lang/String; = "Event_Tag"

.field protected static I:Ljava/lang/String; = "I"

.field public static final LAYOUT_TAG:Ljava/lang/String; = "Layout_Path"

.field private static final LOGTAG:Ljava/lang/String; = "DCloud_LOG"

.field private static LogPath:Ljava/lang/String; = ""

.field public static final MAIN_TAG:Ljava/lang/String; = "Main_Path"

.field public static final MAP_TAG:Ljava/lang/String; = "Map_Path"

.field private static MAX_CRASH_FILE_COUNT:I = 0x3

.field private static final MSC_TAG:Ljava/lang/String; = "DCloud_"

.field private static final STREAMSDKLOGTAG:Ljava/lang/String; = "DCLOUD_STREAMSDK_LOG"

.field public static final StreamApp_TAG:Ljava/lang/String; = "stream_manager"

.field private static TIMES:J = 0x19bfcc00L

.field public static final TIMESTAMP_HH_MM_SS_SSS:Ljava/lang/String; = "HH:mm:ss.SSS"

.field public static final TIMESTAMP_YYYY_MM_DD:Ljava/lang/String; = "yyyyMMdd"

.field public static final TIMESTAMP_YYYY_MM_DD_HH_MM_SS_SSS:Ljava/lang/String; = "yyyyMMdd HH:mm:ss.SSS"

.field public static final VIEW_VISIBLE_TAG:Ljava/lang/String; = "View_Visible_Path"

.field protected static W:Ljava/lang/String; = "W"

.field private static isHasDevFile:Z = false

.field private static isOpen:Z = true

.field private static isStoreLog:Z = false

.field private static mLogFile:Ljava/io/File; = null

.field private static mSimpleDateFormatCache:Ljava/util/HashMap; = null
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/HashMap<",
            "Ljava/lang/String;",
            "Ljava/text/SimpleDateFormat;",
            ">;"
        }
    .end annotation
.end field

.field private static mWriteLogToSdCardThread:Landroid/os/HandlerThread; = null

.field private static mWriteLogToSdCardThreadHandler:Lio/dcloud/common/adapter/util/Logger$WriteLogToSdCardThreadHandler; = null

.field static pkg:Ljava/lang/String; = ""


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

    return-void
.end method

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

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

    return-void
.end method

.method private static WriteExceptionToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .registers 9

    if-eqz p3, :cond_41

    .line 1
    invoke-virtual {p3}, Ljava/lang/Object;->getClass()Ljava/lang/Class;

    move-result-object v0

    .line 2
    invoke-virtual {v0}, Ljava/lang/Class;->getName()Ljava/lang/String;

    move-result-object v0

    const-string v1, "DCloud_Exception"

    .line 3
    invoke-static {p0, v1, v0}, Lio/dcloud/common/adapter/util/Logger;->generateLog(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    .line 5
    invoke-static {p0, p1, v0}, Lio/dcloud/common/adapter/util/Logger;->WriteLogToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    .line 6
    invoke-virtual {p3}, Ljava/lang/Throwable;->getStackTrace()[Ljava/lang/StackTraceElement;

    move-result-object p3

    if-eqz p3, :cond_41

    .line 8
    invoke-static {p0, p1, p2}, Lio/dcloud/common/adapter/util/Logger;->WriteLogToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    const/4 p2, 0x0

    .line 9
    array-length v0, p3

    :goto_1e
    if-ge p2, v0, :cond_41

    .line 11
    aget-object v2, p3, p2

    .line 12
    new-instance v3, Ljava/lang/StringBuilder;

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

    const-string v4, "    at "

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

    invoke-virtual {v2}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;

    move-result-object v2

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

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

    move-result-object v2

    .line 13
    invoke-static {p0, v1, v2}, Lio/dcloud/common/adapter/util/Logger;->generateLog(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;

    move-result-object v2

    .line 14
    invoke-static {p0, p1, v2}, Lio/dcloud/common/adapter/util/Logger;->WriteLogToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    add-int/lit8 p2, p2, 0x1

    goto :goto_1e

    :cond_41
    return-void
.end method

.method private static WriteLogToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
    .registers 6

    .line 1
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    if-nez v0, :cond_5

    return-void

    .line 2
    :cond_5
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->mLogFile:Ljava/io/File;

    if-eqz v0, :cond_32

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

    move-result v0

    if-nez v0, :cond_10

    goto :goto_32

    .line 5
    :cond_10
    invoke-static {}, Lio/dcloud/common/adapter/util/Logger;->initWriteLogToSdCardThread()V

    .line 6
    invoke-static {}, Landroid/os/Message;->obtain()Landroid/os/Message;

    move-result-object v0

    const/4 v1, 0x3

    new-array v1, v1, [Ljava/lang/String;

    const/4 v2, 0x0

    aput-object p0, v1, v2

    const/4 p0, 0x1

    aput-object p1, v1, p0

    const/4 p0, 0x2

    aput-object p2, v1, p0

    .line 7
    iput-object v1, v0, Landroid/os/Message;->obj:Ljava/lang/Object;

    .line 8
    sget-object p0, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThreadHandler:Lio/dcloud/common/adapter/util/Logger$WriteLogToSdCardThreadHandler;

    invoke-static {p0}, Lio/dcloud/common/util/PdrUtil;->isEmpty(Ljava/lang/Object;)Z

    move-result p0

    if-nez p0, :cond_32

    .line 9
    sget-object p0, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThreadHandler:Lio/dcloud/common/adapter/util/Logger$WriteLogToSdCardThreadHandler;

    invoke-virtual {p0, v0}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    :cond_32
    :goto_32
    return-void
.end method

.method static synthetic access$000()I
    .registers 1

    .line 1
    sget v0, Lio/dcloud/common/adapter/util/Logger;->MAX_CRASH_FILE_COUNT:I

    return v0
.end method

.method static synthetic access$100()Ljava/io/File;
    .registers 1

    .line 1
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->mLogFile:Ljava/io/File;

    return-object v0
.end method

.method public static canStoreLogToSDcard()Z
    .registers 2

    .line 1
    invoke-static {}, Lio/dcloud/common/adapter/util/Logger;->isSDcardExists()Z

    move-result v0

    if-eqz v0, :cond_2a

    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    if-eqz v0, :cond_2a

    .line 3
    new-instance v0, Ljava/io/File;

    sget-object v1, Lio/dcloud/common/adapter/util/Logger;->LogPath:Ljava/lang/String;

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

    .line 4
    invoke-virtual {v0}, Ljava/io/File;->exists()Z

    move-result v1

    if-nez v1, :cond_18

    goto :goto_1b

    .line 8
    :cond_18
    invoke-static {v0}, Lio/dcloud/common/adapter/util/Logger;->deleteOldLog(Ljava/io/File;)V

    .line 10
    :goto_1b
    invoke-virtual {v0}, Ljava/io/File;->exists()Z

    move-result v1

    if-eqz v1, :cond_2a

    invoke-virtual {v0}, Ljava/io/File;->canWrite()Z

    move-result v0

    if-eqz v0, :cond_2a

    const/4 v0, 0x1

    .line 11
    sput-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isStoreLog:Z

    .line 14
    :cond_2a
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isStoreLog:Z

    return v0
.end method

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

    if-eqz p0, :cond_1d

    if-eqz p1, :cond_1d

    .line 1
    invoke-virtual {p0}, Ljava/lang/String;->length()I

    move-result v0

    invoke-virtual {p1}, Ljava/lang/String;->length()I

    move-result v1

    add-int/2addr v0, v1

    .line 2
    new-instance v1, Ljava/lang/StringBuffer;

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

    .line 3
    invoke-virtual {v1, p0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;

    invoke-virtual {v1, p1}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;

    .line 4
    invoke-virtual {v1}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;

    move-result-object p0

    goto :goto_1e

    :cond_1d
    const/4 p0, 0x0

    :goto_1e
    return-object p0
.end method

.method public static d(Ljava/lang/String;)V
    .registers 2

    const-string v0, "DCloud_LOG"

    .line 21
    invoke-static {v0, p0}, Lio/dcloud/common/adapter/util/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method public static d(Ljava/lang/String;Ljava/lang/String;)V
    .registers 3

    .line 1
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    if-eqz v0, :cond_14

    .line 2
    sget-boolean v0, Lio/dcloud/common/util/BaseInfo;->ISDEBUG:Z

    if-nez v0, :cond_c

    .line 3
    invoke-static {p0, p1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_f

    .line 5
    :cond_c
    invoke-static {p0, p1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 7
    :goto_f
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->D:Ljava/lang/String;

    invoke-static {v0, p0, p1}, Lio/dcloud/common/adapter/util/Logger;->WriteLogToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    :cond_14
    return-void
.end method

.method public static varargs d(Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 6

    .line 8
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    if-eqz v0, :cond_38

    .line 9
    new-instance v0, Ljava/lang/StringBuffer;

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

    if-eqz p1, :cond_1c

    .line 11
    array-length v1, p1

    const/4 v2, 0x0

    :goto_d
    if-ge v2, v1, :cond_1c

    aget-object v3, p1, v2

    .line 12
    invoke-virtual {v0, v3}, Ljava/lang/StringBuffer;->append(Ljava/lang/Object;)Ljava/lang/StringBuffer;

    const-string v3, ";"

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

    add-int/lit8 v2, v2, 0x1

    goto :goto_d

    .line 15
    :cond_1c
    sget-boolean p1, Lio/dcloud/common/util/BaseInfo;->ISDEBUG:Z

    if-nez p1, :cond_28

    .line 16
    invoke-virtual {v0}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;

    move-result-object p1

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

    goto :goto_2f

    .line 18
    :cond_28
    invoke-virtual {v0}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;

    move-result-object p1

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

    .line 20
    :goto_2f
    sget-object p1, Lio/dcloud/common/adapter/util/Logger;->D:Ljava/lang/String;

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

    move-result-object v0

    invoke-static {p1, p0, v0}, Lio/dcloud/common/adapter/util/Logger;->WriteLogToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    :cond_38
    return-void
.end method

.method protected static deleteOldLog(Ljava/io/File;)V
    .registers 11

    .line 1
    invoke-virtual {p0}, Ljava/io/File;->listFiles()[Ljava/io/File;

    move-result-object p0

    .line 2
    new-instance v0, Ljava/util/Date;

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

    if-eqz p0, :cond_47

    .line 4
    array-length v1, p0

    const/4 v2, 0x0

    move v3, v2

    :goto_e
    if-ge v3, v1, :cond_47

    aget-object v4, p0, v3

    .line 5
    invoke-virtual {v4}, Ljava/io/File;->isDirectory()Z

    move-result v5

    if-nez v5, :cond_44

    .line 6
    invoke-virtual {v4}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v5

    const/16 v6, 0x8

    invoke-virtual {v5, v2, v6}, Ljava/lang/String;->substring(II)Ljava/lang/String;

    move-result-object v5

    .line 7
    new-instance v6, Ljava/text/SimpleDateFormat;

    const-string v7, "yyyyMMdd"

    invoke-direct {v6, v7}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;)V

    .line 9
    :try_start_29
    invoke-virtual {v6, v5}, Ljava/text/SimpleDateFormat;->parse(Ljava/lang/String;)Ljava/util/Date;

    move-result-object v5

    .line 10
    invoke-virtual {v0}, Ljava/util/Date;->getTime()J

    move-result-wide v6

    invoke-virtual {v5}, Ljava/util/Date;->getTime()J

    move-result-wide v8

    sub-long/2addr v6, v8

    sget-wide v8, Lio/dcloud/common/adapter/util/Logger;->TIMES:J

    cmp-long v5, v6, v8

    if-lez v5, :cond_44

    .line 11
    invoke-virtual {v4}, Ljava/io/File;->delete()Z
    :try_end_3f
    .catch Ljava/text/ParseException; {:try_start_29 .. :try_end_3f} :catch_40

    goto :goto_44

    :catch_40
    move-exception v4

    .line 14
    invoke-virtual {v4}, Ljava/text/ParseException;->printStackTrace()V

    :cond_44
    :goto_44
    add-int/lit8 v3, v3, 0x1

    goto :goto_e

    :cond_47
    return-void
.end method

.method public static e(Ljava/lang/String;)V
    .registers 2

    const-string v0, "DCloud_LOG"

    .line 4
    invoke-static {v0, p0}, Lio/dcloud/common/adapter/util/Logger;->e(Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method public static e(Ljava/lang/String;Ljava/lang/String;)V
    .registers 3

    .line 1
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    if-eqz v0, :cond_c

    .line 2
    invoke-static {p0, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 3
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->E:Ljava/lang/String;

    invoke-static {v0, p0, p1}, Lio/dcloud/common/adapter/util/Logger;->WriteLogToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    :cond_c
    return-void
.end method

.method public static es(Ljava/lang/String;)V
    .registers 2

    .line 4
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    if-eqz v0, :cond_9

    const-string v0, "DCLOUD_STREAMSDK_LOG"

    .line 5
    invoke-static {v0, p0}, Lio/dcloud/common/adapter/util/Logger;->es(Ljava/lang/String;Ljava/lang/String;)V

    :cond_9
    return-void
.end method

.method public static es(Ljava/lang/String;Ljava/lang/String;)V
    .registers 3

    .line 1
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    if-eqz v0, :cond_c

    .line 2
    invoke-static {p0, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 3
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->E:Ljava/lang/String;

    invoke-static {v0, p0, p1}, Lio/dcloud/common/adapter/util/Logger;->WriteLogToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    :cond_c
    return-void
.end method

.method protected static generateLog(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
    .registers 5

    .line 1
    new-instance v0, Ljava/lang/StringBuffer;

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

    .line 2
    sget-object v1, Ljava/lang/Boolean;->TRUE:Ljava/lang/Boolean;

    invoke-static {v1}, Lio/dcloud/common/adapter/util/Logger;->generateTimeStamp(Ljava/lang/Boolean;)Ljava/lang/String;

    move-result-object v1

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

    const-string v1, " "

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

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

    .line 3
    invoke-virtual {v0, v1}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;

    const-string p0, "-"

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

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

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

    .line 4
    invoke-virtual {v0, v1}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;

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

    const-string p0, "\n"

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

    .line 5
    invoke-virtual {v0}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;

    move-result-object p0

    return-object p0
.end method

.method public static generateTimeStamp(Ljava/lang/Boolean;)Ljava/lang/String;
    .registers 2

    .line 1
    invoke-virtual {p0}, Ljava/lang/Boolean;->booleanValue()Z

    move-result p0

    if-eqz p0, :cond_9

    const-string p0, "HH:mm:ss.SSS"

    goto :goto_b

    :cond_9
    const-string p0, "yyyyMMdd"

    .line 8
    :goto_b
    new-instance v0, Ljava/util/Date;

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

    invoke-static {p0, v0}, Lio/dcloud/common/adapter/util/Logger;->generateTimeStamp(Ljava/lang/String;Ljava/util/Date;)Ljava/lang/String;

    move-result-object p0

    return-object p0
.end method

.method public static generateTimeStamp(Ljava/lang/String;Ljava/util/Date;)Ljava/lang/String;
    .registers 3

    .line 9
    invoke-static {p0}, Lio/dcloud/common/adapter/util/Logger;->getDateFormatFromCache(Ljava/lang/String;)Ljava/text/SimpleDateFormat;

    move-result-object v0

    .line 10
    invoke-virtual {v0, p0}, Ljava/text/SimpleDateFormat;->applyPattern(Ljava/lang/String;)V

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

    move-result-object p0

    return-object p0
.end method

.method private static getDateFormatFromCache(Ljava/lang/String;)Ljava/text/SimpleDateFormat;
    .registers 3

    .line 1
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->mSimpleDateFormatCache:Ljava/util/HashMap;

    if-nez v0, :cond_b

    .line 2
    new-instance v0, Ljava/util/HashMap;

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

    sput-object v0, Lio/dcloud/common/adapter/util/Logger;->mSimpleDateFormatCache:Ljava/util/HashMap;

    .line 5
    :cond_b
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->mSimpleDateFormatCache:Ljava/util/HashMap;

    invoke-virtual {v0, p0}, Ljava/util/HashMap;->containsKey(Ljava/lang/Object;)Z

    move-result v0

    if-nez v0, :cond_20

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

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

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

    .line 7
    sget-object v1, Lio/dcloud/common/adapter/util/Logger;->mSimpleDateFormatCache:Ljava/util/HashMap;

    invoke-virtual {v1, p0, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    goto :goto_29

    .line 9
    :cond_20
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->mSimpleDateFormatCache:Ljava/util/HashMap;

    invoke-virtual {v0, p0}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p0

    move-object v0, p0

    check-cast v0, Ljava/text/SimpleDateFormat;

    :goto_29
    return-object v0
.end method

.method public static i(Ljava/lang/String;)V
    .registers 2

    const-string v0, "DCloud_LOG"

    .line 4
    invoke-static {v0, p0}, Lio/dcloud/common/adapter/util/Logger;->i(Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method public static i(Ljava/lang/String;Ljava/lang/String;)V
    .registers 3

    .line 1
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    if-eqz v0, :cond_e

    if-eqz p1, :cond_e

    .line 2
    invoke-static {p0, p1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I

    .line 3
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->I:Ljava/lang/String;

    invoke-static {v0, p0, p1}, Lio/dcloud/common/adapter/util/Logger;->WriteLogToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    :cond_e
    return-void
.end method

.method private static init(Ljava/lang/String;Ljava/lang/String;)V
    .registers 4

    .line 1
    :try_start_0
    invoke-static {}, Lio/dcloud/common/util/ThreadPool;->self()Lio/dcloud/common/util/ThreadPool;

    move-result-object v0

    new-instance v1, Lio/dcloud/common/adapter/util/Logger$1;

    invoke-direct {v1, p0, p1}, Lio/dcloud/common/adapter/util/Logger$1;-><init>(Ljava/lang/String;Ljava/lang/String;)V

    invoke-virtual {v0, v1}, Lio/dcloud/common/util/ThreadPool;->addThreadTask(Ljava/lang/Runnable;)V
    :try_end_c
    .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_c} :catch_d

    goto :goto_11

    :catch_d
    move-exception p0

    .line 25
    invoke-virtual {p0}, Ljava/lang/Exception;->printStackTrace()V

    :goto_11
    return-void
.end method

.method public static initLogger(Landroid/content/Context;)V
    .registers 3

    .line 1
    invoke-virtual {p0}, Landroid/content/Context;->getPackageName()Ljava/lang/String;

    move-result-object v0

    sput-object v0, Lio/dcloud/common/adapter/util/Logger;->pkg:Ljava/lang/String;

    .line 2
    invoke-static {}, Lio/dcloud/common/adapter/io/DHFile;->hasFile()Z

    move-result v0

    sput-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isHasDevFile:Z

    .line 3
    invoke-static {p0}, Lio/dcloud/common/util/BaseInfo;->isBase(Landroid/content/Context;)Z

    move-result v0

    if-nez v0, :cond_19

    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isHasDevFile:Z

    if-eqz v0, :cond_17

    goto :goto_19

    :cond_17
    const/4 v0, 0x0

    goto :goto_1a

    :cond_19
    :goto_19
    const/4 v0, 0x1

    :goto_1a
    sput-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    .line 4
    sget-boolean v1, Lio/dcloud/common/util/BaseInfo;->ISDEBUG:Z

    or-int/2addr v0, v1

    sput-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

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

    move-result-object v0

    const-string v1, "mounted"

    .line 7
    invoke-virtual {v1, v0}, Ljava/lang/String;->equalsIgnoreCase(Ljava/lang/String;)Z

    move-result v0

    if-eqz v0, :cond_33

    .line 9
    invoke-static {p0}, Lio/dcloud/common/util/BaseInfo;->getCrashLogsPath(Landroid/content/Context;)Ljava/lang/String;

    move-result-object p0

    sput-object p0, Lio/dcloud/common/adapter/util/Logger;->LogPath:Ljava/lang/String;

    .line 11
    :cond_33
    sget-boolean p0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    if-eqz p0, :cond_55

    .line 12
    sget-object p0, Lio/dcloud/common/adapter/util/Logger;->LogPath:Ljava/lang/String;

    const-string v0, "crash"

    invoke-static {p0, v0}, Lio/dcloud/common/adapter/util/Logger;->init(Ljava/lang/String;Ljava/lang/String;)V

    .line 13
    new-instance p0, Ljava/lang/StringBuilder;

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

    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->LogPath:Ljava/lang/String;

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

    const-string v0, "crash/"

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

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

    move-result-object p0

    const/4 v0, 0x0

    invoke-static {p0, v0}, Lio/dcloud/common/adapter/util/Logger;->init(Ljava/lang/String;Ljava/lang/String;)V

    .line 15
    :cond_55
    sget-boolean p0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    invoke-static {p0}, Lio/dcloud/common/adapter/util/Logger;->setOpen(Z)V

    return-void
.end method

.method private static initWriteLogToSdCardThread()V
    .registers 2

    .line 1
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThread:Landroid/os/HandlerThread;

    if-nez v0, :cond_1d

    .line 2
    new-instance v0, Landroid/os/HandlerThread;

    const-string v1, "WriteLogToSdCardThread"

    invoke-direct {v0, v1}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V

    sput-object v0, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThread:Landroid/os/HandlerThread;

    .line 3
    invoke-virtual {v0}, Landroid/os/HandlerThread;->start()V

    .line 4
    new-instance v0, Lio/dcloud/common/adapter/util/Logger$WriteLogToSdCardThreadHandler;

    sget-object v1, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThread:Landroid/os/HandlerThread;

    invoke-virtual {v1}, Landroid/os/HandlerThread;->getLooper()Landroid/os/Looper;

    move-result-object v1

    invoke-direct {v0, v1}, Lio/dcloud/common/adapter/util/Logger$WriteLogToSdCardThreadHandler;-><init>(Landroid/os/Looper;)V

    sput-object v0, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThreadHandler:Lio/dcloud/common/adapter/util/Logger$WriteLogToSdCardThreadHandler;

    :cond_1d
    return-void
.end method

.method public static isOpen()Z
    .registers 1

    .line 1
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    return v0
.end method

.method protected static isSDcardExists()Z
    .registers 2

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

    move-result-object v0

    const-string v1, "mounted"

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

    move-result v0

    return v0
.end method

.method public static isTurnOn()Z
    .registers 1

    .line 1
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isStoreLog:Z

    return v0
.end method

.method public static p(Ljava/lang/String;)V
    .registers 2

    const-string v0, "DCloud_LOG"

    .line 2
    invoke-static {v0, p0}, Lio/dcloud/common/adapter/util/Logger;->privacyLog(Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method public static p(Ljava/lang/String;Ljava/lang/String;)V
    .registers 2

    .line 1
    invoke-static {p0, p1}, Lio/dcloud/common/adapter/util/Logger;->privacyLog(Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method private static privacyLog(Ljava/lang/String;Ljava/lang/String;)V
    .registers 3

    .line 1
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isHasDevFile:Z

    if-eqz v0, :cond_7

    .line 2
    invoke-static {p0, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    :cond_7
    return-void
.end method

.method public static setOpen(Z)V
    .registers 1

    .line 1
    sput-boolean p0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    if-eqz p0, :cond_a

    .line 5
    invoke-static {}, Lio/dcloud/common/adapter/util/Logger;->canStoreLogToSDcard()Z

    .line 6
    invoke-static {}, Lio/dcloud/common/adapter/util/Logger;->storeLogToSDcard()V

    :cond_a
    return-void
.end method

.method public static stopWriteLogToSdCardThread()V
    .registers 3

    .line 1
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThread:Landroid/os/HandlerThread;

    if-eqz v0, :cond_21

    .line 2
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThreadHandler:Lio/dcloud/common/adapter/util/Logger$WriteLogToSdCardThreadHandler;

    const/4 v1, 0x0

    if-eqz v0, :cond_c

    .line 3
    invoke-virtual {v0, v1}, Landroid/os/Handler;->removeCallbacksAndMessages(Ljava/lang/Object;)V

    .line 5
    :cond_c
    sput-object v1, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThreadHandler:Lio/dcloud/common/adapter/util/Logger$WriteLogToSdCardThreadHandler;

    .line 6
    sget v0, Landroid/os/Build$VERSION;->SDK_INT:I

    const/16 v2, 0x12

    if-lt v0, v2, :cond_1a

    .line 7
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThread:Landroid/os/HandlerThread;

    invoke-virtual {v0}, Landroid/os/HandlerThread;->quitSafely()Z

    goto :goto_1f

    .line 9
    :cond_1a
    sget-object v0, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThread:Landroid/os/HandlerThread;

    invoke-virtual {v0}, Landroid/os/HandlerThread;->quit()Z

    .line 11
    :goto_1f
    sput-object v1, Lio/dcloud/common/adapter/util/Logger;->mWriteLogToSdCardThread:Landroid/os/HandlerThread;

    :cond_21
    return-void
.end method

.method public static storeLogToSDcard()V
    .registers 3

    .line 1
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isStoreLog:Z

    if-eqz v0, :cond_62

    .line 3
    new-instance v0, Ljava/lang/StringBuffer;

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

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

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

    sget-object v2, Ljava/lang/Boolean;->FALSE:Ljava/lang/Boolean;

    invoke-static {v2}, Lio/dcloud/common/adapter/util/Logger;->generateTimeStamp(Ljava/lang/Boolean;)Ljava/lang/String;

    move-result-object v2

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

    const-string v2, ".log"

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

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

    move-result-object v1

    .line 5
    sget-object v2, Lio/dcloud/common/adapter/util/Logger;->LogPath:Ljava/lang/String;

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

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

    .line 6
    new-instance v1, Ljava/io/File;

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

    move-result-object v2

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

    sput-object v1, Lio/dcloud/common/adapter/util/Logger;->mLogFile:Ljava/io/File;

    .line 7
    invoke-virtual {v1}, Ljava/io/File;->exists()Z

    move-result v1

    if-nez v1, :cond_46

    .line 9
    :try_start_39
    sget-object v1, Lio/dcloud/common/adapter/util/Logger;->mLogFile:Ljava/io/File;

    invoke-virtual {v1}, Ljava/io/File;->createNewFile()Z
    :try_end_3e
    .catch Ljava/io/IOException; {:try_start_39 .. :try_end_3e} :catch_3f

    goto :goto_46

    :catch_3f
    move-exception v1

    const/4 v2, 0x0

    .line 11
    sput-object v2, Lio/dcloud/common/adapter/util/Logger;->mLogFile:Ljava/io/File;

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

    .line 15
    :cond_46
    :goto_46
    new-instance v1, Ljava/lang/StringBuilder;

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

    const-string v2, "path="

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

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

    move-result-object v0

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

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

    move-result-object v0

    const-string v1, "\u65e5\u5fd7\u8def\u5f84:"

    const-string v2, "Logger"

    invoke-static {v1, v2, v0}, Lio/dcloud/common/adapter/util/Logger;->WriteLogToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    :cond_62
    return-void
.end method

.method public static turnOff()V
    .registers 1

    const/4 v0, 0x0

    .line 1
    sput-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isStoreLog:Z

    return-void
.end method

.method public static w(Ljava/lang/String;Ljava/lang/Throwable;)V
    .registers 4

    .line 1
    sget-boolean v0, Lio/dcloud/common/adapter/util/Logger;->isOpen:Z

    if-eqz v0, :cond_13

    if-eqz p1, :cond_9

    .line 3
    invoke-virtual {p1}, Ljava/lang/Throwable;->printStackTrace()V

    :cond_9
    const-string v0, "DCloud_Exception"

    .line 4
    invoke-static {v0, p0, p1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I

    .line 5
    sget-object v1, Lio/dcloud/common/adapter/util/Logger;->W:Ljava/lang/String;

    invoke-static {v1, v0, p0, p1}, Lio/dcloud/common/adapter/util/Logger;->WriteExceptionToSDcard(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    :cond_13
    return-void
.end method

.method public static w(Ljava/lang/Throwable;)V
    .registers 2

    const-string v0, ""

    .line 6
    invoke-static {v0, p0}, Lio/dcloud/common/adapter/util/Logger;->w(Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method