.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 ()V .locals 0 return-void .end method .method public constructor (Landroid/content/Context;)V .locals 2 invoke-direct {p0}, Ljava/lang/Object;->()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;->()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;->(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;->(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;->(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;->(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