Logging.smali

.class public Lio/agora/base/internal/Logging;
.super Ljava/lang/Object;
.source "Logging.java"


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lio/agora/base/internal/Logging$Severity;,
        Lio/agora/base/internal/Logging$TraceLevel;
    }
.end annotation


# static fields
.field private static final fallbackLogger:Ljava/util/logging/Logger;

.field private static loggable:Lio/agora/base/internal/Loggable;

.field private static loggableSeverity:Lio/agora/base/internal/Logging$Severity;

.field private static volatile loggingEnabled:Z


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

    .line 43
    invoke-static {}, Lio/agora/base/internal/Logging;->createFallbackLogger()Ljava/util/logging/Logger;

    move-result-object v0

    sput-object v0, Lio/agora/base/internal/Logging;->fallbackLogger:Ljava/util/logging/Logger;

    const/4 v0, 0x1

    .line 44
    sput-boolean v0, Lio/agora/base/internal/Logging;->loggingEnabled:Z

    .line 46
    sget-object v0, Lio/agora/base/internal/Logging$Severity;->LS_INFO:Lio/agora/base/internal/Logging$Severity;

    sput-object v0, Lio/agora/base/internal/Logging;->loggableSeverity:Lio/agora/base/internal/Logging$Severity;

    return-void
.end method

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

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

    return-void
.end method

.method private static createFallbackLogger()Ljava/util/logging/Logger;
    .registers 2

    const-string v0, "org.webrtc.Logging"

    .line 49
    invoke-static {v0}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger;

    move-result-object v0

    .line 50
    sget-object v1, Ljava/util/logging/Level;->ALL:Ljava/util/logging/Level;

    invoke-virtual {v0, v1}, Ljava/util/logging/Logger;->setLevel(Ljava/util/logging/Level;)V

    return-object v0
.end method

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

    .line 159
    sget-object v0, Lio/agora/base/internal/Logging$Severity;->LS_INFO:Lio/agora/base/internal/Logging$Severity;

    invoke-static {v0, p0, p1}, Lio/agora/base/internal/Logging;->log(Lio/agora/base/internal/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method static deleteInjectedLoggable()V
    .registers 1

    const/4 v0, 0x0

    .line 62
    sput-object v0, Lio/agora/base/internal/Logging;->loggable:Lio/agora/base/internal/Loggable;

    return-void
.end method

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

    .line 163
    sget-object v0, Lio/agora/base/internal/Logging$Severity;->LS_ERROR:Lio/agora/base/internal/Logging$Severity;

    invoke-static {v0, p0, p1}, Lio/agora/base/internal/Logging;->log(Lio/agora/base/internal/Logging$Severity;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 171
    sget-object v0, Lio/agora/base/internal/Logging$Severity;->LS_ERROR:Lio/agora/base/internal/Logging$Severity;

    invoke-static {v0, p0, p1}, Lio/agora/base/internal/Logging;->log(Lio/agora/base/internal/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V

    .line 172
    sget-object p1, Lio/agora/base/internal/Logging$Severity;->LS_ERROR:Lio/agora/base/internal/Logging$Severity;

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

    move-result-object v0

    invoke-static {p1, p0, v0}, Lio/agora/base/internal/Logging;->log(Lio/agora/base/internal/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V

    .line 173
    sget-object p1, Lio/agora/base/internal/Logging$Severity;->LS_ERROR:Lio/agora/base/internal/Logging$Severity;

    invoke-static {p2}, Lio/agora/base/internal/Logging;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;

    move-result-object p2

    invoke-static {p1, p0, p2}, Lio/agora/base/internal/Logging;->log(Lio/agora/base/internal/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method public static enableLogThreads()V
    .registers 0

    .line 94
    invoke-static {}, Lio/agora/base/internal/Logging;->nativeEnableLogThreads()V

    return-void
.end method

.method public static enableLogTimeStamps()V
    .registers 0

    .line 98
    invoke-static {}, Lio/agora/base/internal/Logging;->nativeEnableLogTimeStamps()V

    return-void
.end method

.method public static declared-synchronized enableLogToDebugOutput(Lio/agora/base/internal/Logging$Severity;)V
    .registers 3

    const-class v0, Lio/agora/base/internal/Logging;

    monitor-enter v0

    .line 111
    :try_start_3
    sget-object v1, Lio/agora/base/internal/Logging;->loggable:Lio/agora/base/internal/Loggable;

    if-nez v1, :cond_13

    .line 116
    invoke-virtual {p0}, Lio/agora/base/internal/Logging$Severity;->ordinal()I

    move-result p0

    invoke-static {p0}, Lio/agora/base/internal/Logging;->nativeEnableLogToDebugOutput(I)V

    const/4 p0, 0x1

    .line 117
    sput-boolean p0, Lio/agora/base/internal/Logging;->loggingEnabled:Z
    :try_end_11
    .catchall {:try_start_3 .. :try_end_11} :catchall_1b

    .line 118
    monitor-exit v0

    return-void

    .line 112
    :cond_13
    :try_start_13
    new-instance p0, Ljava/lang/IllegalStateException;

    const-string v1, "Logging to native debug output not supported while Loggable is injected. Delete the Loggable before calling this method."

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

    throw p0
    :try_end_1b
    .catchall {:try_start_13 .. :try_end_1b} :catchall_1b

    :catchall_1b
    move-exception p0

    monitor-exit v0

    throw p0
.end method

.method public static enableTracing(Ljava/lang/String;Ljava/util/EnumSet;)V
    .registers 2
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/lang/String;",
            "Ljava/util/EnumSet<",
            "Lio/agora/base/internal/Logging$TraceLevel;",
            ">;)V"
        }
    .end annotation

    .annotation runtime Ljava/lang/Deprecated;
    .end annotation

    return-void
.end method

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

    const-string v0, ""

    if-nez p0, :cond_5

    return-object v0

    .line 191
    :cond_5
    new-instance v1, Ljava/io/StringWriter;

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

    .line 192
    new-instance v2, Ljava/io/PrintWriter;

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

    .line 198
    :try_start_f
    invoke-static {p0, v2}, Lcom/google/devtools/build/android/desugar/runtime/ThrowableExtension;->printStackTrace(Ljava/lang/Throwable;Ljava/io/PrintWriter;)V

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

    move-result-object p0
    :try_end_16
    .catchall {:try_start_f .. :try_end_16} :catchall_17

    return-object p0

    .line 201
    :catchall_17
    invoke-virtual {p0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;

    move-result-object p0

    if-nez p0, :cond_1e

    goto :goto_1f

    :cond_1e
    move-object v0, p0

    :goto_1f
    return-object v0
.end method

.method static injectLoggable(Lio/agora/base/internal/Loggable;Lio/agora/base/internal/Logging$Severity;)V
    .registers 2

    if-eqz p0, :cond_6

    .line 56
    sput-object p0, Lio/agora/base/internal/Logging;->loggable:Lio/agora/base/internal/Loggable;

    .line 57
    sput-object p1, Lio/agora/base/internal/Logging;->loggableSeverity:Lio/agora/base/internal/Logging$Severity;

    :cond_6
    return-void
.end method

.method public static log(Lio/agora/base/internal/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
    .registers 5

    if-eqz p1, :cond_5d

    if-eqz p2, :cond_5d

    .line 124
    sget-object v0, Lio/agora/base/internal/Logging;->loggable:Lio/agora/base/internal/Loggable;

    if-eqz v0, :cond_1b

    .line 126
    invoke-virtual {p0}, Lio/agora/base/internal/Logging$Severity;->ordinal()I

    move-result v0

    sget-object v1, Lio/agora/base/internal/Logging;->loggableSeverity:Lio/agora/base/internal/Logging$Severity;

    invoke-virtual {v1}, Lio/agora/base/internal/Logging$Severity;->ordinal()I

    move-result v1

    if-ge v0, v1, :cond_15

    return-void

    .line 129
    :cond_15
    sget-object v0, Lio/agora/base/internal/Logging;->loggable:Lio/agora/base/internal/Loggable;

    invoke-interface {v0, p2, p0, p1}, Lio/agora/base/internal/Loggable;->onLogMessage(Ljava/lang/String;Lio/agora/base/internal/Logging$Severity;Ljava/lang/String;)V

    return-void

    .line 134
    :cond_1b
    sget-boolean v0, Lio/agora/base/internal/Logging;->loggingEnabled:Z

    if-eqz v0, :cond_27

    .line 135
    invoke-virtual {p0}, Lio/agora/base/internal/Logging$Severity;->ordinal()I

    move-result p0

    invoke-static {p0, p1, p2}, Lio/agora/base/internal/Logging;->nativeLog(ILjava/lang/String;Ljava/lang/String;)V

    return-void

    .line 141
    :cond_27
    sget-object v0, Lio/agora/base/internal/Logging$1;->$SwitchMap$io$agora$base$internal$Logging$Severity:[I

    invoke-virtual {p0}, Lio/agora/base/internal/Logging$Severity;->ordinal()I

    move-result p0

    aget p0, v0, p0

    const/4 v0, 0x1

    if-eq p0, v0, :cond_41

    const/4 v0, 0x2

    if-eq p0, v0, :cond_3e

    const/4 v0, 0x3

    if-eq p0, v0, :cond_3b

    .line 152
    sget-object p0, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;

    goto :goto_43

    .line 149
    :cond_3b
    sget-object p0, Ljava/util/logging/Level;->INFO:Ljava/util/logging/Level;

    goto :goto_43

    .line 146
    :cond_3e
    sget-object p0, Ljava/util/logging/Level;->WARNING:Ljava/util/logging/Level;

    goto :goto_43

    .line 143
    :cond_41
    sget-object p0, Ljava/util/logging/Level;->SEVERE:Ljava/util/logging/Level;

    .line 155
    :goto_43
    sget-object v0, Lio/agora/base/internal/Logging;->fallbackLogger:Ljava/util/logging/Logger;

    new-instance v1, Ljava/lang/StringBuilder;

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

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

    const-string p1, ": "

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

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

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

    move-result-object p1

    invoke-virtual {v0, p0, p1}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;)V

    return-void

    .line 122
    :cond_5d
    new-instance p0, Ljava/lang/IllegalArgumentException;

    const-string p1, "Logging 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 nativeEnableLogThreads()V
.end method

.method private static native nativeEnableLogTimeStamps()V
.end method

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

.method private static native nativeLog(ILjava/lang/String;Ljava/lang/String;)V
.end method

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

    .line 183
    sget-object v0, Lio/agora/base/internal/Logging$Severity;->LS_VERBOSE:Lio/agora/base/internal/Logging$Severity;

    invoke-static {v0, p0, p1}, Lio/agora/base/internal/Logging;->log(Lio/agora/base/internal/Logging$Severity;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 167
    sget-object v0, Lio/agora/base/internal/Logging$Severity;->LS_WARNING:Lio/agora/base/internal/Logging$Severity;

    invoke-static {v0, p0, p1}, Lio/agora/base/internal/Logging;->log(Lio/agora/base/internal/Logging$Severity;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 177
    sget-object v0, Lio/agora/base/internal/Logging$Severity;->LS_WARNING:Lio/agora/base/internal/Logging$Severity;

    invoke-static {v0, p0, p1}, Lio/agora/base/internal/Logging;->log(Lio/agora/base/internal/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V

    .line 178
    sget-object p1, Lio/agora/base/internal/Logging$Severity;->LS_WARNING:Lio/agora/base/internal/Logging$Severity;

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

    move-result-object v0

    invoke-static {p1, p0, v0}, Lio/agora/base/internal/Logging;->log(Lio/agora/base/internal/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V

    .line 179
    sget-object p1, Lio/agora/base/internal/Logging$Severity;->LS_WARNING:Lio/agora/base/internal/Logging$Severity;

    invoke-static {p2}, Lio/agora/base/internal/Logging;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;

    move-result-object p2

    invoke-static {p1, p0, p2}, Lio/agora/base/internal/Logging;->log(Lio/agora/base/internal/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method