a.smali
.class public Lcom/huawei/hms/support/log/b/a;
.super Ljava/lang/Object;
.source "FileLogNode.java"
# interfaces
.implements Lcom/huawei/hms/support/log/c;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/huawei/hms/support/log/b/a$a;
}
.end annotation
# instance fields
.field private a:Ljava/io/File;
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 23
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 164
return-void
.end method
.method private static a(Ljava/io/Closeable;)V
.registers 3
.prologue
.line 151
if-eqz p0, :cond_5
.line 153
:try_start_2
invoke-interface {p0}, Ljava/io/Closeable;->close()V
:try_end_5
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_5} :catch_6
.line 158
:cond_5
:goto_5
return-void
.line 154
:catch_6
move-exception v0
.line 155
const-string v0, "FileLogNode"
const-string v1, "Exception when closing the closeable."
invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_5
.end method
.method private a(Ljava/lang/String;)Z
.registers 6
.prologue
.line 105
iget-object v0, p0, Lcom/huawei/hms/support/log/b/a;->a:Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->length()J
move-result-wide v0
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result v2
int-to-long v2, v2
add-long/2addr v0, v2
const-wide/32 v2, 0x80000
cmp-long v0, v0, v2
if-lez v0, :cond_42
.line 106
new-instance v0, Ljava/io/File;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
iget-object v2, p0, Lcom/huawei/hms/support/log/b/a;->a:Ljava/io/File;
invoke-virtual {v2}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, ".bak"
invoke-virtual {v1, v2}, 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
invoke-direct {v0, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 108
iget-object v1, p0, Lcom/huawei/hms/support/log/b/a;->a:Ljava/io/File;
invoke-virtual {v1, v0}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
move-result v0
.line 109
if-nez v0, :cond_42
.line 110
const-string v0, "FileLogNode"
const-string v1, "Failed to backup the log file."
invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
.line 111
const/4 v0, 0x0
.line 115
:goto_41
return v0
:cond_42
const/4 v0, 0x1
goto :goto_41
.end method
.method private b(Ljava/lang/String;)V
.registers 8
.prologue
const/4 v1, 0x0
.line 124
.line 128
:try_start_1
new-instance v3, Ljava/io/FileOutputStream;
iget-object v0, p0, Lcom/huawei/hms/support/log/b/a;->a:Ljava/io/File;
const/4 v2, 0x1
invoke-direct {v3, v0, v2}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;Z)V
:try_end_9
.catch Ljava/io/FileNotFoundException; {:try_start_1 .. :try_end_9} :catch_25
.catch Ljava/io/IOException; {:try_start_1 .. :try_end_9} :catch_39
.catchall {:try_start_1 .. :try_end_9} :catchall_4d
.line 129
:try_start_9
new-instance v2, Ljava/io/BufferedOutputStream;
invoke-direct {v2, v3}, Ljava/io/BufferedOutputStream;-><init>(Ljava/io/OutputStream;)V
:try_end_e
.catch Ljava/io/FileNotFoundException; {:try_start_9 .. :try_end_e} :catch_73
.catch Ljava/io/IOException; {:try_start_9 .. :try_end_e} :catch_6b
.catchall {:try_start_9 .. :try_end_e} :catchall_5a
.line 130
:try_start_e
new-instance v0, Ljava/io/OutputStreamWriter;
const-string v4, "UTF-8"
invoke-direct {v0, v2, v4}, Ljava/io/OutputStreamWriter;-><init>(Ljava/io/OutputStream;Ljava/lang/String;)V
:try_end_15
.catch Ljava/io/FileNotFoundException; {:try_start_e .. :try_end_15} :catch_77
.catch Ljava/io/IOException; {:try_start_e .. :try_end_15} :catch_6e
.catchall {:try_start_e .. :try_end_15} :catchall_5d
.line 132
:try_start_15
invoke-virtual {v0, p1}, Ljava/io/OutputStreamWriter;->write(Ljava/lang/String;)V
.line 133
invoke-virtual {v0}, Ljava/io/OutputStreamWriter;->flush()V
:try_end_1b
.catch Ljava/io/FileNotFoundException; {:try_start_15 .. :try_end_1b} :catch_7c
.catch Ljava/io/IOException; {:try_start_15 .. :try_end_1b} :catch_70
.catchall {:try_start_15 .. :try_end_1b} :catchall_5f
.line 139
invoke-static {v0}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
.line 140
invoke-static {v2}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
.line 141
invoke-static {v3}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
.line 143
:goto_24
return-void
.line 134
:catch_25
move-exception v0
move-object v0, v1
move-object v2, v1
.line 135
:goto_28
:try_start_28
const-string v3, "FileLogNode"
const-string v4, "Exception when writing the log file."
invoke-static {v3, v4}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:try_end_2f
.catchall {:try_start_28 .. :try_end_2f} :catchall_64
.line 139
invoke-static {v0}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
.line 140
invoke-static {v1}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
.line 141
invoke-static {v2}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
goto :goto_24
.line 136
:catch_39
move-exception v0
move-object v2, v1
move-object v3, v1
.line 137
:goto_3c
:try_start_3c
const-string v0, "FileLogNode"
const-string v4, "Exception when writing the log file."
invoke-static {v0, v4}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:try_end_43
.catchall {:try_start_3c .. :try_end_43} :catchall_5d
.line 139
invoke-static {v1}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
.line 140
invoke-static {v2}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
.line 141
invoke-static {v3}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
goto :goto_24
.line 139
:catchall_4d
move-exception v0
move-object v2, v1
move-object v3, v1
:goto_50
invoke-static {v1}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
.line 140
invoke-static {v2}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
.line 141
invoke-static {v3}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/io/Closeable;)V
throw v0
.line 139
:catchall_5a
move-exception v0
move-object v2, v1
goto :goto_50
:catchall_5d
move-exception v0
goto :goto_50
:catchall_5f
move-exception v1
move-object v5, v1
move-object v1, v0
move-object v0, v5
goto :goto_50
:catchall_64
move-exception v3
move-object v5, v3
move-object v3, v2
move-object v2, v1
move-object v1, v0
move-object v0, v5
goto :goto_50
.line 136
:catch_6b
move-exception v0
move-object v2, v1
goto :goto_3c
:catch_6e
move-exception v0
goto :goto_3c
:catch_70
move-exception v1
move-object v1, v0
goto :goto_3c
.line 134
:catch_73
move-exception v0
move-object v0, v1
move-object v2, v3
goto :goto_28
:catch_77
move-exception v0
move-object v0, v1
move-object v1, v2
move-object v2, v3
goto :goto_28
:catch_7c
move-exception v1
move-object v1, v2
move-object v2, v3
goto :goto_28
.end method
# virtual methods
.method public a(Landroid/content/Context;Ljava/lang/String;)V
.registers 9
.prologue
const/4 v5, 0x1
const/4 v4, 0x0
.line 47
if-eqz p1, :cond_c
if-eqz p2, :cond_c
invoke-virtual {p2}, Ljava/lang/String;->isEmpty()Z
move-result v0
if-eqz v0, :cond_14
.line 48
:cond_c
const-string v0, "FileLogNode"
const-string v1, "Failed to initialize the file logger, parameter error."
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 70
:goto_13
return-void
.line 52
:cond_14
iget-object v0, p0, Lcom/huawei/hms/support/log/b/a;->a:Ljava/io/File;
if-nez v0, :cond_5c
.line 53
const/4 v0, 0x0
invoke-virtual {p1, v0}, Landroid/content/Context;->getExternalFilesDir(Ljava/lang/String;)Ljava/io/File;
move-result-object v0
.line 54
if-eqz v0, :cond_5c
.line 55
new-instance v1, Ljava/io/File;
const-string v2, "Log"
invoke-direct {v1, v0, v2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 57
invoke-virtual {v1}, Ljava/io/File;->isDirectory()Z
move-result v0
if-nez v0, :cond_32
invoke-virtual {v1}, Ljava/io/File;->mkdirs()Z
move-result v0
if-eqz v0, :cond_5c
.line 58
:cond_32
new-instance v0, Ljava/io/File;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
const-string v3, ".log"
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 {v0, v1, v2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
iput-object v0, p0, Lcom/huawei/hms/support/log/b/a;->a:Ljava/io/File;
.line 60
iget-object v0, p0, Lcom/huawei/hms/support/log/b/a;->a:Ljava/io/File;
invoke-virtual {v0, v5}, Ljava/io/File;->setReadable(Z)Z
.line 61
iget-object v0, p0, Lcom/huawei/hms/support/log/b/a;->a:Ljava/io/File;
invoke-virtual {v0, v5}, Ljava/io/File;->setWritable(Z)Z
.line 62
iget-object v0, p0, Lcom/huawei/hms/support/log/b/a;->a:Ljava/io/File;
invoke-virtual {v0, v4, v4}, Ljava/io/File;->setExecutable(ZZ)Z
goto :goto_13
.line 69
:cond_5c
const-string v0, "FileLogNode"
const-string v1, "Failed to initialize the file logger."
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_13
.end method
.method public a(Ljava/lang/String;ILjava/lang/String;Ljava/lang/String;)V
.registers 7
.prologue
.line 84
iget-object v0, p0, Lcom/huawei/hms/support/log/b/a;->a:Ljava/io/File;
if-nez v0, :cond_5
.line 97
:cond_4
:goto_4
return-void
.line 88
:cond_5
if-eqz p1, :cond_4
.line 92
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const/16 v1, 0xa
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 94
invoke-direct {p0, v0}, Lcom/huawei/hms/support/log/b/a;->a(Ljava/lang/String;)Z
move-result v1
if-eqz v1, :cond_4
.line 95
invoke-direct {p0, v0}, Lcom/huawei/hms/support/log/b/a;->b(Ljava/lang/String;)V
goto :goto_4
.end method