407 lines
10 KiB
Smali
407 lines
10 KiB
Smali
.class public Lcom/tencent/smtt/utils/TbsLogClient;
|
|
.super Ljava/lang/Object;
|
|
|
|
|
|
# annotations
|
|
.annotation system Ldalvik/annotation/MemberClasses;
|
|
value = {
|
|
Lcom/tencent/smtt/utils/TbsLogClient$a;
|
|
}
|
|
.end annotation
|
|
|
|
|
|
# static fields
|
|
.field static a:Lcom/tencent/smtt/utils/TbsLogClient; = null
|
|
|
|
.field static c:Ljava/io/File; = null
|
|
|
|
.field static d:Ljava/lang/String; = null
|
|
|
|
.field static e:[B = null
|
|
|
|
.field private static i:Z = true
|
|
|
|
|
|
# instance fields
|
|
.field b:Landroid/widget/TextView;
|
|
|
|
.field private f:Ljava/text/SimpleDateFormat;
|
|
|
|
.field private g:Landroid/content/Context;
|
|
|
|
.field private h:Ljava/lang/StringBuffer;
|
|
|
|
|
|
# direct methods
|
|
.method static constructor <clinit>()V
|
|
.locals 0
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public constructor <init>(Landroid/content/Context;)V
|
|
.locals 2
|
|
|
|
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
|
|
|
|
const/4 v0, 0x0
|
|
|
|
iput-object v0, p0, Lcom/tencent/smtt/utils/TbsLogClient;->f:Ljava/text/SimpleDateFormat;
|
|
|
|
iput-object v0, p0, Lcom/tencent/smtt/utils/TbsLogClient;->g:Landroid/content/Context;
|
|
|
|
new-instance v0, Ljava/lang/StringBuffer;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuffer;-><init>()V
|
|
|
|
iput-object v0, p0, Lcom/tencent/smtt/utils/TbsLogClient;->h:Ljava/lang/StringBuffer;
|
|
|
|
:try_start_0
|
|
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
|
|
|
|
move-result-object p1
|
|
|
|
iput-object p1, p0, Lcom/tencent/smtt/utils/TbsLogClient;->g:Landroid/content/Context;
|
|
|
|
new-instance p1, Ljava/text/SimpleDateFormat;
|
|
|
|
const-string v0, "yyyy-MM-dd_HH:mm:ss.SSS"
|
|
|
|
sget-object v1, Ljava/util/Locale;->US:Ljava/util/Locale;
|
|
|
|
invoke-direct {p1, v0, v1}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
|
|
|
|
iput-object p1, p0, Lcom/tencent/smtt/utils/TbsLogClient;->f:Ljava/text/SimpleDateFormat;
|
|
:try_end_0
|
|
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_0
|
|
new-instance p1, Ljava/text/SimpleDateFormat;
|
|
|
|
const-string v0, "yyyy-MM-dd_HH:mm:ss.SSS"
|
|
|
|
invoke-direct {p1, v0}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;)V
|
|
|
|
iput-object p1, p0, Lcom/tencent/smtt/utils/TbsLogClient;->f:Ljava/text/SimpleDateFormat;
|
|
|
|
:goto_0
|
|
return-void
|
|
.end method
|
|
|
|
.method private a()V
|
|
.locals 3
|
|
|
|
:try_start_0
|
|
sget-object v0, Lcom/tencent/smtt/utils/TbsLogClient;->c:Ljava/io/File;
|
|
|
|
if-nez v0, :cond_2
|
|
|
|
invoke-static {}, Landroid/os/Environment;->getExternalStorageState()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
const-string v1, "mounted"
|
|
|
|
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
|
|
|
|
move-result v0
|
|
|
|
const/4 v1, 0x0
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
iget-object v0, p0, Lcom/tencent/smtt/utils/TbsLogClient;->g:Landroid/content/Context;
|
|
|
|
const/4 v2, 0x6
|
|
|
|
invoke-static {v0, v2}, Lcom/tencent/smtt/utils/k;->a(Landroid/content/Context;I)Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
if-nez v0, :cond_1
|
|
|
|
:cond_0
|
|
sput-object v1, Lcom/tencent/smtt/utils/TbsLogClient;->c:Ljava/io/File;
|
|
|
|
goto :goto_0
|
|
|
|
:cond_1
|
|
new-instance v1, Ljava/io/File;
|
|
|
|
const-string v2, "tbslog.txt"
|
|
|
|
invoke-direct {v1, v0, v2}, Ljava/io/File;-><init>(Ljava/lang/String;Ljava/lang/String;)V
|
|
|
|
sput-object v1, Lcom/tencent/smtt/utils/TbsLogClient;->c:Ljava/io/File;
|
|
|
|
invoke-static {}, Lcom/tencent/smtt/utils/LogFileUtils;->createKey()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
sput-object v0, Lcom/tencent/smtt/utils/TbsLogClient;->d:Ljava/lang/String;
|
|
|
|
sget-object v0, Lcom/tencent/smtt/utils/TbsLogClient;->c:Ljava/io/File;
|
|
|
|
invoke-virtual {v0}, Ljava/io/File;->getName()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
sget-object v1, Lcom/tencent/smtt/utils/TbsLogClient;->d:Ljava/lang/String;
|
|
|
|
invoke-static {v0, v1}, Lcom/tencent/smtt/utils/LogFileUtils;->createHeaderText(Ljava/lang/String;Ljava/lang/String;)[B
|
|
|
|
move-result-object v0
|
|
|
|
sput-object v0, Lcom/tencent/smtt/utils/TbsLogClient;->e:[B
|
|
:try_end_0
|
|
.catch Ljava/lang/SecurityException; {:try_start_0 .. :try_end_0} :catch_1
|
|
.catch Ljava/lang/NullPointerException; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_0
|
|
move-exception v0
|
|
|
|
invoke-virtual {v0}, Ljava/lang/NullPointerException;->printStackTrace()V
|
|
|
|
goto :goto_0
|
|
|
|
:catch_1
|
|
move-exception v0
|
|
|
|
invoke-virtual {v0}, Ljava/lang/SecurityException;->printStackTrace()V
|
|
|
|
:cond_2
|
|
:goto_0
|
|
return-void
|
|
.end method
|
|
|
|
.method public static setWriteLogJIT(Z)V
|
|
.locals 0
|
|
|
|
sput-boolean p0, Lcom/tencent/smtt/utils/TbsLogClient;->i:Z
|
|
|
|
return-void
|
|
.end method
|
|
|
|
|
|
# virtual methods
|
|
.method public d(Ljava/lang/String;Ljava/lang/String;)V
|
|
.locals 0
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public e(Ljava/lang/String;Ljava/lang/String;)V
|
|
.locals 0
|
|
|
|
invoke-static {p1, p2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public i(Ljava/lang/String;Ljava/lang/String;)V
|
|
.locals 0
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public setLogView(Landroid/widget/TextView;)V
|
|
.locals 0
|
|
|
|
iput-object p1, p0, Lcom/tencent/smtt/utils/TbsLogClient;->b:Landroid/widget/TextView;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public showLog(Ljava/lang/String;)V
|
|
.locals 2
|
|
|
|
iget-object v0, p0, Lcom/tencent/smtt/utils/TbsLogClient;->b:Landroid/widget/TextView;
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
iget-object v0, p0, Lcom/tencent/smtt/utils/TbsLogClient;->b:Landroid/widget/TextView;
|
|
|
|
new-instance v1, Lcom/tencent/smtt/utils/TbsLogClient$a;
|
|
|
|
invoke-direct {v1, p0, p1}, Lcom/tencent/smtt/utils/TbsLogClient$a;-><init>(Lcom/tencent/smtt/utils/TbsLogClient;Ljava/lang/String;)V
|
|
|
|
invoke-virtual {v0, v1}, Landroid/widget/TextView;->post(Ljava/lang/Runnable;)Z
|
|
|
|
:cond_0
|
|
return-void
|
|
.end method
|
|
|
|
.method public v(Ljava/lang/String;Ljava/lang/String;)V
|
|
.locals 0
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public w(Ljava/lang/String;Ljava/lang/String;)V
|
|
.locals 0
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public writeLog(Ljava/lang/String;)V
|
|
.locals 3
|
|
|
|
:try_start_0
|
|
iget-object v0, p0, Lcom/tencent/smtt/utils/TbsLogClient;->f:Ljava/text/SimpleDateFormat;
|
|
|
|
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
|
|
|
|
move-result-wide v1
|
|
|
|
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-virtual {v0, v1}, Ljava/text/SimpleDateFormat;->format(Ljava/lang/Object;)Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
iget-object v1, p0, Lcom/tencent/smtt/utils/TbsLogClient;->h:Ljava/lang/StringBuffer;
|
|
|
|
invoke-virtual {v1, v0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
|
|
|
|
const-string v0, " pid="
|
|
|
|
invoke-virtual {v1, v0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
|
|
|
|
invoke-static {}, Landroid/os/Process;->myPid()I
|
|
|
|
move-result v0
|
|
|
|
invoke-virtual {v1, v0}, Ljava/lang/StringBuffer;->append(I)Ljava/lang/StringBuffer;
|
|
|
|
const-string v0, " tid="
|
|
|
|
invoke-virtual {v1, v0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
|
|
|
|
invoke-static {}, Landroid/os/Process;->myTid()I
|
|
|
|
move-result v0
|
|
|
|
invoke-virtual {v1, v0}, Ljava/lang/StringBuffer;->append(I)Ljava/lang/StringBuffer;
|
|
|
|
invoke-virtual {v1, p1}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
|
|
|
|
const-string p1, "\n"
|
|
|
|
invoke-virtual {v1, p1}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
|
|
|
|
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
|
|
|
|
move-result-object p1
|
|
|
|
invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-virtual {v0}, Landroid/os/Looper;->getThread()Ljava/lang/Thread;
|
|
|
|
move-result-object v0
|
|
|
|
if-ne p1, v0, :cond_0
|
|
|
|
sget-boolean p1, Lcom/tencent/smtt/utils/TbsLogClient;->i:Z
|
|
|
|
if-eqz p1, :cond_1
|
|
|
|
:cond_0
|
|
invoke-virtual {p0}, Lcom/tencent/smtt/utils/TbsLogClient;->writeLogToDisk()V
|
|
|
|
:cond_1
|
|
iget-object p1, p0, Lcom/tencent/smtt/utils/TbsLogClient;->h:Ljava/lang/StringBuffer;
|
|
|
|
invoke-virtual {p1}, Ljava/lang/StringBuffer;->length()I
|
|
|
|
move-result p1
|
|
|
|
const/high16 v0, 0x80000
|
|
|
|
if-le p1, v0, :cond_2
|
|
|
|
iget-object p1, p0, Lcom/tencent/smtt/utils/TbsLogClient;->h:Ljava/lang/StringBuffer;
|
|
|
|
const/4 v0, 0x0
|
|
|
|
iget-object v1, p0, Lcom/tencent/smtt/utils/TbsLogClient;->h:Ljava/lang/StringBuffer;
|
|
|
|
invoke-virtual {v1}, Ljava/lang/StringBuffer;->length()I
|
|
|
|
move-result v1
|
|
|
|
invoke-virtual {p1, v0, v1}, Ljava/lang/StringBuffer;->delete(II)Ljava/lang/StringBuffer;
|
|
:try_end_0
|
|
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_0
|
|
move-exception p1
|
|
|
|
invoke-virtual {p1}, Ljava/lang/Exception;->printStackTrace()V
|
|
|
|
:cond_2
|
|
:goto_0
|
|
return-void
|
|
.end method
|
|
|
|
.method public writeLogToDisk()V
|
|
.locals 5
|
|
|
|
:try_start_0
|
|
invoke-direct {p0}, Lcom/tencent/smtt/utils/TbsLogClient;->a()V
|
|
|
|
sget-object v0, Lcom/tencent/smtt/utils/TbsLogClient;->c:Ljava/io/File;
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
sget-object v0, Lcom/tencent/smtt/utils/TbsLogClient;->c:Ljava/io/File;
|
|
|
|
sget-object v1, Lcom/tencent/smtt/utils/TbsLogClient;->d:Ljava/lang/String;
|
|
|
|
sget-object v2, Lcom/tencent/smtt/utils/TbsLogClient;->e:[B
|
|
|
|
iget-object v3, p0, Lcom/tencent/smtt/utils/TbsLogClient;->h:Ljava/lang/StringBuffer;
|
|
|
|
invoke-virtual {v3}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v3
|
|
|
|
const/4 v4, 0x1
|
|
|
|
invoke-static {v0, v1, v2, v3, v4}, Lcom/tencent/smtt/utils/LogFileUtils;->writeDataToStorage(Ljava/io/File;Ljava/lang/String;[BLjava/lang/String;Z)V
|
|
|
|
iget-object v0, p0, Lcom/tencent/smtt/utils/TbsLogClient;->h:Ljava/lang/StringBuffer;
|
|
|
|
const/4 v1, 0x0
|
|
|
|
iget-object v2, p0, Lcom/tencent/smtt/utils/TbsLogClient;->h:Ljava/lang/StringBuffer;
|
|
|
|
invoke-virtual {v2}, Ljava/lang/StringBuffer;->length()I
|
|
|
|
move-result v2
|
|
|
|
invoke-virtual {v0, v1, v2}, Ljava/lang/StringBuffer;->delete(II)Ljava/lang/StringBuffer;
|
|
:try_end_0
|
|
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
goto :goto_0
|
|
|
|
:catch_0
|
|
move-exception v0
|
|
|
|
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
|
|
|
|
:cond_0
|
|
:goto_0
|
|
return-void
|
|
.end method
|