XLogger.smali

.class Lsg/bigo/log/XLogger;
.super Ljava/lang/Object;
.source "SourceFile"

# interfaces
.implements Ljava/lang/Runnable;
.implements Lsg/bigo/log/Logger;


# static fields
.field private static final TAG:Ljava/lang/String; = "LogConfig"

.field private static final TAG_FOR_ALL:Ljava/lang/String; = "yysdk"

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

.field private static final XLOG_LEVEL:Landroid/util/SparseIntArray;

.field private static volatile sCacheDir:Ljava/lang/String; = null

.field private static volatile sHasChecked:Z = false

.field private static final sLock:Ljava/lang/Object;

.field private static volatile sLogDir:Ljava/lang/String; = null

.field private static volatile sSoHasReady:Z = false

.field private static volatile sSoLoaded:Z = true

.field private static volatile sXLogger:Lsg/bigo/log/XLogger;


# instance fields
.field private mLogLevel:I

.field private mQueue:Ljava/util/concurrent/LinkedBlockingQueue;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/LinkedBlockingQueue<",
            "Lsg/bigo/log/LogEvent;",
            ">;"
        }
    .end annotation
.end field

.field private mThread:Ljava/lang/Thread;


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

    .line 55
    new-instance v0, Landroid/util/SparseIntArray;

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

    .line 56
    sput-object v0, Lsg/bigo/log/XLogger;->XLOG_LEVEL:Landroid/util/SparseIntArray;

    const/4 v1, 0x2

    const/4 v2, 0x0

    invoke-virtual {v0, v1, v2}, Landroid/util/SparseIntArray;->put(II)V

    .line 57
    sget-object v0, Lsg/bigo/log/XLogger;->XLOG_LEVEL:Landroid/util/SparseIntArray;

    const/4 v3, 0x3

    const/4 v4, 0x1

    invoke-virtual {v0, v3, v4}, Landroid/util/SparseIntArray;->put(II)V

    .line 58
    sget-object v0, Lsg/bigo/log/XLogger;->XLOG_LEVEL:Landroid/util/SparseIntArray;

    const/4 v4, 0x4

    invoke-virtual {v0, v4, v1}, Landroid/util/SparseIntArray;->put(II)V

    .line 59
    sget-object v0, Lsg/bigo/log/XLogger;->XLOG_LEVEL:Landroid/util/SparseIntArray;

    const/4 v1, 0x5

    invoke-virtual {v0, v1, v3}, Landroid/util/SparseIntArray;->put(II)V

    .line 60
    sget-object v0, Lsg/bigo/log/XLogger;->XLOG_LEVEL:Landroid/util/SparseIntArray;

    const/4 v1, 0x6

    invoke-virtual {v0, v1, v4}, Landroid/util/SparseIntArray;->put(II)V

    .line 207
    sput-boolean v2, Lsg/bigo/log/XLogger;->sHasChecked:Z

    .line 208
    sput-boolean v2, Lsg/bigo/log/XLogger;->sSoHasReady:Z

    .line 215
    new-instance v0, Ljava/lang/Object;

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

    sput-object v0, Lsg/bigo/log/XLogger;->sLock:Ljava/lang/Object;

    return-void
.end method

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

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

    const/4 v0, 0x2

    .line 31
    iput v0, p0, Lsg/bigo/log/XLogger;->mLogLevel:I

    .line 51
    new-instance v0, Ljava/util/concurrent/LinkedBlockingQueue;

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

    iput-object v0, p0, Lsg/bigo/log/XLogger;->mQueue:Ljava/util/concurrent/LinkedBlockingQueue;

    return-void
.end method

.method private appenderOpen(IILjava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
    .registers 13

    const-string v0, "yysdk"

    const/4 v1, 0x2

    if-lt p1, v1, :cond_30

    const/4 v1, 0x6

    if-gt p1, v1, :cond_30

    .line 140
    sget-boolean v1, Lsg/bigo/log/XLogger;->sSoLoaded:Z

    if-eqz v1, :cond_30

    invoke-static {}, Lsg/bigo/log/XLogger;->ensureSoReady()Z

    move-result v1

    if-eqz v1, :cond_30

    .line 141
    invoke-static {p1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v1

    const-string v2, "set log level->"

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

    move-result-object v1

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

    .line 142
    iput p1, p0, Lsg/bigo/log/XLogger;->mLogLevel:I

    .line 143
    sget-object v0, Lsg/bigo/log/XLogger;->XLOG_LEVEL:Landroid/util/SparseIntArray;

    invoke-virtual {v0, p1}, Landroid/util/SparseIntArray;->get(I)I

    move-result v1

    const/4 v6, 0x0

    move v2, p2

    move-object v3, p3

    move-object v4, p4

    move-object v5, p5

    invoke-static/range {v1 .. v6}, Lcom/tencent/mars/xlog/Xlog;->appenderOpen(IILjava/lang/String;Ljava/lang/String;Ljava/lang/String;I)V

    return-void

    .line 145
    :cond_30
    invoke-static {p1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object p1

    const-string p2, "invalid log level->"

    invoke-virtual {p2, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p1

    invoke-virtual {p0, v0, p1}, Lsg/bigo/log/XLogger;->e(Ljava/lang/String;Ljava/lang/String;)I

    return-void
.end method

.method private doAppend(ILjava/lang/String;Ljava/lang/String;)V
    .registers 4

    .line 268
    invoke-static {p1, p2, p3}, Lsg/bigo/log/LogEvent;->obtain(ILjava/lang/String;Ljava/lang/String;)Lsg/bigo/log/LogEvent;

    move-result-object p1

    .line 269
    iget-object p2, p0, Lsg/bigo/log/XLogger;->mQueue:Ljava/util/concurrent/LinkedBlockingQueue;

    invoke-virtual {p2, p1}, Ljava/util/concurrent/LinkedBlockingQueue;->offer(Ljava/lang/Object;)Z

    return-void
.end method

.method private static ensureSoReady()Z
    .registers 4

    .line 218
    sget-boolean v0, Lsg/bigo/log/XLogger;->sHasChecked:Z

    if-nez v0, :cond_4d

    .line 219
    sget-object v0, Lsg/bigo/log/XLogger;->sLock:Ljava/lang/Object;

    monitor-enter v0

    .line 220
    :try_start_7
    sget-boolean v1, Lsg/bigo/log/XLogger;->sHasChecked:Z
    :try_end_9
    .catchall {:try_start_7 .. :try_end_9} :catchall_4a

    if-nez v1, :cond_48

    const/4 v1, 0x1

    :try_start_c
    const-string v2, "t"

    const-string v3, "t"

    .line 222
    invoke-static {v2, v3}, Lcom/tencent/mars/xlog/Log;->i(Ljava/lang/String;Ljava/lang/String;)V

    const-string v2, "t"

    const-string v3, "t"

    .line 223
    invoke-static {v2, v3}, Lcom/tencent/mars/xlog/Log;->v(Ljava/lang/String;Ljava/lang/String;)V

    const-string v2, "t"

    const-string v3, "t"

    .line 224
    invoke-static {v2, v3}, Lcom/tencent/mars/xlog/Log;->w(Ljava/lang/String;Ljava/lang/String;)V

    const-string v2, "t"

    const-string v3, "t"

    .line 225
    invoke-static {v2, v3}, Lcom/tencent/mars/xlog/Log;->e(Ljava/lang/String;Ljava/lang/String;)V

    const-string v2, "t"

    const-string v3, "t"

    .line 226
    invoke-static {v2, v3}, Lcom/tencent/mars/xlog/Log;->d(Ljava/lang/String;Ljava/lang/String;)V

    const-string v2, "t"

    const-string v3, "t"

    .line 227
    invoke-static {v2, v3}, Lcom/tencent/mars/xlog/Log;->f(Ljava/lang/String;Ljava/lang/String;)V

    .line 228
    sput-boolean v1, Lsg/bigo/log/XLogger;->sSoHasReady:Z
    :try_end_38
    .catchall {:try_start_c .. :try_end_38} :catchall_3b

    .line 235
    :cond_38
    :goto_38
    :try_start_38
    sput-boolean v1, Lsg/bigo/log/XLogger;->sHasChecked:Z
    :try_end_3a
    .catchall {:try_start_38 .. :try_end_3a} :catchall_4a

    goto :goto_48

    .line 230
    :catchall_3b
    :try_start_3b
    invoke-static {}, Lsg/bigo/log/XLogger;->fixBySystemLoad()Z

    move-result v2

    if-eqz v2, :cond_38

    .line 232
    sput-boolean v1, Lsg/bigo/log/XLogger;->sSoHasReady:Z
    :try_end_43
    .catchall {:try_start_3b .. :try_end_43} :catchall_44

    goto :goto_38

    :catchall_44
    move-exception v2

    .line 235
    :try_start_45
    sput-boolean v1, Lsg/bigo/log/XLogger;->sHasChecked:Z

    throw v2

    .line 238
    :cond_48
    :goto_48
    monitor-exit v0

    goto :goto_4d

    :catchall_4a
    move-exception v1

    monitor-exit v0
    :try_end_4c
    .catchall {:try_start_45 .. :try_end_4c} :catchall_4a

    throw v1

    .line 240
    :cond_4d
    :goto_4d
    sget-boolean v0, Lsg/bigo/log/XLogger;->sSoHasReady:Z

    return v0
.end method

.method private static fixBySystemLoad()Z
    .registers 2

    const-string v0, "t"

    :try_start_2
    const-string v1, "stlport_shared"

    .line 245
    invoke-static {v1}, Lsg/bigo/common/ab;->a(Ljava/lang/String;)V

    const-string v1, "marsxlog"

    .line 246
    invoke-static {v1}, Lsg/bigo/common/ab;->a(Ljava/lang/String;)V

    .line 247
    invoke-static {v0, v0}, Lcom/tencent/mars/xlog/Log;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 248
    invoke-static {v0, v0}, Lcom/tencent/mars/xlog/Log;->v(Ljava/lang/String;Ljava/lang/String;)V

    .line 249
    invoke-static {v0, v0}, Lcom/tencent/mars/xlog/Log;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 250
    invoke-static {v0, v0}, Lcom/tencent/mars/xlog/Log;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 251
    invoke-static {v0, v0}, Lcom/tencent/mars/xlog/Log;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 252
    invoke-static {v0, v0}, Lcom/tencent/mars/xlog/Log;->f(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_1e
    .catchall {:try_start_2 .. :try_end_1e} :catchall_20

    const/4 v0, 0x1

    return v0

    :catchall_20
    const/4 v0, 0x0

    return v0
.end method

.method static getInstance()Lsg/bigo/log/XLogger;
    .registers 2

    .line 67
    sget-object v0, Lsg/bigo/log/XLogger;->sXLogger:Lsg/bigo/log/XLogger;

    if-nez v0, :cond_1a

    .line 68
    const-class v0, Lsg/bigo/log/XLogger;

    monitor-enter v0

    .line 69
    :try_start_7
    sget-object v1, Lsg/bigo/log/XLogger;->sXLogger:Lsg/bigo/log/XLogger;

    if-nez v1, :cond_15

    .line 70
    new-instance v1, Lsg/bigo/log/XLogger;

    invoke-direct {v1}, Lsg/bigo/log/XLogger;-><init>()V

    .line 71
    invoke-direct {v1}, Lsg/bigo/log/XLogger;->init()V

    .line 72
    sput-object v1, Lsg/bigo/log/XLogger;->sXLogger:Lsg/bigo/log/XLogger;

    .line 74
    :cond_15
    monitor-exit v0

    goto :goto_1a

    :catchall_17
    move-exception v1

    monitor-exit v0
    :try_end_19
    .catchall {:try_start_7 .. :try_end_19} :catchall_17

    throw v1

    .line 76
    :cond_1a
    :goto_1a
    sget-object v0, Lsg/bigo/log/XLogger;->sXLogger:Lsg/bigo/log/XLogger;

    return-object v0
.end method

.method private static getLogFileNamePrefix()Ljava/lang/String;
    .registers 2

    .line 260
    invoke-static {}, Lsg/bigo/common/r;->d()Ljava/lang/String;

    move-result-object v0

    .line 261
    invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v1

    if-eqz v1, :cond_c

    const-string v0, ""

    :cond_c
    return-object v0
.end method

.method private init()V
    .registers 5

    .line 81
    invoke-static {}, Lsg/bigo/common/a;->e()Z

    move-result v0

    if-nez v0, :cond_f

    invoke-static {}, Lsg/bigo/common/a;->g()Z

    move-result v0

    if-nez v0, :cond_d

    goto :goto_f

    :cond_d
    const/4 v0, 0x3

    goto :goto_10

    :cond_f
    :goto_f
    const/4 v0, 0x4

    .line 84
    :goto_10
    sget v1, Landroid/os/Build$VERSION;->SDK_INT:I

    const/16 v2, 0x15

    if-ge v1, v2, :cond_1e

    .line 85
    invoke-static {}, Lsg/bigo/common/a;->d()Landroid/content/Context;

    move-result-object v1

    invoke-direct {p0, v1, v0}, Lsg/bigo/log/XLogger;->init(Landroid/content/Context;I)V

    goto :goto_52

    .line 89
    :cond_1e
    :try_start_1e
    invoke-static {}, Lsg/bigo/common/a;->d()Landroid/content/Context;

    move-result-object v1

    invoke-direct {p0, v1, v0}, Lsg/bigo/log/XLogger;->init(Landroid/content/Context;I)V
    :try_end_25
    .catch Ljava/lang/UnsatisfiedLinkError; {:try_start_1e .. :try_end_25} :catch_26

    goto :goto_52

    .line 92
    :catch_26
    :try_start_26
    invoke-static {}, Lcom/getkeepsafe/relinker/b;->a()Lcom/getkeepsafe/relinker/c;

    move-result-object v1

    invoke-static {}, Lsg/bigo/common/a;->d()Landroid/content/Context;

    move-result-object v2

    const-string v3, "stlport_shared"

    .line 1092
    invoke-virtual {v1, v2, v3}, Lcom/getkeepsafe/relinker/c;->a(Landroid/content/Context;Ljava/lang/String;)V

    .line 93
    invoke-static {}, Lcom/getkeepsafe/relinker/b;->a()Lcom/getkeepsafe/relinker/c;

    move-result-object v1

    invoke-static {}, Lsg/bigo/common/a;->d()Landroid/content/Context;

    move-result-object v2

    const-string v3, "marsxlog"

    .line 2092
    invoke-virtual {v1, v2, v3}, Lcom/getkeepsafe/relinker/c;->a(Landroid/content/Context;Ljava/lang/String;)V

    .line 94
    invoke-static {}, Lsg/bigo/common/a;->d()Landroid/content/Context;

    move-result-object v1

    invoke-direct {p0, v1, v0}, Lsg/bigo/log/XLogger;->init(Landroid/content/Context;I)V
    :try_end_47
    .catchall {:try_start_26 .. :try_end_47} :catchall_48

    goto :goto_52

    :catchall_48
    move-exception v0

    .line 96
    invoke-static {v0}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;

    move-result-object v0

    const-string v1, "LogConfig"

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

    .line 101
    :goto_52
    new-instance v0, Ljava/lang/Thread;

    const-string v1, "XLOG_QUEUE"

    invoke-direct {v0, p0, v1}, Ljava/lang/Thread;-><init>(Ljava/lang/Runnable;Ljava/lang/String;)V

    iput-object v0, p0, Lsg/bigo/log/XLogger;->mThread:Ljava/lang/Thread;

    .line 102
    invoke-virtual {v0}, Ljava/lang/Thread;->start()V

    return-void
.end method

.method private init(Landroid/content/Context;I)V
    .registers 14

    if-nez p1, :cond_3

    return-void

    :cond_3
    const-string v0, "marsxlog"

    .line 109
    invoke-static {v0}, Lsg/bigo/common/ab;->a(Ljava/lang/String;)V

    const/4 v0, 0x1

    .line 110
    sput-boolean v0, Lsg/bigo/log/XLogger;->sSoLoaded:Z

    .line 112
    invoke-static {}, Lsg/bigo/common/v;->a()Ljava/lang/String;

    move-result-object v1

    .line 114
    invoke-static {}, Lsg/bigo/log/XLogger;->getLogFileNamePrefix()Ljava/lang/String;

    move-result-object v2

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

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

    const/4 v4, 0x0

    invoke-virtual {p1, v4}, Landroid/content/Context;->getExternalFilesDir(Ljava/lang/String;)Ljava/io/File;

    move-result-object v4

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

    sget-object v4, Ljava/io/File;->separator:Ljava/lang/String;

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

    const-string v4, "xlog"

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

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

    move-result-object v9

    .line 117
    sput-object v9, Lsg/bigo/log/XLogger;->sLogDir:Ljava/lang/String;

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

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

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

    move-result-object p1

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

    sget-object p1, Ljava/io/File;->separator:Ljava/lang/String;

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

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

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

    move-result-object v8

    .line 121
    sput-object v8, Lsg/bigo/log/XLogger;->sCacheDir:Ljava/lang/String;

    const-string p1, ":"

    .line 123
    invoke-virtual {v1, p1}, Ljava/lang/String;->indexOf(Ljava/lang/String;)I

    move-result v3

    const/4 v4, -0x1

    if-ne v3, v4, :cond_54

    goto :goto_71

    :cond_54
    new-instance v3, Ljava/lang/StringBuilder;

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

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

    const-string v2, "_"

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

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

    move-result p1

    add-int/2addr p1, v0

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

    move-result-object p1

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

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

    move-result-object v2

    :goto_71
    move-object v10, v2

    const/4 v7, 0x0

    move-object v5, p0

    move v6, p2

    .line 125
    invoke-direct/range {v5 .. v10}, Lsg/bigo/log/XLogger;->appenderOpen(IILjava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    const/4 p1, 0x0

    .line 127
    invoke-direct {p0, p1}, Lsg/bigo/log/XLogger;->setConsoleLogOpen(Z)V

    .line 129
    new-instance p1, Lcom/tencent/mars/xlog/Xlog;

    invoke-direct {p1}, Lcom/tencent/mars/xlog/Xlog;-><init>()V

    invoke-static {p1}, Lcom/tencent/mars/xlog/Log;->setLogImp(Lcom/tencent/mars/xlog/Log$LogImp;)V

    return-void
.end method

.method private setConsoleLogOpen(Z)V
    .registers 3

    .line 133
    sget-boolean v0, Lsg/bigo/log/XLogger;->sSoLoaded:Z

    if-eqz v0, :cond_d

    invoke-static {}, Lsg/bigo/log/XLogger;->ensureSoReady()Z

    move-result v0

    if-eqz v0, :cond_d

    .line 134
    invoke-static {p1}, Lcom/tencent/mars/xlog/Xlog;->setConsoleLogOpen(Z)V

    :cond_d
    return-void
.end method


# virtual methods
.method public d(Ljava/lang/String;Ljava/lang/String;)I
    .registers 4

    .line 168
    sget-boolean v0, Lsg/bigo/log/XLogger;->sSoLoaded:Z

    if-eqz v0, :cond_f

    invoke-static {}, Lsg/bigo/log/XLogger;->ensureSoReady()Z

    move-result v0

    if-eqz v0, :cond_f

    const/4 v0, 0x1

    .line 169
    invoke-direct {p0, v0, p1, p2}, Lsg/bigo/log/XLogger;->doAppend(ILjava/lang/String;Ljava/lang/String;)V

    return v0

    :cond_f
    const/4 p1, 0x0

    return p1
.end method

.method public e(Ljava/lang/String;Ljava/lang/String;)I
    .registers 4

    .line 198
    sget-boolean v0, Lsg/bigo/log/XLogger;->sSoLoaded:Z

    if-eqz v0, :cond_10

    invoke-static {}, Lsg/bigo/log/XLogger;->ensureSoReady()Z

    move-result v0

    if-eqz v0, :cond_10

    const/4 v0, 0x4

    .line 199
    invoke-direct {p0, v0, p1, p2}, Lsg/bigo/log/XLogger;->doAppend(ILjava/lang/String;Ljava/lang/String;)V

    const/4 p1, 0x1

    return p1

    :cond_10
    const/4 p1, 0x0

    return p1
.end method

.method public flush()V
    .registers 2

    .line 151
    sget-boolean v0, Lsg/bigo/log/XLogger;->sSoLoaded:Z

    if-eqz v0, :cond_e

    invoke-static {}, Lsg/bigo/log/XLogger;->ensureSoReady()Z

    move-result v0

    if-eqz v0, :cond_e

    const/4 v0, 0x1

    .line 152
    invoke-static {v0}, Lcom/tencent/mars/xlog/Log;->appenderFlush(Z)V

    :cond_e
    return-void
.end method

.method public i(Ljava/lang/String;Ljava/lang/String;)I
    .registers 4

    .line 178
    sget-boolean v0, Lsg/bigo/log/XLogger;->sSoLoaded:Z

    if-eqz v0, :cond_10

    invoke-static {}, Lsg/bigo/log/XLogger;->ensureSoReady()Z

    move-result v0

    if-eqz v0, :cond_10

    const/4 v0, 0x2

    .line 179
    invoke-direct {p0, v0, p1, p2}, Lsg/bigo/log/XLogger;->doAppend(ILjava/lang/String;Ljava/lang/String;)V

    const/4 p1, 0x1

    return p1

    :cond_10
    const/4 p1, 0x0

    return p1
.end method

.method public run()V
    .registers 6

    const-string v0, ","

    :cond_2
    :goto_2
    const/4 v1, 0x0

    .line 277
    :try_start_3
    iget-object v2, p0, Lsg/bigo/log/XLogger;->mQueue:Ljava/util/concurrent/LinkedBlockingQueue;

    invoke-virtual {v2}, Ljava/util/concurrent/LinkedBlockingQueue;->take()Ljava/lang/Object;

    move-result-object v2

    check-cast v2, Lsg/bigo/log/LogEvent;
    :try_end_b
    .catch Ljava/lang/InterruptedException; {:try_start_3 .. :try_end_b} :catch_7a
    .catchall {:try_start_3 .. :try_end_b} :catchall_73

    .line 278
    :try_start_b
    iget v1, v2, Lsg/bigo/log/LogEvent;->level:I

    if-eqz v1, :cond_61

    const/4 v3, 0x1

    if-eq v1, v3, :cond_59

    const/4 v3, 0x2

    if-eq v1, v3, :cond_51

    const/4 v3, 0x3

    if-eq v1, v3, :cond_49

    const/4 v3, 0x4

    if-ne v1, v3, :cond_23

    .line 289
    iget-object v1, v2, Lsg/bigo/log/LogEvent;->tag:Ljava/lang/String;

    iget-object v3, v2, Lsg/bigo/log/LogEvent;->message:Ljava/lang/String;

    invoke-static {v1, v3}, Lcom/tencent/mars/xlog/Log;->e(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_68

    .line 295
    :cond_23
    new-instance v1, Ljava/lang/RuntimeException;

    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "invalid event:"

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

    iget v4, v2, Lsg/bigo/log/LogEvent;->level:I

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

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

    iget-object v4, v2, Lsg/bigo/log/LogEvent;->tag:Ljava/lang/String;

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

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

    iget-object v4, v2, Lsg/bigo/log/LogEvent;->message:Ljava/lang/String;

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

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

    move-result-object v3

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

    throw v1

    .line 292
    :cond_49
    iget-object v1, v2, Lsg/bigo/log/LogEvent;->tag:Ljava/lang/String;

    iget-object v3, v2, Lsg/bigo/log/LogEvent;->message:Ljava/lang/String;

    invoke-static {v1, v3}, Lcom/tencent/mars/xlog/Log;->w(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_68

    .line 286
    :cond_51
    iget-object v1, v2, Lsg/bigo/log/LogEvent;->tag:Ljava/lang/String;

    iget-object v3, v2, Lsg/bigo/log/LogEvent;->message:Ljava/lang/String;

    invoke-static {v1, v3}, Lcom/tencent/mars/xlog/Log;->i(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_68

    .line 283
    :cond_59
    iget-object v1, v2, Lsg/bigo/log/LogEvent;->tag:Ljava/lang/String;

    iget-object v3, v2, Lsg/bigo/log/LogEvent;->message:Ljava/lang/String;

    invoke-static {v1, v3}, Lcom/tencent/mars/xlog/Log;->d(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_68

    .line 280
    :cond_61
    iget-object v1, v2, Lsg/bigo/log/LogEvent;->tag:Ljava/lang/String;

    iget-object v3, v2, Lsg/bigo/log/LogEvent;->message:Ljava/lang/String;

    invoke-static {v1, v3}, Lcom/tencent/mars/xlog/Log;->v(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_68
    .catch Ljava/lang/InterruptedException; {:try_start_b .. :try_end_68} :catch_71
    .catchall {:try_start_b .. :try_end_68} :catchall_6e

    :goto_68
    if-eqz v2, :cond_2

    .line 301
    invoke-virtual {v2}, Lsg/bigo/log/LogEvent;->recycle()V

    goto :goto_2

    :catchall_6e
    move-exception v0

    move-object v1, v2

    goto :goto_74

    :catch_71
    move-object v1, v2

    goto :goto_7b

    :catchall_73
    move-exception v0

    :goto_74
    if-eqz v1, :cond_79

    invoke-virtual {v1}, Lsg/bigo/log/LogEvent;->recycle()V

    :cond_79
    throw v0

    :catch_7a
    nop

    :goto_7b
    if-eqz v1, :cond_2

    invoke-virtual {v1}, Lsg/bigo/log/LogEvent;->recycle()V

    goto :goto_2
.end method

.method setOptions(JI)V
    .registers 7

    const-wide/16 v0, 0x0

    cmp-long v2, p1, v0

    if-lez v2, :cond_9

    .line 43
    invoke-static {p1, p2}, Lcom/tencent/mars/xlog/Xlog;->setMaxFileSize(J)V

    :cond_9
    if-lez p3, :cond_12

    .line 47
    sget-object p1, Lsg/bigo/log/XLogger;->sLogDir:Ljava/lang/String;

    sget-object p2, Lsg/bigo/log/XLogger;->sCacheDir:Ljava/lang/String;

    invoke-static {p1, p2, p3}, Lsg/bigo/log/LogFileCleaner;->tryToCleanExceedFiles(Ljava/lang/String;Ljava/lang/String;I)V

    :cond_12
    return-void
.end method

.method public v(Ljava/lang/String;Ljava/lang/String;)I
    .registers 5

    .line 158
    sget-boolean v0, Lsg/bigo/log/XLogger;->sSoLoaded:Z

    const/4 v1, 0x0

    if-eqz v0, :cond_10

    invoke-static {}, Lsg/bigo/log/XLogger;->ensureSoReady()Z

    move-result v0

    if-eqz v0, :cond_10

    .line 159
    invoke-direct {p0, v1, p1, p2}, Lsg/bigo/log/XLogger;->doAppend(ILjava/lang/String;Ljava/lang/String;)V

    const/4 p1, 0x1

    return p1

    :cond_10
    return v1
.end method

.method public w(Ljava/lang/String;Ljava/lang/String;)I
    .registers 4

    .line 188
    sget-boolean v0, Lsg/bigo/log/XLogger;->sSoLoaded:Z

    if-eqz v0, :cond_10

    invoke-static {}, Lsg/bigo/log/XLogger;->ensureSoReady()Z

    move-result v0

    if-eqz v0, :cond_10

    const/4 v0, 0x3

    .line 189
    invoke-direct {p0, v0, p1, p2}, Lsg/bigo/log/XLogger;->doAppend(ILjava/lang/String;Ljava/lang/String;)V

    const/4 p1, 0x1

    return p1

    :cond_10
    const/4 p1, 0x0

    return p1
.end method