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