Logging.smali
.class public Lorg/webrtc/Logging;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lorg/webrtc/Logging$Severity;,
Lorg/webrtc/Logging$TraceLevel;
}
.end annotation
# static fields
.field private static final fallbackLogger:Ljava/util/logging/Logger;
.field private static loggable:Lorg/webrtc/Loggable;
.field private static loggableSeverity:Lorg/webrtc/Logging$Severity;
.field private static volatile loggingEnabled:Z
# direct methods
.method public static constructor <clinit>()V
.registers 1
invoke-static {}, Lorg/webrtc/Logging;->createFallbackLogger()Ljava/util/logging/Logger;
move-result-object v0
sput-object v0, Lorg/webrtc/Logging;->fallbackLogger:Ljava/util/logging/Logger;
return-void
.end method
.method public constructor <init>()V
.registers 1
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 1
invoke-static {v0}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger;
move-result-object v0
.line 2
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
sget-object v0, Lorg/webrtc/Logging$Severity;->LS_INFO:Lorg/webrtc/Logging$Severity;
invoke-static {v0, p0, p1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method public static deleteInjectedLoggable()V
.registers 1
const/4 v0, 0x0
sput-object v0, Lorg/webrtc/Logging;->loggable:Lorg/webrtc/Loggable;
return-void
.end method
.method public static e(Ljava/lang/String;Ljava/lang/String;)V
.registers 3
.line 1
sget-object v0, Lorg/webrtc/Logging$Severity;->LS_ERROR:Lorg/webrtc/Logging$Severity;
invoke-static {v0, p0, p1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/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 2
sget-object v0, Lorg/webrtc/Logging$Severity;->LS_ERROR:Lorg/webrtc/Logging$Severity;
invoke-static {v0, p0, p1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/Logging$Severity;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/webrtc/Logging;->log(Lorg/webrtc/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
.line 4
invoke-static {p2}, Lorg/webrtc/Logging;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;
move-result-object p1
invoke-static {v0, p0, p1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method public static enableLogThreads()V
.registers 0
invoke-static {}, Lorg/webrtc/Logging;->nativeEnableLogThreads()V
return-void
.end method
.method public static enableLogTimeStamps()V
.registers 0
invoke-static {}, Lorg/webrtc/Logging;->nativeEnableLogTimeStamps()V
return-void
.end method
.method public static declared-synchronized enableLogToDebugOutput(Lorg/webrtc/Logging$Severity;)V
.registers 3
const-class v0, Lorg/webrtc/Logging;
monitor-enter v0
.line 1
:try_start_3
sget-object v1, Lorg/webrtc/Logging;->loggable:Lorg/webrtc/Loggable;
if-nez v1, :cond_13
.line 2
invoke-virtual {p0}, Ljava/lang/Enum;->ordinal()I
move-result p0
invoke-static {p0}, Lorg/webrtc/Logging;->nativeEnableLogToDebugOutput(I)V
const/4 p0, 0x1
.line 3
sput-boolean p0, Lorg/webrtc/Logging;->loggingEnabled:Z
:try_end_11
.catchall {:try_start_3 .. :try_end_11} :catchall_1b
.line 4
monitor-exit v0
return-void
.line 5
: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<",
"Lorg/webrtc/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 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 injectLoggable(Lorg/webrtc/Loggable;Lorg/webrtc/Logging$Severity;)V
.registers 2
if-eqz p0, :cond_6
.line 1
sput-object p0, Lorg/webrtc/Logging;->loggable:Lorg/webrtc/Loggable;
.line 2
sput-object p1, Lorg/webrtc/Logging;->loggableSeverity:Lorg/webrtc/Logging$Severity;
:cond_6
return-void
.end method
.method public static log(Lorg/webrtc/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
.registers 5
if-eqz p1, :cond_5d
if-eqz p2, :cond_5d
.line 1
sget-object v0, Lorg/webrtc/Logging;->loggable:Lorg/webrtc/Loggable;
if-eqz v0, :cond_1b
.line 2
invoke-virtual {p0}, Ljava/lang/Enum;->ordinal()I
move-result v0
sget-object v1, Lorg/webrtc/Logging;->loggableSeverity:Lorg/webrtc/Logging$Severity;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
if-ge v0, v1, :cond_15
return-void
.line 3
:cond_15
sget-object v0, Lorg/webrtc/Logging;->loggable:Lorg/webrtc/Loggable;
invoke-interface {v0, p2, p0, p1}, Lorg/webrtc/Loggable;->onLogMessage(Ljava/lang/String;Lorg/webrtc/Logging$Severity;Ljava/lang/String;)V
return-void
.line 4
:cond_1b
sget-boolean v0, Lorg/webrtc/Logging;->loggingEnabled:Z
if-eqz v0, :cond_27
.line 5
invoke-virtual {p0}, Ljava/lang/Enum;->ordinal()I
move-result p0
invoke-static {p0, p1, p2}, Lorg/webrtc/Logging;->nativeLog(ILjava/lang/String;Ljava/lang/String;)V
return-void
.line 6
:cond_27
sget-object v0, Lorg/webrtc/Logging$1;->$SwitchMap$org$webrtc$Logging$Severity:[I
invoke-virtual {p0}, Ljava/lang/Enum;->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 7
sget-object p0, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
goto :goto_43
.line 8
:cond_3b
sget-object p0, Ljava/util/logging/Level;->INFO:Ljava/util/logging/Level;
goto :goto_43
.line 9
:cond_3e
sget-object p0, Ljava/util/logging/Level;->WARNING:Ljava/util/logging/Level;
goto :goto_43
.line 10
:cond_41
sget-object p0, Ljava/util/logging/Level;->SEVERE:Ljava/util/logging/Level;
.line 11
:goto_43
sget-object v0, Lorg/webrtc/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 12
: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
sget-object v0, Lorg/webrtc/Logging$Severity;->LS_VERBOSE:Lorg/webrtc/Logging$Severity;
invoke-static {v0, p0, p1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/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 1
sget-object v0, Lorg/webrtc/Logging$Severity;->LS_WARNING:Lorg/webrtc/Logging$Severity;
invoke-static {v0, p0, p1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/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 2
sget-object v0, Lorg/webrtc/Logging$Severity;->LS_WARNING:Lorg/webrtc/Logging$Severity;
invoke-static {v0, p0, p1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/Logging$Severity;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/webrtc/Logging;->log(Lorg/webrtc/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
.line 4
invoke-static {p2}, Lorg/webrtc/Logging;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;
move-result-object p1
invoke-static {v0, p0, p1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method