Logger.smali

.class public Lorg/mediasoup/Logger;
.super Ljava/lang/Object;
.source "SourceFile"


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lorg/mediasoup/Logger$DefaultLogHandler;,
        Lorg/mediasoup/Logger$LogHandlerInterface;,
        Lorg/mediasoup/Logger$LogLevel;
    }
.end annotation


# static fields
.field private static logHandler:Lorg/mediasoup/Logger$LogHandlerInterface;

.field private static nativeHandler:J


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

    const-string v0, "sszrtc"

    invoke-static {v0}, Lorg/mediasoup/Logger;->INVOKESTATIC_org_mediasoup_Logger_com_shopee_app_asm_fix_loadlibrary_SoLoaderFixer_loadLibrary(Ljava/lang/String;)V

    return-void
.end method

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

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

    return-void
.end method

.method public static INVOKESTATIC_org_mediasoup_Logger_com_shopee_app_asm_fix_loadlibrary_SoLoaderFixer_loadLibrary(Ljava/lang/String;)V
    .registers 3
    .annotation build Landroid/annotation/SuppressLint;
        value = {
            "LogNotTimber"
        }
    .end annotation

    .line 1
    :try_start_0
    # invokes: Ljava/lang/System;->loadLibrary(Ljava/lang/String;)V
    invoke-static {p0}, Lorg/mediasoup/Logger;->access$000(Ljava/lang/String;)V
    :try_end_3
    .catchall {:try_start_0 .. :try_end_3} :catchall_4

    goto :goto_2b

    :catchall_4
    move-exception v0

    .line 2
    invoke-static {}, Lcom/shopee/app/asm/fix/loadlibrary/a;->a()Z

    move-result v1

    if-eqz v1, :cond_37

    .line 3
    sget-object v0, Lcom/shopee/app/asm/fix/loadlibrary/a;->a:Lcom/getkeepsafe/relinker/e;

    if-nez v0, :cond_15

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

    move-result-object v0

    .line 5
    sput-object v0, Lcom/shopee/app/asm/fix/loadlibrary/a;->a:Lcom/getkeepsafe/relinker/e;

    .line 6
    :cond_15
    invoke-static {}, Lcom/shopee/app/application/n2;->e()Lcom/shopee/app/application/n2;

    move-result-object v0

    .line 7
    invoke-static {v0}, Landroidx/appcompat/i;->O(Landroid/content/Context;)Landroid/content/Context;

    move-result-object v0

    if-nez v0, :cond_23

    .line 8
    invoke-static {}, Lcom/shopee/app/application/n2;->e()Lcom/shopee/app/application/n2;

    move-result-object v0

    .line 9
    :cond_23
    invoke-static {v0}, Lcom/shopee/app/asm/fix/loadlibrary/a;->b(Landroid/content/Context;)V

    .line 10
    :try_start_26
    sget-object v1, Lcom/shopee/app/asm/fix/loadlibrary/a;->a:Lcom/getkeepsafe/relinker/e;

    .line 11
    invoke-virtual {v1, v0, p0}, Lcom/getkeepsafe/relinker/e;->b(Landroid/content/Context;Ljava/lang/String;)V
    :try_end_2b
    .catch Lcom/getkeepsafe/relinker/b; {:try_start_26 .. :try_end_2b} :catch_2c

    :goto_2b
    return-void

    :catch_2c
    move-exception p0

    .line 12
    new-instance v0, Ljava/lang/UnsatisfiedLinkError;

    invoke-virtual {p0}, Ljava/lang/Throwable;->getLocalizedMessage()Ljava/lang/String;

    move-result-object p0

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

    throw v0

    .line 13
    :cond_37
    throw v0
.end method

.method public static synthetic access$000(Ljava/lang/String;)V
    .registers 1

    invoke-static {p0}, Ljava/lang/System;->loadLibrary(Ljava/lang/String;)V

    return-void
.end method

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

    sget-object v0, Lorg/mediasoup/Logger$LogLevel;->LOG_DEBUG:Lorg/mediasoup/Logger$LogLevel;

    invoke-static {v0, p0, p1}, Lorg/mediasoup/Logger;->log(Lorg/mediasoup/Logger$LogLevel;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-object v0, Lorg/mediasoup/Logger$LogLevel;->LOG_ERROR:Lorg/mediasoup/Logger$LogLevel;

    invoke-static {v0, p0, p1}, Lorg/mediasoup/Logger;->log(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

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

    .line 2
    sget-object v0, Lorg/mediasoup/Logger$LogLevel;->LOG_ERROR:Lorg/mediasoup/Logger$LogLevel;

    invoke-static {v0, p0, p1}, Lorg/mediasoup/Logger;->log(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V

    .line 3
    invoke-virtual {p2}, Ljava/lang/Throwable;->toString()Ljava/lang/String;

    move-result-object p1

    invoke-static {v0, p0, p1}, Lorg/mediasoup/Logger;->log(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V

    .line 4
    invoke-static {p2}, Lorg/mediasoup/Logger;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;

    move-result-object p1

    invoke-static {v0, p0, p1}, Lorg/mediasoup/Logger;->log(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method public static freeHandler()V
    .registers 2

    .line 1
    sget-wide v0, Lorg/mediasoup/Logger;->nativeHandler:J

    invoke-static {v0, v1}, Lorg/mediasoup/Logger;->nativeFreeLogHandler(J)V

    const-wide/16 v0, 0x0

    .line 2
    sput-wide v0, Lorg/mediasoup/Logger;->nativeHandler:J

    return-void
.end method

.method private static getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;
    .registers 3

    if-nez p0, :cond_5

    const-string p0, ""

    return-object p0

    .line 1
    :cond_5
    new-instance v0, Ljava/io/StringWriter;

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

    .line 2
    new-instance v1, Ljava/io/PrintWriter;

    invoke-direct {v1, v0}, Ljava/io/PrintWriter;-><init>(Ljava/io/Writer;)V

    .line 3
    invoke-virtual {p0, v1}, Ljava/lang/Throwable;->printStackTrace(Ljava/io/PrintWriter;)V

    .line 4
    invoke-virtual {v0}, Ljava/io/StringWriter;->toString()Ljava/lang/String;

    move-result-object p0

    return-object p0
.end method

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

    sget-object v0, Lorg/mediasoup/Logger$LogLevel;->LOG_INFO:Lorg/mediasoup/Logger$LogLevel;

    invoke-static {v0, p0, p1}, Lorg/mediasoup/Logger;->log(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method public static log(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V
    .registers 4

    if-eqz p1, :cond_c

    if-eqz p2, :cond_c

    .line 1
    sget-object v0, Lorg/mediasoup/Logger;->logHandler:Lorg/mediasoup/Logger$LogHandlerInterface;

    if-eqz v0, :cond_b

    .line 2
    invoke-interface {v0, p0, p1, p2}, Lorg/mediasoup/Logger$LogHandlerInterface;->OnLog(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V

    :cond_b
    return-void

    .line 3
    :cond_c
    new-instance p0, Ljava/lang/IllegalArgumentException;

    const-string p1, "Log tag or message may not be null."

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

    throw p0
.end method

.method private static native nativeFreeLogHandler(J)V
.end method

.method private static native nativeSetHandler(Lorg/mediasoup/Logger$LogHandlerInterface;)J
.end method

.method private static native nativeSetLogLevel(I)V
.end method

.method public static setDefaultHandler()V
    .registers 2

    new-instance v0, Lorg/mediasoup/Logger$DefaultLogHandler;

    const/4 v1, 0x0

    invoke-direct {v0, v1}, Lorg/mediasoup/Logger$DefaultLogHandler;-><init>(Lorg/mediasoup/Logger$1;)V

    invoke-static {v0}, Lorg/mediasoup/Logger;->setHandler(Lorg/mediasoup/Logger$LogHandlerInterface;)V

    return-void
.end method

.method public static setHandler(Lorg/mediasoup/Logger$LogHandlerInterface;)V
    .registers 3

    .line 1
    sput-object p0, Lorg/mediasoup/Logger;->logHandler:Lorg/mediasoup/Logger$LogHandlerInterface;

    .line 2
    invoke-static {p0}, Lorg/mediasoup/Logger;->nativeSetHandler(Lorg/mediasoup/Logger$LogHandlerInterface;)J

    move-result-wide v0

    sput-wide v0, Lorg/mediasoup/Logger;->nativeHandler:J

    return-void
.end method

.method public static setLogLevel(Lorg/mediasoup/Logger$LogLevel;)V
    .registers 2

    if-eqz p0, :cond_a

    .line 1
    invoke-virtual {p0}, Lorg/mediasoup/Logger$LogLevel;->getValue()I

    move-result p0

    invoke-static {p0}, Lorg/mediasoup/Logger;->nativeSetLogLevel(I)V

    return-void

    .line 2
    :cond_a
    new-instance p0, Ljava/lang/IllegalArgumentException;

    const-string v0, "Logging level may not be null."

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

    throw p0
.end method

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

    sget-object v0, Lorg/mediasoup/Logger$LogLevel;->LOG_TRACE:Lorg/mediasoup/Logger$LogLevel;

    invoke-static {v0, p0, p1}, Lorg/mediasoup/Logger;->log(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

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

    .line 1
    sget-object v0, Lorg/mediasoup/Logger$LogLevel;->LOG_WARN:Lorg/mediasoup/Logger$LogLevel;

    invoke-static {v0, p0, p1}, Lorg/mediasoup/Logger;->log(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

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

    .line 2
    sget-object v0, Lorg/mediasoup/Logger$LogLevel;->LOG_WARN:Lorg/mediasoup/Logger$LogLevel;

    invoke-static {v0, p0, p1}, Lorg/mediasoup/Logger;->log(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V

    .line 3
    invoke-virtual {p2}, Ljava/lang/Throwable;->toString()Ljava/lang/String;

    move-result-object p1

    invoke-static {v0, p0, p1}, Lorg/mediasoup/Logger;->log(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V

    .line 4
    invoke-static {p2}, Lorg/mediasoup/Logger;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;

    move-result-object p1

    invoke-static {v0, p0, p1}, Lorg/mediasoup/Logger;->log(Lorg/mediasoup/Logger$LogLevel;Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method