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