dg.smali
.class public final Lcom/baidu/techain/af/dg;
.super Ljava/lang/Object;
# interfaces
.implements Lcom/baidu/techain/aa/a;
# static fields
.field public static a:Ljava/lang/String;
.field private static final b:Ljava/text/SimpleDateFormat;
.field private static c:Lcom/baidu/techain/af/m;
.field private static g:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List",
"<",
"Landroid/util/Pair",
"<",
"Ljava/lang/String;",
"Ljava/lang/Throwable;",
">;>;"
}
.end annotation
.end field
# instance fields
.field private d:Ljava/lang/String;
.field private e:Landroid/content/Context;
.field private f:Ljava/lang/String;
# direct methods
.method static constructor <clinit>()V
.registers 2
new-instance v0, Ljava/text/SimpleDateFormat;
const-string v1, "yyyy-MM-dd HH:mm:ss aaa"
invoke-direct {v0, v1}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;)V
sput-object v0, Lcom/baidu/techain/af/dg;->b:Ljava/text/SimpleDateFormat;
new-instance v0, Lcom/baidu/techain/af/m;
const/4 v1, 0x1
invoke-direct {v0, v1}, Lcom/baidu/techain/af/m;-><init>(Z)V
sput-object v0, Lcom/baidu/techain/af/dg;->c:Lcom/baidu/techain/af/m;
const-string v0, "/MiPushLog"
sput-object v0, Lcom/baidu/techain/af/dg;->a:Ljava/lang/String;
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
invoke-static {v0}, Ljava/util/Collections;->synchronizedList(Ljava/util/List;)Ljava/util/List;
move-result-object v0
sput-object v0, Lcom/baidu/techain/af/dg;->g:Ljava/util/List;
return-void
.end method
.method public constructor <init>(Landroid/content/Context;)V
.registers 3
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const-string v0, ""
iput-object v0, p0, Lcom/baidu/techain/af/dg;->f:Ljava/lang/String;
iput-object p1, p0, Lcom/baidu/techain/af/dg;->e:Landroid/content/Context;
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v0
if-eqz v0, :cond_15
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v0
iput-object v0, p0, Lcom/baidu/techain/af/dg;->e:Landroid/content/Context;
:cond_15
iget-object v0, p0, Lcom/baidu/techain/af/dg;->e:Landroid/content/Context;
invoke-virtual {v0}, Landroid/content/Context;->getPackageName()Ljava/lang/String;
move-result-object v0
iput-object v0, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
return-void
.end method
.method static synthetic a(Lcom/baidu/techain/af/dg;)Ljava/lang/String;
.registers 2
iget-object v0, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
return-object v0
.end method
.method static synthetic a()Ljava/util/List;
.registers 1
sget-object v0, Lcom/baidu/techain/af/dg;->g:Ljava/util/List;
return-object v0
.end method
.method static synthetic b(Lcom/baidu/techain/af/dg;)V
.registers 15
.prologue
const/4 v4, 0x0
.line 1000
:try_start_1
iget-object v2, p0, Lcom/baidu/techain/af/dg;->f:Ljava/lang/String;
invoke-static {v2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v2
if-eqz v2, :cond_25
iget-object v2, p0, Lcom/baidu/techain/af/dg;->e:Landroid/content/Context;
const/4 v3, 0x0
invoke-virtual {v2, v3}, Landroid/content/Context;->getExternalFilesDir(Ljava/lang/String;)Ljava/io/File;
move-result-object v2
if-eqz v2, :cond_25
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v2
invoke-virtual {v3, v2}, 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
iput-object v2, p0, Lcom/baidu/techain/af/dg;->f:Ljava/lang/String;
:cond_25
new-instance v8, Ljava/io/File;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
iget-object v3, p0, Lcom/baidu/techain/af/dg;->f:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
sget-object v3, Lcom/baidu/techain/af/dg;->a:Ljava/lang/String;
invoke-virtual {v2, v3}, 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-direct {v8, v2}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v8}, Ljava/io/File;->exists()Z
move-result v2
if-eqz v2, :cond_4b
invoke-virtual {v8}, Ljava/io/File;->isDirectory()Z
move-result v2
if-nez v2, :cond_59
:cond_4b
invoke-virtual {v8}, Ljava/io/File;->mkdirs()Z
move-result v2
if-nez v2, :cond_59
iget-object v2, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
const-string v3, "Create mipushlog directory fail."
invoke-static {v2, v3}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:cond_58
:goto_58
return-void
:cond_59
new-instance v2, Ljava/io/File;
const-string v3, "log.lock"
invoke-direct {v2, v8, v3}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
invoke-virtual {v2}, Ljava/io/File;->exists()Z
move-result v3
if-eqz v3, :cond_6c
invoke-virtual {v2}, Ljava/io/File;->isDirectory()Z
move-result v3
if-eqz v3, :cond_6f
:cond_6c
invoke-virtual {v2}, Ljava/io/File;->createNewFile()Z
:cond_6f
new-instance v7, Ljava/io/RandomAccessFile;
const-string v3, "rw"
invoke-direct {v7, v2, v3}, Ljava/io/RandomAccessFile;-><init>(Ljava/io/File;Ljava/lang/String;)V
:try_end_76
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_76} :catch_1c6
.catchall {:try_start_1 .. :try_end_76} :catchall_185
:try_start_76
invoke-virtual {v7}, Ljava/io/RandomAccessFile;->getChannel()Ljava/nio/channels/FileChannel;
move-result-object v2
invoke-virtual {v2}, Ljava/nio/channels/FileChannel;->lock()Ljava/nio/channels/FileLock;
:try_end_7d
.catch Ljava/lang/Exception; {:try_start_76 .. :try_end_7d} :catch_1cb
.catchall {:try_start_76 .. :try_end_7d} :catchall_1b9
move-result-object v6
:try_start_7e
new-instance v5, Ljava/io/BufferedWriter;
new-instance v2, Ljava/io/OutputStreamWriter;
new-instance v3, Ljava/io/FileOutputStream;
new-instance v9, Ljava/io/File;
const-string v10, "log1.txt"
invoke-direct {v9, v8, v10}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
const/4 v10, 0x1
invoke-direct {v3, v9, v10}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;Z)V
invoke-direct {v2, v3}, Ljava/io/OutputStreamWriter;-><init>(Ljava/io/OutputStream;)V
invoke-direct {v5, v2}, Ljava/io/BufferedWriter;-><init>(Ljava/io/Writer;)V
:try_end_95
.catch Ljava/lang/Exception; {:try_start_7e .. :try_end_95} :catch_1d0
.catchall {:try_start_7e .. :try_end_95} :catchall_1bc
:goto_95
:try_start_95
sget-object v2, Lcom/baidu/techain/af/dg;->g:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->isEmpty()Z
move-result v2
if-nez v2, :cond_11f
sget-object v2, Lcom/baidu/techain/af/dg;->g:Ljava/util/List;
const/4 v3, 0x0
invoke-interface {v2, v3}, Ljava/util/List;->remove(I)Ljava/lang/Object;
move-result-object v2
move-object v0, v2
check-cast v0, Landroid/util/Pair;
move-object v3, v0
iget-object v2, v3, Landroid/util/Pair;->first:Ljava/lang/Object;
check-cast v2, Ljava/lang/String;
iget-object v9, v3, Landroid/util/Pair;->second:Ljava/lang/Object;
if-eqz v9, :cond_dc
new-instance v9, Ljava/lang/StringBuilder;
invoke-direct {v9}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v9, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v9, "\n"
invoke-virtual {v2, v9}, 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
new-instance v9, Ljava/lang/StringBuilder;
invoke-direct {v9}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v9, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v9
iget-object v2, v3, Landroid/util/Pair;->second:Ljava/lang/Object;
check-cast v2, Ljava/lang/Throwable;
invoke-static {v2}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;
move-result-object v2
invoke-virtual {v9, v2}, 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
:cond_dc
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, "\n"
invoke-virtual {v2, v3}, 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 {v5, v2}, Ljava/io/BufferedWriter;->write(Ljava/lang/String;)V
:try_end_f2
.catch Ljava/lang/Exception; {:try_start_95 .. :try_end_f2} :catch_f3
.catchall {:try_start_95 .. :try_end_f2} :catchall_1be
goto :goto_95
:catch_f3
move-exception v2
move-object v3, v5
move-object v4, v6
move-object v5, v7
:goto_f7
:try_start_f7
iget-object v6, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
const-string v7, ""
invoke-static {v6, v7, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
:try_end_fe
.catchall {:try_start_f7 .. :try_end_fe} :catchall_1c1
if-eqz v3, :cond_103
:try_start_100
invoke-virtual {v3}, Ljava/io/BufferedWriter;->close()V
:try_end_103
.catch Ljava/io/IOException; {:try_start_100 .. :try_end_103} :catch_173
:cond_103
:goto_103
if-eqz v4, :cond_10e
invoke-virtual {v4}, Ljava/nio/channels/FileLock;->isValid()Z
move-result v2
if-eqz v2, :cond_10e
:try_start_10b
invoke-virtual {v4}, Ljava/nio/channels/FileLock;->release()V
:try_end_10e
.catch Ljava/io/IOException; {:try_start_10b .. :try_end_10e} :catch_17c
:cond_10e
:goto_10e
if-eqz v5, :cond_58
:try_start_110
invoke-virtual {v5}, Ljava/io/RandomAccessFile;->close()V
:try_end_113
.catch Ljava/io/IOException; {:try_start_110 .. :try_end_113} :catch_115
goto/16 :goto_58
:catch_115
move-exception v2
iget-object v3, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
const-string v4, ""
invoke-static {v3, v4, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto/16 :goto_58
:cond_11f
:try_start_11f
invoke-virtual {v5}, Ljava/io/BufferedWriter;->flush()V
invoke-virtual {v5}, Ljava/io/BufferedWriter;->close()V
:try_end_125
.catch Ljava/lang/Exception; {:try_start_11f .. :try_end_125} :catch_f3
.catchall {:try_start_11f .. :try_end_125} :catchall_1be
:try_start_125
new-instance v2, Ljava/io/File;
const-string v3, "log1.txt"
invoke-direct {v2, v8, v3}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
invoke-virtual {v2}, Ljava/io/File;->length()J
move-result-wide v10
const-wide/32 v12, 0x100000
cmp-long v3, v10, v12
if-ltz v3, :cond_150
new-instance v3, Ljava/io/File;
const-string v5, "log0.txt"
invoke-direct {v3, v8, v5}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
invoke-virtual {v3}, Ljava/io/File;->exists()Z
move-result v5
if-eqz v5, :cond_14d
invoke-virtual {v3}, Ljava/io/File;->isFile()Z
move-result v5
if-eqz v5, :cond_14d
invoke-virtual {v3}, Ljava/io/File;->delete()Z
:cond_14d
invoke-virtual {v2, v3}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
:try_end_150
.catch Ljava/lang/Exception; {:try_start_125 .. :try_end_150} :catch_1d0
.catchall {:try_start_125 .. :try_end_150} :catchall_1bc
:cond_150
if-eqz v6, :cond_15b
invoke-virtual {v6}, Ljava/nio/channels/FileLock;->isValid()Z
move-result v2
if-eqz v2, :cond_15b
:try_start_158
invoke-virtual {v6}, Ljava/nio/channels/FileLock;->release()V
:try_end_15b
.catch Ljava/io/IOException; {:try_start_158 .. :try_end_15b} :catch_16a
:cond_15b
:goto_15b
:try_start_15b
invoke-virtual {v7}, Ljava/io/RandomAccessFile;->close()V
:try_end_15e
.catch Ljava/io/IOException; {:try_start_15b .. :try_end_15e} :catch_160
goto/16 :goto_58
:catch_160
move-exception v2
iget-object v3, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
const-string v4, ""
invoke-static {v3, v4, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto/16 :goto_58
:catch_16a
move-exception v2
iget-object v3, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
const-string v4, ""
invoke-static {v3, v4, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_15b
:catch_173
move-exception v2
iget-object v3, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
const-string v6, ""
invoke-static {v3, v6, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_103
:catch_17c
move-exception v2
iget-object v3, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
const-string v4, ""
invoke-static {v3, v4, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_10e
:catchall_185
move-exception v2
move-object v6, v4
move-object v7, v4
:goto_188
if-eqz v4, :cond_18d
:try_start_18a
invoke-virtual {v4}, Ljava/io/BufferedWriter;->close()V
:try_end_18d
.catch Ljava/io/IOException; {:try_start_18a .. :try_end_18d} :catch_19e
:cond_18d
:goto_18d
if-eqz v6, :cond_198
invoke-virtual {v6}, Ljava/nio/channels/FileLock;->isValid()Z
move-result v3
if-eqz v3, :cond_198
:try_start_195
invoke-virtual {v6}, Ljava/nio/channels/FileLock;->release()V
:try_end_198
.catch Ljava/io/IOException; {:try_start_195 .. :try_end_198} :catch_1a7
:cond_198
:goto_198
if-eqz v7, :cond_19d
:try_start_19a
invoke-virtual {v7}, Ljava/io/RandomAccessFile;->close()V
:try_end_19d
.catch Ljava/io/IOException; {:try_start_19a .. :try_end_19d} :catch_1b0
:cond_19d
:goto_19d
throw v2
:catch_19e
move-exception v3
iget-object v4, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
const-string v5, ""
invoke-static {v4, v5, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_18d
:catch_1a7
move-exception v3
iget-object v4, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
const-string v5, ""
invoke-static {v4, v5, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_198
:catch_1b0
move-exception v3
iget-object v4, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
const-string v5, ""
invoke-static {v4, v5, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_19d
:catchall_1b9
move-exception v2
move-object v6, v4
goto :goto_188
:catchall_1bc
move-exception v2
goto :goto_188
:catchall_1be
move-exception v2
move-object v4, v5
goto :goto_188
:catchall_1c1
move-exception v2
move-object v6, v4
move-object v7, v5
move-object v4, v3
goto :goto_188
:catch_1c6
move-exception v2
move-object v3, v4
move-object v5, v4
goto/16 :goto_f7
:catch_1cb
move-exception v2
move-object v3, v4
move-object v5, v7
goto/16 :goto_f7
:catch_1d0
move-exception v2
move-object v3, v4
move-object v5, v7
move-object v4, v6
goto/16 :goto_f7
.end method
# virtual methods
.method public final a(Ljava/lang/String;)V
.registers 3
const/4 v0, 0x0
invoke-virtual {p0, p1, v0}, Lcom/baidu/techain/af/dg;->a(Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
.end method
.method public final a(Ljava/lang/String;Ljava/lang/Throwable;)V
.registers 10
sget-object v0, Lcom/baidu/techain/af/dg;->g:Ljava/util/List;
new-instance v1, Landroid/util/Pair;
const-string v2, "%1$s %2$s %3$s "
const/4 v3, 0x3
new-array v3, v3, [Ljava/lang/Object;
const/4 v4, 0x0
sget-object v5, Lcom/baidu/techain/af/dg;->b:Ljava/text/SimpleDateFormat;
new-instance v6, Ljava/util/Date;
invoke-direct {v6}, Ljava/util/Date;-><init>()V
invoke-virtual {v5, v6}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v5
aput-object v5, v3, v4
const/4 v4, 0x1
iget-object v5, p0, Lcom/baidu/techain/af/dg;->d:Ljava/lang/String;
aput-object v5, v3, v4
const/4 v4, 0x2
aput-object p1, v3, v4
invoke-static {v2, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
invoke-direct {v1, v2, p2}, Landroid/util/Pair;-><init>(Ljava/lang/Object;Ljava/lang/Object;)V
invoke-interface {v0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
sget-object v0, Lcom/baidu/techain/af/dg;->c:Lcom/baidu/techain/af/m;
new-instance v1, Lcom/baidu/techain/af/dh;
invoke-direct {v1, p0}, Lcom/baidu/techain/af/dh;-><init>(Lcom/baidu/techain/af/dg;)V
invoke-virtual {v0, v1}, Lcom/baidu/techain/af/m;->a(Lcom/baidu/techain/af/m$b;)V
return-void
.end method