482 lines
14 KiB
Smali
482 lines
14 KiB
Smali
.class public Lorg/webrtc/Logging;
|
|
.super Ljava/lang/Object;
|
|
.source "Logging.java"
|
|
|
|
|
|
# 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 volatile nativeLibLoaded:Z
|
|
|
|
.field private static volatile tracingEnabled:Z
|
|
|
|
|
|
# direct methods
|
|
.method static constructor <clinit>()V
|
|
.locals 4
|
|
|
|
.prologue
|
|
const-string v1, "org.webrtc.Logging"
|
|
|
|
invoke-static {v1}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger;
|
|
|
|
move-result-object v1
|
|
|
|
sput-object v1, Lorg/webrtc/Logging;->fallbackLogger:Ljava/util/logging/Logger;
|
|
|
|
:try_start_0
|
|
const-string v1, "jingle_peerconnection_so"
|
|
|
|
invoke-static {v1}, Ljava/lang/System;->loadLibrary(Ljava/lang/String;)V
|
|
|
|
const/4 v1, 0x1
|
|
|
|
sput-boolean v1, Lorg/webrtc/Logging;->nativeLibLoaded:Z
|
|
:try_end_0
|
|
.catch Ljava/lang/UnsatisfiedLinkError; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
.local v0, "t":Ljava/lang/UnsatisfiedLinkError;
|
|
:goto_0
|
|
return-void
|
|
|
|
.end local v0 # "t":Ljava/lang/UnsatisfiedLinkError;
|
|
:catch_0
|
|
move-exception v0
|
|
|
|
.restart local v0 # "t":Ljava/lang/UnsatisfiedLinkError;
|
|
sget-object v1, Lorg/webrtc/Logging;->fallbackLogger:Ljava/util/logging/Logger;
|
|
|
|
sget-object v2, Ljava/util/logging/Level;->ALL:Ljava/util/logging/Level;
|
|
|
|
invoke-virtual {v1, v2}, Ljava/util/logging/Logger;->setLevel(Ljava/util/logging/Level;)V
|
|
|
|
sget-object v1, Lorg/webrtc/Logging;->fallbackLogger:Ljava/util/logging/Logger;
|
|
|
|
sget-object v2, Ljava/util/logging/Level;->WARNING:Ljava/util/logging/Level;
|
|
|
|
const-string v3, "Failed to load jingle_peerconnection_so: "
|
|
|
|
invoke-virtual {v1, v2, v3, v0}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
|
|
|
|
goto :goto_0
|
|
.end method
|
|
|
|
.method public constructor <init>()V
|
|
.locals 0
|
|
|
|
.prologue
|
|
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static d(Ljava/lang/String;Ljava/lang/String;)V
|
|
.locals 1
|
|
.param p0, "tag" # Ljava/lang/String;
|
|
.param p1, "message" # Ljava/lang/String;
|
|
|
|
.prologue
|
|
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 e(Ljava/lang/String;Ljava/lang/String;)V
|
|
.locals 1
|
|
.param p0, "tag" # Ljava/lang/String;
|
|
.param p1, "message" # Ljava/lang/String;
|
|
|
|
.prologue
|
|
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
|
|
.locals 2
|
|
.param p0, "tag" # Ljava/lang/String;
|
|
.param p1, "message" # Ljava/lang/String;
|
|
.param p2, "e" # Ljava/lang/Throwable;
|
|
|
|
.prologue
|
|
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
|
|
|
|
sget-object v0, Lorg/webrtc/Logging$Severity;->LS_ERROR:Lorg/webrtc/Logging$Severity;
|
|
|
|
invoke-virtual {p2}, Ljava/lang/Throwable;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-static {v0, p0, v1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
|
|
|
|
sget-object v0, Lorg/webrtc/Logging$Severity;->LS_ERROR:Lorg/webrtc/Logging$Severity;
|
|
|
|
invoke-static {p2}, Lorg/webrtc/Logging;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-static {v0, p0, v1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static enableLogThreads()V
|
|
.locals 3
|
|
|
|
.prologue
|
|
sget-boolean v0, Lorg/webrtc/Logging;->nativeLibLoaded:Z
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
sget-object v0, Lorg/webrtc/Logging;->fallbackLogger:Ljava/util/logging/Logger;
|
|
|
|
sget-object v1, Ljava/util/logging/Level;->WARNING:Ljava/util/logging/Level;
|
|
|
|
const-string v2, "Cannot enable log thread because native lib not loaded."
|
|
|
|
invoke-virtual {v0, v1, v2}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;)V
|
|
|
|
:goto_0
|
|
return-void
|
|
|
|
:cond_0
|
|
invoke-static {}, Lorg/webrtc/Logging;->nativeEnableLogThreads()V
|
|
|
|
goto :goto_0
|
|
.end method
|
|
|
|
.method public static enableLogTimeStamps()V
|
|
.locals 3
|
|
|
|
.prologue
|
|
sget-boolean v0, Lorg/webrtc/Logging;->nativeLibLoaded:Z
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
sget-object v0, Lorg/webrtc/Logging;->fallbackLogger:Ljava/util/logging/Logger;
|
|
|
|
sget-object v1, Ljava/util/logging/Level;->WARNING:Ljava/util/logging/Level;
|
|
|
|
const-string v2, "Cannot enable log timestamps because native lib not loaded."
|
|
|
|
invoke-virtual {v0, v1, v2}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;)V
|
|
|
|
:goto_0
|
|
return-void
|
|
|
|
:cond_0
|
|
invoke-static {}, Lorg/webrtc/Logging;->nativeEnableLogTimeStamps()V
|
|
|
|
goto :goto_0
|
|
.end method
|
|
|
|
.method public static declared-synchronized enableTracing(Ljava/lang/String;Ljava/util/EnumSet;Lorg/webrtc/Logging$Severity;)V
|
|
.locals 6
|
|
.param p0, "path" # Ljava/lang/String;
|
|
.param p2, "severity" # Lorg/webrtc/Logging$Severity;
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/String;",
|
|
"Ljava/util/EnumSet",
|
|
"<",
|
|
"Lorg/webrtc/Logging$TraceLevel;",
|
|
">;",
|
|
"Lorg/webrtc/Logging$Severity;",
|
|
")V"
|
|
}
|
|
.end annotation
|
|
|
|
.prologue
|
|
.local p1, "levels":Ljava/util/EnumSet;, "Ljava/util/EnumSet<Lorg/webrtc/Logging$TraceLevel;>;"
|
|
const-class v3, Lorg/webrtc/Logging;
|
|
|
|
monitor-enter v3
|
|
|
|
:try_start_0
|
|
sget-boolean v2, Lorg/webrtc/Logging;->nativeLibLoaded:Z
|
|
|
|
if-nez v2, :cond_1
|
|
|
|
sget-object v2, Lorg/webrtc/Logging;->fallbackLogger:Ljava/util/logging/Logger;
|
|
|
|
sget-object v4, Ljava/util/logging/Level;->WARNING:Ljava/util/logging/Level;
|
|
|
|
const-string v5, "Cannot enable tracing because native lib not loaded."
|
|
|
|
invoke-virtual {v2, v4, v5}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;)V
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
:cond_0
|
|
:goto_0
|
|
monitor-exit v3
|
|
|
|
return-void
|
|
|
|
:cond_1
|
|
:try_start_1
|
|
sget-boolean v2, Lorg/webrtc/Logging;->tracingEnabled:Z
|
|
|
|
if-nez v2, :cond_0
|
|
|
|
const/4 v1, 0x0
|
|
|
|
.local v1, "nativeLevel":I
|
|
invoke-virtual {p1}, Ljava/util/EnumSet;->iterator()Ljava/util/Iterator;
|
|
|
|
move-result-object v2
|
|
|
|
:goto_1
|
|
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
|
|
|
|
move-result v4
|
|
|
|
if-eqz v4, :cond_2
|
|
|
|
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
|
|
|
|
move-result-object v0
|
|
|
|
check-cast v0, Lorg/webrtc/Logging$TraceLevel;
|
|
|
|
.local v0, "level":Lorg/webrtc/Logging$TraceLevel;
|
|
iget v4, v0, Lorg/webrtc/Logging$TraceLevel;->level:I
|
|
|
|
or-int/2addr v1, v4
|
|
|
|
goto :goto_1
|
|
|
|
.end local v0 # "level":Lorg/webrtc/Logging$TraceLevel;
|
|
:cond_2
|
|
invoke-virtual {p2}, Lorg/webrtc/Logging$Severity;->ordinal()I
|
|
|
|
move-result v2
|
|
|
|
invoke-static {p0, v1, v2}, Lorg/webrtc/Logging;->nativeEnableTracing(Ljava/lang/String;II)V
|
|
|
|
const/4 v2, 0x1
|
|
|
|
sput-boolean v2, Lorg/webrtc/Logging;->tracingEnabled:Z
|
|
:try_end_1
|
|
.catchall {:try_start_1 .. :try_end_1} :catchall_0
|
|
|
|
goto :goto_0
|
|
|
|
.end local v1 # "nativeLevel":I
|
|
:catchall_0
|
|
move-exception v2
|
|
|
|
monitor-exit v3
|
|
|
|
throw v2
|
|
.end method
|
|
|
|
.method private static getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;
|
|
.locals 3
|
|
.param p0, "e" # Ljava/lang/Throwable;
|
|
|
|
.prologue
|
|
if-nez p0, :cond_0
|
|
|
|
const-string v2, ""
|
|
|
|
:goto_0
|
|
return-object v2
|
|
|
|
:cond_0
|
|
new-instance v1, Ljava/io/StringWriter;
|
|
|
|
invoke-direct {v1}, Ljava/io/StringWriter;-><init>()V
|
|
|
|
.local v1, "sw":Ljava/io/StringWriter;
|
|
new-instance v0, Ljava/io/PrintWriter;
|
|
|
|
invoke-direct {v0, v1}, Ljava/io/PrintWriter;-><init>(Ljava/io/Writer;)V
|
|
|
|
.local v0, "pw":Ljava/io/PrintWriter;
|
|
invoke-virtual {p0, v0}, Ljava/lang/Throwable;->printStackTrace(Ljava/io/PrintWriter;)V
|
|
|
|
invoke-virtual {v1}, Ljava/io/StringWriter;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
goto :goto_0
|
|
.end method
|
|
|
|
.method public static log(Lorg/webrtc/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
|
|
.locals 4
|
|
.param p0, "severity" # Lorg/webrtc/Logging$Severity;
|
|
.param p1, "tag" # Ljava/lang/String;
|
|
.param p2, "message" # Ljava/lang/String;
|
|
|
|
.prologue
|
|
sget-boolean v1, Lorg/webrtc/Logging;->tracingEnabled:Z
|
|
|
|
if-eqz v1, :cond_0
|
|
|
|
invoke-virtual {p0}, Lorg/webrtc/Logging$Severity;->ordinal()I
|
|
|
|
move-result v1
|
|
|
|
invoke-static {v1, p1, p2}, Lorg/webrtc/Logging;->nativeLog(ILjava/lang/String;Ljava/lang/String;)V
|
|
|
|
:goto_0
|
|
return-void
|
|
|
|
:cond_0
|
|
sget-object v1, Lorg/webrtc/Logging$1;->$SwitchMap$org$webrtc$Logging$Severity:[I
|
|
|
|
invoke-virtual {p0}, Lorg/webrtc/Logging$Severity;->ordinal()I
|
|
|
|
move-result v2
|
|
|
|
aget v1, v1, v2
|
|
|
|
packed-switch v1, :pswitch_data_0
|
|
|
|
sget-object v0, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
|
|
|
|
.local v0, "level":Ljava/util/logging/Level;
|
|
:goto_1
|
|
sget-object v1, Lorg/webrtc/Logging;->fallbackLogger:Ljava/util/logging/Logger;
|
|
|
|
new-instance v2, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
move-result-object v2
|
|
|
|
const-string v3, ": "
|
|
|
|
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-virtual {v1, v0, v2}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;)V
|
|
|
|
goto :goto_0
|
|
|
|
.end local v0 # "level":Ljava/util/logging/Level;
|
|
:pswitch_0
|
|
sget-object v0, Ljava/util/logging/Level;->SEVERE:Ljava/util/logging/Level;
|
|
|
|
.restart local v0 # "level":Ljava/util/logging/Level;
|
|
goto :goto_1
|
|
|
|
.end local v0 # "level":Ljava/util/logging/Level;
|
|
:pswitch_1
|
|
sget-object v0, Ljava/util/logging/Level;->WARNING:Ljava/util/logging/Level;
|
|
|
|
.restart local v0 # "level":Ljava/util/logging/Level;
|
|
goto :goto_1
|
|
|
|
.end local v0 # "level":Ljava/util/logging/Level;
|
|
:pswitch_2
|
|
sget-object v0, Ljava/util/logging/Level;->INFO:Ljava/util/logging/Level;
|
|
|
|
.restart local v0 # "level":Ljava/util/logging/Level;
|
|
goto :goto_1
|
|
|
|
nop
|
|
|
|
:pswitch_data_0
|
|
.packed-switch 0x1
|
|
:pswitch_0
|
|
:pswitch_1
|
|
:pswitch_2
|
|
.end packed-switch
|
|
.end method
|
|
|
|
.method private static native nativeEnableLogThreads()V
|
|
.end method
|
|
|
|
.method private static native nativeEnableLogTimeStamps()V
|
|
.end method
|
|
|
|
.method private static native nativeEnableTracing(Ljava/lang/String;II)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
|
|
.locals 1
|
|
.param p0, "tag" # Ljava/lang/String;
|
|
.param p1, "message" # Ljava/lang/String;
|
|
|
|
.prologue
|
|
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
|
|
.locals 1
|
|
.param p0, "tag" # Ljava/lang/String;
|
|
.param p1, "message" # Ljava/lang/String;
|
|
|
|
.prologue
|
|
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
|
|
.locals 2
|
|
.param p0, "tag" # Ljava/lang/String;
|
|
.param p1, "message" # Ljava/lang/String;
|
|
.param p2, "e" # Ljava/lang/Throwable;
|
|
|
|
.prologue
|
|
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
|
|
|
|
sget-object v0, Lorg/webrtc/Logging$Severity;->LS_WARNING:Lorg/webrtc/Logging$Severity;
|
|
|
|
invoke-virtual {p2}, Ljava/lang/Throwable;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-static {v0, p0, v1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
|
|
|
|
sget-object v0, Lorg/webrtc/Logging$Severity;->LS_WARNING:Lorg/webrtc/Logging$Severity;
|
|
|
|
invoke-static {p2}, Lorg/webrtc/Logging;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-static {v0, p0, v1}, Lorg/webrtc/Logging;->log(Lorg/webrtc/Logging$Severity;Ljava/lang/String;Ljava/lang/String;)V
|
|
|
|
return-void
|
|
.end method
|