Log.smali 
.class public Lcom/tencent/liteav/base/Log;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field public static final ASSERT:I = 0x7
.field public static final DEBUG:I = 0x3
.field public static final ERROR:I = 0x6
.field public static final INFO:I = 0x4
.field public static final VERBOSE:I = 0x2
.field public static final WARN:I = 0x5
.field private static final sDeprecatedTagPrefix:Ljava/lang/String; = "cr."
.field private static final sTagPrefix:Ljava/lang/String; = "cr_"
.field private static final useChromiumLog:Z = true
# direct methods
.method private constructor <init>()V
    .registers 1
    .line 47
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V
    return-void
.end method
.method public static varargs d(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 4
    .line 150
    invoke-static {p2}, Lcom/tencent/liteav/base/Log;->getThrowableToLog([Ljava/lang/Object;)Ljava/lang/Throwable;
    move-result-object v0
    .line 151
    invoke-static {p1, v0, p2}, Lcom/tencent/liteav/base/Log;->formatLogWithStack(Ljava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)Ljava/lang/String;
    move-result-object p1
    const/4 p2, 0x3
    .line 153
    invoke-static {p2, p0, p1}, Lcom/tencent/liteav/base/Log;->nativeWriteLogToNative(ILjava/lang/String;Ljava/lang/String;)V
    return-void
.end method
.method public static varargs e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 4
    .line 222
    invoke-static {p2}, Lcom/tencent/liteav/base/Log;->getThrowableToLog([Ljava/lang/Object;)Ljava/lang/Throwable;
    move-result-object v0
    .line 223
    invoke-static {p1, v0, p2}, Lcom/tencent/liteav/base/Log;->formatLog(Ljava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)Ljava/lang/String;
    move-result-object p1
    const/4 p2, 0x6
    .line 225
    invoke-static {p2, p0, p1}, Lcom/tencent/liteav/base/Log;->nativeWriteLogToNative(ILjava/lang/String;Ljava/lang/String;)V
    return-void
.end method
.method private static varargs formatLog(Ljava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)Ljava/lang/String;
    .registers 4
    if-eqz p2, :cond_11
    if-nez p1, :cond_7
    .line 53
    array-length p1, p2
    if-gtz p1, :cond_b
    :cond_7
    array-length p1, p2
    const/4 v0, 0x1
    if-le p1, v0, :cond_11
    .line 54
    :cond_b
    sget-object p1, Ljava/util/Locale;->US:Ljava/util/Locale;
    invoke-static {p1, p0, p2}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
    move-result-object p0
    :cond_11
    return-object p0
.end method
.method private static varargs formatLogWithStack(Ljava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)Ljava/lang/String;
    .registers 5
    .line 84
    new-instance v0, Ljava/lang/StringBuilder;
    const-string v1, "["
    invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
    invoke-static {}, Lcom/tencent/liteav/base/Log;->getCallOrigin()Ljava/lang/String;
    move-result-object v1
    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    const-string v1, "] "
    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-static {p0, p1, p2}, Lcom/tencent/liteav/base/Log;->formatLog(Ljava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)Ljava/lang/String;
    move-result-object p0
    invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p0
    return-object p0
.end method
.method private static getCallOrigin()Ljava/lang/String;
    .registers 4
    .line 280
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
    move-result-object v0
    invoke-virtual {v0}, Ljava/lang/Thread;->getStackTrace()[Ljava/lang/StackTraceElement;
    move-result-object v0
    .line 290
    const-class v1, Lcom/tencent/liteav/base/Log;
    invoke-virtual {v1}, Ljava/lang/Class;->getName()Ljava/lang/String;
    move-result-object v1
    const/4 v2, 0x0
    .line 291
    :goto_f
    array-length v3, v0
    if-ge v2, v3, :cond_24
    .line 292
    aget-object v3, v0, v2
    invoke-virtual {v3}, Ljava/lang/StackTraceElement;->getClassName()Ljava/lang/String;
    move-result-object v3
    invoke-virtual {v3, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
    move-result v3
    if-eqz v3, :cond_21
    add-int/lit8 v2, v2, 0x3
    goto :goto_24
    :cond_21
    add-int/lit8 v2, v2, 0x1
    goto :goto_f
    .line 298
    :cond_24
    :goto_24
    new-instance v1, Ljava/lang/StringBuilder;
    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
    aget-object v3, v0, v2
    invoke-virtual {v3}, Ljava/lang/StackTraceElement;->getFileName()Ljava/lang/String;
    move-result-object v3
    invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    const-string v3, ":"
    invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    aget-object v0, v0, v2
    invoke-virtual {v0}, Ljava/lang/StackTraceElement;->getLineNumber()I
    move-result v0
    invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
    invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object v0
    return-object v0
.end method
.method public static getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;
    .registers 1
    .line 265
    invoke-static {p0}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;
    move-result-object p0
    return-object p0
.end method
.method private static getThrowableToLog([Ljava/lang/Object;)Ljava/lang/Throwable;
    .registers 3
    const/4 v0, 0x0
    if-eqz p0, :cond_14
    .line 269
    array-length v1, p0
    if-nez v1, :cond_7
    goto :goto_14
    .line 271
    :cond_7
    array-length v1, p0
    add-int/lit8 v1, v1, -0x1
    aget-object p0, p0, v1
    .line 273
    instance-of v1, p0, Ljava/lang/Throwable;
    if-nez v1, :cond_11
    return-object v0
    .line 274
    :cond_11
    check-cast p0, Ljava/lang/Throwable;
    return-object p0
    :cond_14
    :goto_14
    return-object v0
.end method
.method public static varargs i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 4
    .line 174
    invoke-static {p2}, Lcom/tencent/liteav/base/Log;->getThrowableToLog([Ljava/lang/Object;)Ljava/lang/Throwable;
    move-result-object v0
    .line 175
    invoke-static {p1, v0, p2}, Lcom/tencent/liteav/base/Log;->formatLog(Ljava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)Ljava/lang/String;
    move-result-object p1
    const/4 p2, 0x4
    .line 177
    invoke-static {p2, p0, p1}, Lcom/tencent/liteav/base/Log;->nativeWriteLogToNative(ILjava/lang/String;Ljava/lang/String;)V
    return-void
.end method
.method private static isDebug()Z
    .registers 1
    const/4 v0, 0x1
    return v0
.end method
.method public static isLoggable(Ljava/lang/String;I)Z
    .registers 3
    .line 99
    invoke-static {}, Lcom/tencent/liteav/base/Log;->isDebug()Z
    move-result v0
    if-nez v0, :cond_b
    const/4 v0, 0x4
    if-gt p1, v0, :cond_b
    const/4 p0, 0x0
    return p0
    .line 102
    :cond_b
    invoke-static {p0, p1}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
    move-result p0
    return p0
.end method
.method private static native nativeWriteLogToNative(ILjava/lang/String;Ljava/lang/String;)V
.end method
.method public static normalizeTag(Ljava/lang/String;)Ljava/lang/String;
    .registers 4
    const-string v0, "cr_"
    .line 67
    invoke-virtual {p0, v0}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
    move-result v1
    if-eqz v1, :cond_9
    return-object p0
    :cond_9
    const/4 v1, 0x0
    const-string v2, "cr."
    .line 71
    invoke-virtual {p0, v2}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
    move-result v2
    if-eqz v2, :cond_13
    const/4 v1, 0x3
    .line 75
    :cond_13
    new-instance v2, Ljava/lang/StringBuilder;
    invoke-direct {v2, v0}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
    invoke-virtual {p0}, Ljava/lang/String;->length()I
    move-result v0
    invoke-virtual {p0, v1, v0}, Ljava/lang/String;->substring(II)Ljava/lang/String;
    move-result-object p0
    invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
    move-result-object p0
    return-object p0
.end method
.method public static varargs v(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 4
    .line 121
    invoke-static {p2}, Lcom/tencent/liteav/base/Log;->getThrowableToLog([Ljava/lang/Object;)Ljava/lang/Throwable;
    move-result-object v0
    .line 122
    invoke-static {p1, v0, p2}, Lcom/tencent/liteav/base/Log;->formatLogWithStack(Ljava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)Ljava/lang/String;
    move-result-object p1
    const/4 p2, 0x2
    .line 124
    invoke-static {p2, p0, p1}, Lcom/tencent/liteav/base/Log;->nativeWriteLogToNative(ILjava/lang/String;Ljava/lang/String;)V
    return-void
.end method
.method public static varargs w(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 4
    .line 198
    invoke-static {p2}, Lcom/tencent/liteav/base/Log;->getThrowableToLog([Ljava/lang/Object;)Ljava/lang/Throwable;
    move-result-object v0
    .line 199
    invoke-static {p1, v0, p2}, Lcom/tencent/liteav/base/Log;->formatLog(Ljava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)Ljava/lang/String;
    move-result-object p1
    const/4 p2, 0x5
    .line 201
    invoke-static {p2, p0, p1}, Lcom/tencent/liteav/base/Log;->nativeWriteLogToNative(ILjava/lang/String;Ljava/lang/String;)V
    return-void
.end method
.method public static varargs wtf(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 4
    .line 250
    invoke-static {p2}, Lcom/tencent/liteav/base/Log;->getThrowableToLog([Ljava/lang/Object;)Ljava/lang/Throwable;
    move-result-object v0
    .line 251
    invoke-static {p1, v0, p2}, Lcom/tencent/liteav/base/Log;->formatLog(Ljava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)Ljava/lang/String;
    move-result-object p1
    const/4 p2, 0x7
    .line 253
    invoke-static {p2, p0, p1}, Lcom/tencent/liteav/base/Log;->nativeWriteLogToNative(ILjava/lang/String;Ljava/lang/String;)V
    return-void
.end method