f.smali
.class public Lcom/xiaomi/push/a/f;
.super Ljava/lang/Object;
# interfaces
.implements Lcom/xiaomi/channel/commonutils/b/a;
# static fields
.field private static final a:Ljava/text/SimpleDateFormat;
.field private static b:Lcom/xiaomi/channel/commonutils/c/j;
.field private static c:Ljava/lang/String;
.field private static f: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;
# direct methods
.method static constructor <clinit>()V
.registers 2
new-instance v0, Ljava/text/SimpleDateFormat;
const-string/jumbo v1, "yyyy-MM-dd HH:mm:ss aaa"
invoke-direct {v0, v1}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;)V
sput-object v0, Lcom/xiaomi/push/a/f;->a:Ljava/text/SimpleDateFormat;
new-instance v0, Lcom/xiaomi/channel/commonutils/c/j;
const/4 v1, 0x1
invoke-direct {v0, v1}, Lcom/xiaomi/channel/commonutils/c/j;-><init>(Z)V
sput-object v0, Lcom/xiaomi/push/a/f;->b:Lcom/xiaomi/channel/commonutils/c/j;
const-string/jumbo v0, "/MiPushLog"
sput-object v0, Lcom/xiaomi/push/a/f;->c: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/xiaomi/push/a/f;->f: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
iput-object p1, p0, Lcom/xiaomi/push/a/f;->e:Landroid/content/Context;
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v0
if-eqz v0, :cond_11
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v0
iput-object v0, p0, Lcom/xiaomi/push/a/f;->e:Landroid/content/Context;
:cond_11
iget-object v0, p0, Lcom/xiaomi/push/a/f;->e:Landroid/content/Context;
invoke-virtual {v0}, Landroid/content/Context;->getPackageName()Ljava/lang/String;
move-result-object v0
iput-object v0, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
return-void
.end method
.method static synthetic a(Lcom/xiaomi/push/a/f;)Ljava/lang/String;
.registers 2
iget-object v0, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
return-object v0
.end method
.method static synthetic a()Ljava/util/List;
.registers 1
sget-object v0, Lcom/xiaomi/push/a/f;->f:Ljava/util/List;
return-object v0
.end method
.method private b()V
.registers 11
const/4 v2, 0x0
const/4 v0, 0x0
const/4 v1, 0x0
const/4 v3, 0x0
:try_start_4
new-instance v6, Ljava/io/File;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
iget-object v5, p0, Lcom/xiaomi/push/a/f;->e:Landroid/content/Context;
const/4 v7, 0x0
invoke-virtual {v5, v7}, Landroid/content/Context;->getExternalFilesDir(Ljava/lang/String;)Ljava/io/File;
move-result-object v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v4
sget-object v5, Lcom/xiaomi/push/a/f;->c:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-direct {v6, v4}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v6}, Ljava/io/File;->exists()Z
move-result v4
if-eqz v4, :cond_2f
invoke-virtual {v6}, Ljava/io/File;->isDirectory()Z
move-result v4
if-nez v4, :cond_53
:cond_2f
invoke-virtual {v6}, Ljava/io/File;->mkdirs()Z
move-result v4
if-nez v4, :cond_53
iget-object v4, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v5, "Create mipushlog directory fail."
invoke-static {v4, v5}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:try_end_3d
.catch Ljava/lang/Exception; {:try_start_4 .. :try_end_3d} :catch_207
.catchall {:try_start_4 .. :try_end_3d} :catchall_172
if-eqz v2, :cond_42
:try_start_3f
invoke-virtual {v3}, Ljava/io/BufferedWriter;->close()V
:try_end_42
.catch Ljava/io/IOException; {:try_start_3f .. :try_end_42} :catch_1bf
:cond_42
:goto_42
if-eqz v2, :cond_4d
invoke-virtual {v2}, Ljava/nio/channels/FileLock;->isValid()Z
move-result v3
if-eqz v3, :cond_4d
:try_start_4a
invoke-virtual {v1}, Ljava/nio/channels/FileLock;->release()V
:try_end_4d
.catch Ljava/io/IOException; {:try_start_4a .. :try_end_4d} :catch_1d2
:cond_4d
:goto_4d
if-eqz v2, :cond_52
:try_start_4f
invoke-virtual {v0}, Ljava/io/RandomAccessFile;->close()V
:try_end_52
.catch Ljava/io/IOException; {:try_start_4f .. :try_end_52} :catch_1ca
:cond_52
:goto_52
return-void
:cond_53
:try_start_53
new-instance v0, Ljava/io/File;
const-string/jumbo v1, "log.lock"
invoke-direct {v0, v6, v1}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v1
if-eqz v1, :cond_67
invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z
move-result v1
if-eqz v1, :cond_6a
:cond_67
invoke-virtual {v0}, Ljava/io/File;->createNewFile()Z
:cond_6a
new-instance v5, Ljava/io/RandomAccessFile;
const-string/jumbo v1, "rw"
invoke-direct {v5, v0, v1}, Ljava/io/RandomAccessFile;-><init>(Ljava/io/File;Ljava/lang/String;)V
:try_end_72
.catch Ljava/lang/Exception; {:try_start_53 .. :try_end_72} :catch_207
.catchall {:try_start_53 .. :try_end_72} :catchall_172
:try_start_72
invoke-virtual {v5}, Ljava/io/RandomAccessFile;->getChannel()Ljava/nio/channels/FileChannel;
move-result-object v0
invoke-virtual {v0}, Ljava/nio/channels/FileChannel;->lock()Ljava/nio/channels/FileLock;
:try_end_79
.catch Ljava/lang/Exception; {:try_start_72 .. :try_end_79} :catch_20c
.catchall {:try_start_72 .. :try_end_79} :catchall_1f3
move-result-object v4
:try_start_7a
new-instance v3, Ljava/io/BufferedWriter;
new-instance v0, Ljava/io/OutputStreamWriter;
new-instance v1, Ljava/io/FileOutputStream;
new-instance v7, Ljava/io/File;
const-string/jumbo v8, "log1.txt"
invoke-direct {v7, v6, v8}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
const/4 v8, 0x1
invoke-direct {v1, v7, v8}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;Z)V
invoke-direct {v0, v1}, Ljava/io/OutputStreamWriter;-><init>(Ljava/io/OutputStream;)V
invoke-direct {v3, v0}, Ljava/io/BufferedWriter;-><init>(Ljava/io/Writer;)V
:try_end_92
.catch Ljava/lang/Exception; {:try_start_7a .. :try_end_92} :catch_211
.catchall {:try_start_7a .. :try_end_92} :catchall_1f6
:goto_92
:try_start_92
sget-object v0, Lcom/xiaomi/push/a/f;->f:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v0
if-nez v0, :cond_11e
sget-object v0, Lcom/xiaomi/push/a/f;->f:Ljava/util/List;
const/4 v1, 0x0
invoke-interface {v0, v1}, Ljava/util/List;->remove(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/util/Pair;
iget-object v1, v0, Landroid/util/Pair;->first:Ljava/lang/Object;
check-cast v1, Ljava/lang/String;
iget-object v7, v0, Landroid/util/Pair;->second:Ljava/lang/Object;
if-eqz v7, :cond_d8
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v7, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string/jumbo v7, "\n"
invoke-virtual {v1, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
new-instance v7, Ljava/lang/StringBuilder;
invoke-direct {v7}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v7, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
iget-object v0, v0, Landroid/util/Pair;->second:Ljava/lang/Object;
check-cast v0, Ljava/lang/Throwable;
invoke-static {v0}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
:cond_d8
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string/jumbo v1, "\n"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/io/BufferedWriter;->write(Ljava/lang/String;)V
:try_end_ef
.catch Ljava/lang/Exception; {:try_start_92 .. :try_end_ef} :catch_f0
.catchall {:try_start_92 .. :try_end_ef} :catchall_1f9
goto :goto_92
:catch_f0
move-exception v0
move-object v1, v3
move-object v2, v4
move-object v3, v5
:goto_f4
:try_start_f4
iget-object v4, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v5, ""
invoke-static {v4, v5, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
:try_end_fc
.catchall {:try_start_f4 .. :try_end_fc} :catchall_201
if-eqz v1, :cond_101
:try_start_fe
invoke-virtual {v1}, Ljava/io/BufferedWriter;->close()V
:try_end_101
.catch Ljava/io/IOException; {:try_start_fe .. :try_end_101} :catch_1a9
:cond_101
:goto_101
if-eqz v2, :cond_10c
invoke-virtual {v2}, Ljava/nio/channels/FileLock;->isValid()Z
move-result v0
if-eqz v0, :cond_10c
:try_start_109
invoke-virtual {v2}, Ljava/nio/channels/FileLock;->release()V
:try_end_10c
.catch Ljava/io/IOException; {:try_start_109 .. :try_end_10c} :catch_1b4
:cond_10c
:goto_10c
if-eqz v3, :cond_52
:try_start_10e
invoke-virtual {v3}, Ljava/io/RandomAccessFile;->close()V
:try_end_111
.catch Ljava/io/IOException; {:try_start_10e .. :try_end_111} :catch_113
goto/16 :goto_52
:catch_113
move-exception v0
iget-object v1, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v2, ""
:goto_119
invoke-static {v1, v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto/16 :goto_52
:cond_11e
:try_start_11e
invoke-virtual {v3}, Ljava/io/BufferedWriter;->flush()V
if-eqz v3, :cond_21c
invoke-virtual {v3}, Ljava/io/BufferedWriter;->close()V
:try_end_126
.catch Ljava/lang/Exception; {:try_start_11e .. :try_end_126} :catch_f0
.catchall {:try_start_11e .. :try_end_126} :catchall_1f9
move-object v1, v2
:goto_127
:try_start_127
new-instance v0, Ljava/io/File;
const-string/jumbo v2, "log1.txt"
invoke-direct {v0, v6, v2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/io/File;->length()J
move-result-wide v2
const-wide/32 v8, 0x100000
cmp-long v2, v2, v8
if-ltz v2, :cond_154
new-instance v2, Ljava/io/File;
const-string/jumbo v3, "log0.txt"
invoke-direct {v2, v6, 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_151
invoke-virtual {v2}, Ljava/io/File;->isFile()Z
move-result v3
if-eqz v3, :cond_151
invoke-virtual {v2}, Ljava/io/File;->delete()Z
:cond_151
invoke-virtual {v0, v2}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
:try_end_154
.catch Ljava/lang/Exception; {:try_start_127 .. :try_end_154} :catch_217
.catchall {:try_start_127 .. :try_end_154} :catchall_1fd
:cond_154
if-eqz v1, :cond_159
:try_start_156
invoke-virtual {v1}, Ljava/io/BufferedWriter;->close()V
:try_end_159
.catch Ljava/io/IOException; {:try_start_156 .. :try_end_159} :catch_1dd
:cond_159
:goto_159
if-eqz v4, :cond_164
invoke-virtual {v4}, Ljava/nio/channels/FileLock;->isValid()Z
move-result v0
if-eqz v0, :cond_164
:try_start_161
invoke-virtual {v4}, Ljava/nio/channels/FileLock;->release()V
:try_end_164
.catch Ljava/io/IOException; {:try_start_161 .. :try_end_164} :catch_1e8
:cond_164
:goto_164
if-eqz v5, :cond_52
:try_start_166
invoke-virtual {v5}, Ljava/io/RandomAccessFile;->close()V
:try_end_169
.catch Ljava/io/IOException; {:try_start_166 .. :try_end_169} :catch_16b
goto/16 :goto_52
:catch_16b
move-exception v0
iget-object v1, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v2, ""
goto :goto_119
:catchall_172
move-exception v0
move-object v4, v2
move-object v5, v2
:goto_175
if-eqz v2, :cond_17a
:try_start_177
invoke-virtual {v2}, Ljava/io/BufferedWriter;->close()V
:try_end_17a
.catch Ljava/io/IOException; {:try_start_177 .. :try_end_17a} :catch_18b
:cond_17a
:goto_17a
if-eqz v4, :cond_185
invoke-virtual {v4}, Ljava/nio/channels/FileLock;->isValid()Z
move-result v1
if-eqz v1, :cond_185
:try_start_182
invoke-virtual {v4}, Ljava/nio/channels/FileLock;->release()V
:try_end_185
.catch Ljava/io/IOException; {:try_start_182 .. :try_end_185} :catch_19f
:cond_185
:goto_185
if-eqz v5, :cond_18a
:try_start_187
invoke-virtual {v5}, Ljava/io/RandomAccessFile;->close()V
:try_end_18a
.catch Ljava/io/IOException; {:try_start_187 .. :try_end_18a} :catch_195
:cond_18a
:goto_18a
throw v0
:catch_18b
move-exception v1
iget-object v2, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v3, ""
invoke-static {v2, v3, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_17a
:catch_195
move-exception v1
iget-object v2, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v3, ""
invoke-static {v2, v3, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_18a
:catch_19f
move-exception v1
iget-object v2, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v3, ""
invoke-static {v2, v3, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_185
:catch_1a9
move-exception v0
iget-object v1, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v4, ""
invoke-static {v1, v4, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto/16 :goto_101
:catch_1b4
move-exception v0
iget-object v1, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v2, ""
invoke-static {v1, v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto/16 :goto_10c
:catch_1bf
move-exception v3
iget-object v4, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v5, ""
invoke-static {v4, v5, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto/16 :goto_42
:catch_1ca
move-exception v0
iget-object v1, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v2, ""
goto/16 :goto_119
:catch_1d2
move-exception v1
iget-object v3, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v4, ""
invoke-static {v3, v4, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto/16 :goto_4d
:catch_1dd
move-exception v0
iget-object v1, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v2, ""
invoke-static {v1, v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto/16 :goto_159
:catch_1e8
move-exception v0
iget-object v1, p0, Lcom/xiaomi/push/a/f;->d:Ljava/lang/String;
const-string/jumbo v2, ""
invoke-static {v1, v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto/16 :goto_164
:catchall_1f3
move-exception v0
move-object v4, v2
goto :goto_175
:catchall_1f6
move-exception v0
goto/16 :goto_175
:catchall_1f9
move-exception v0
move-object v2, v3
goto/16 :goto_175
:catchall_1fd
move-exception v0
move-object v2, v1
goto/16 :goto_175
:catchall_201
move-exception v0
move-object v4, v2
move-object v5, v3
move-object v2, v1
goto/16 :goto_175
:catch_207
move-exception v0
move-object v1, v2
move-object v3, v2
goto/16 :goto_f4
:catch_20c
move-exception v0
move-object v1, v2
move-object v3, v5
goto/16 :goto_f4
:catch_211
move-exception v0
move-object v1, v2
move-object v3, v5
move-object v2, v4
goto/16 :goto_f4
:catch_217
move-exception v0
move-object v2, v4
move-object v3, v5
goto/16 :goto_f4
:cond_21c
move-object v1, v3
goto/16 :goto_127
.end method
.method static synthetic b(Lcom/xiaomi/push/a/f;)V
.registers 1
invoke-direct {p0}, Lcom/xiaomi/push/a/f;->b()V
return-void
.end method
# virtual methods
.method public final a(Ljava/lang/String;)V
.registers 3
const/4 v0, 0x0
invoke-virtual {p0, p1, v0}, Lcom/xiaomi/push/a/f;->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/xiaomi/push/a/f;->f:Ljava/util/List;
new-instance v1, Landroid/util/Pair;
const-string/jumbo 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/xiaomi/push/a/f;->a: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/xiaomi/push/a/f;->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/xiaomi/push/a/f;->b:Lcom/xiaomi/channel/commonutils/c/j;
new-instance v1, Lcom/xiaomi/push/a/g;
invoke-direct {v1, p0}, Lcom/xiaomi/push/a/g;-><init>(Lcom/xiaomi/push/a/f;)V
invoke-virtual {v0, v1}, Lcom/xiaomi/channel/commonutils/c/j;->a(Lcom/xiaomi/channel/commonutils/c/j$b;)V
return-void
.end method