LogPersister.smali

.class Lcom/vungle/warren/log/LogPersister;
.super Ljava/lang/Object;
.source "LogPersister.java"


# static fields
.field private static final SDK_CRASH_LOG_FILE_PATTERN:Ljava/lang/String; = "crash_"

.field private static final SDK_LOGS_DIR:Ljava/lang/String; = "sdk_logs"

.field private static final SDK_LOG_FILE_CRASH:Ljava/lang/String; = "_crash"

.field private static final SDK_LOG_FILE_PATTERN:Ljava/lang/String; = "log_"

.field private static final SDK_LOG_FILE_PENDING:Ljava/lang/String; = "_pending"

.field private static final TAG:Ljava/lang/String; = "LogPersister"


# instance fields
.field private entryCount:I

.field private listener:Lcom/vungle/warren/log/LogManager$SdkLoggingEventListener;

.field private logDir:Ljava/io/File;

.field private logFile:Ljava/io/File;

.field private maximumEntries:I


# direct methods
.method static constructor <clinit>()V
    .registers 0

    return-void
.end method

.method constructor <init>(Ljava/io/File;)V
    .registers 3

    .line 1
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    const/16 v0, 0x64

    .line 2
    iput v0, p0, Lcom/vungle/warren/log/LogPersister;->maximumEntries:I

    if-eqz p1, :cond_19

    .line 3
    invoke-direct {p0, p1}, Lcom/vungle/warren/log/LogPersister;->getOrCreateLogDir(Ljava/io/File;)Ljava/io/File;

    move-result-object p1

    iput-object p1, p0, Lcom/vungle/warren/log/LogPersister;->logDir:Ljava/io/File;

    .line 4
    iget-object p1, p0, Lcom/vungle/warren/log/LogPersister;->logDir:Ljava/io/File;

    if-eqz p1, :cond_19

    .line 5
    invoke-virtual {p0, p1}, Lcom/vungle/warren/log/LogPersister;->getOrCreateLogFile(Ljava/io/File;)Ljava/io/File;

    move-result-object p1

    iput-object p1, p0, Lcom/vungle/warren/log/LogPersister;->logFile:Ljava/io/File;

    :cond_19
    return-void
.end method

.method private createFileOrDirectory(Ljava/io/File;Ljava/lang/String;Z)Ljava/io/File;
    .registers 5

    .line 1
    new-instance v0, Ljava/io/File;

    invoke-direct {v0, p1, p2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V

    .line 2
    invoke-virtual {v0}, Ljava/io/File;->exists()Z

    move-result p1

    if-nez p1, :cond_21

    if-nez p3, :cond_1c

    .line 3
    :try_start_d
    invoke-virtual {v0}, Ljava/io/File;->createNewFile()Z

    move-result p1
    :try_end_11
    .catch Ljava/io/IOException; {:try_start_d .. :try_end_11} :catch_12

    goto :goto_22

    :catch_12
    move-exception p1

    .line 4
    sget-object p2, Lcom/vungle/warren/log/LogPersister;->TAG:Ljava/lang/String;

    const-string p3, ""

    invoke-static {p2, p3, p1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I

    const/4 p1, 0x0

    goto :goto_22

    .line 5
    :cond_1c
    invoke-virtual {v0}, Ljava/io/File;->mkdir()Z

    move-result p1

    goto :goto_22

    :cond_21
    const/4 p1, 0x1

    :goto_22
    if-eqz p1, :cond_25

    goto :goto_26

    :cond_25
    const/4 v0, 0x0

    :goto_26
    return-object v0
.end method

.method private static getDateText(J)Ljava/lang/String;
    .registers 5

    .line 1
    new-instance v0, Ljava/text/SimpleDateFormat;

    invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale;

    move-result-object v1

    const-string v2, "yyyy-MM-dd HH:mm:ss.SSS"

    invoke-direct {v0, v2, v1}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V

    .line 2
    new-instance v1, Ljava/util/Date;

    invoke-direct {v1, p0, p1}, Ljava/util/Date;-><init>(J)V

    invoke-virtual {v0, v1}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;

    move-result-object p0

    return-object p0
.end method

.method static getFileLineCount(Ljava/lang/String;)I
    .registers 4

    const/4 v0, 0x0

    .line 1
    :try_start_1
    new-instance v1, Ljava/io/LineNumberReader;

    new-instance v2, Ljava/io/FileReader;

    invoke-direct {v2, p0}, Ljava/io/FileReader;-><init>(Ljava/lang/String;)V

    invoke-direct {v1, v2}, Ljava/io/LineNumberReader;-><init>(Ljava/io/Reader;)V
    :try_end_b
    .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_b} :catch_26
    .catchall {:try_start_1 .. :try_end_b} :catchall_1f

    .line 2
    :goto_b
    :try_start_b
    invoke-virtual {v1}, Ljava/io/LineNumberReader;->readLine()Ljava/lang/String;

    move-result-object p0

    if-eqz p0, :cond_12

    goto :goto_b

    .line 3
    :cond_12
    invoke-virtual {v1}, Ljava/io/LineNumberReader;->getLineNumber()I

    move-result p0
    :try_end_16
    .catch Ljava/lang/Exception; {:try_start_b .. :try_end_16} :catch_1d
    .catchall {:try_start_b .. :try_end_16} :catchall_1a

    .line 4
    :try_start_16
    invoke-virtual {v1}, Ljava/io/LineNumberReader;->close()V
    :try_end_19
    .catch Ljava/lang/Exception; {:try_start_16 .. :try_end_19} :catch_2c

    goto :goto_2c

    :catchall_1a
    move-exception p0

    move-object v0, v1

    goto :goto_20

    :catch_1d
    move-object v0, v1

    goto :goto_26

    :catchall_1f
    move-exception p0

    :goto_20
    if-eqz v0, :cond_25

    :try_start_22
    invoke-virtual {v0}, Ljava/io/LineNumberReader;->close()V
    :try_end_25
    .catch Ljava/lang/Exception; {:try_start_22 .. :try_end_25} :catch_25

    .line 5
    :catch_25
    :cond_25
    throw p0

    :catch_26
    :goto_26
    const/4 p0, -0x1

    if-eqz v0, :cond_2c

    .line 6
    :try_start_29
    invoke-virtual {v0}, Ljava/io/LineNumberReader;->close()V
    :try_end_2c
    .catch Ljava/lang/Exception; {:try_start_29 .. :try_end_2c} :catch_2c

    :catch_2c
    :cond_2c
    :goto_2c
    return p0
.end method

.method private getOrCreateLogDir(Ljava/io/File;)Ljava/io/File;
    .registers 4

    const-string v0, "sdk_logs"

    const/4 v1, 0x1

    .line 1
    invoke-direct {p0, p1, v0, v1}, Lcom/vungle/warren/log/LogPersister;->createFileOrDirectory(Ljava/io/File;Ljava/lang/String;Z)Ljava/io/File;

    move-result-object p1

    if-eqz p1, :cond_11

    .line 2
    invoke-virtual {p1}, Ljava/io/File;->exists()Z

    move-result v0

    if-nez v0, :cond_10

    goto :goto_11

    :cond_10
    return-object p1

    .line 3
    :cond_11
    :goto_11
    sget-object p1, Lcom/vungle/warren/log/LogPersister;->TAG:Ljava/lang/String;

    const-string v0, "Failed to create vungle logs dir"

    invoke-static {p1, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    const/4 p1, 0x0

    return-object p1
.end method

.method private renameFile(Ljava/io/File;Ljava/lang/String;)Z
    .registers 6

    .line 1
    invoke-virtual {p1}, Ljava/io/File;->exists()Z

    move-result v0

    const/4 v1, 0x0

    if-eqz v0, :cond_21

    invoke-virtual {p1}, Ljava/io/File;->isFile()Z

    move-result v0

    if-nez v0, :cond_e

    goto :goto_21

    .line 2
    :cond_e
    new-instance v0, Ljava/io/File;

    iget-object v2, p0, Lcom/vungle/warren/log/LogPersister;->logDir:Ljava/io/File;

    invoke-direct {v0, v2, p2}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V

    .line 3
    invoke-virtual {v0}, Ljava/io/File;->exists()Z

    move-result p2

    if-eqz p2, :cond_1c

    return v1

    .line 4
    :cond_1c
    invoke-virtual {p1, v0}, Ljava/io/File;->renameTo(Ljava/io/File;)Z

    move-result p1

    return p1

    :cond_21
    :goto_21
    return v1
.end method


# virtual methods
.method getCrashReportFiles(I)[Ljava/io/File;
    .registers 5

    .line 1
    iget-object v0, p0, Lcom/vungle/warren/log/LogPersister;->logDir:Ljava/io/File;

    const/4 v1, 0x0

    if-nez v0, :cond_d

    .line 2
    sget-object p1, Lcom/vungle/warren/log/LogPersister;->TAG:Ljava/lang/String;

    const-string v0, "No log cache dir found."

    invoke-static {p1, v0}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I

    return-object v1

    .line 3
    :cond_d
    new-instance v2, Lcom/vungle/warren/log/LogPersister$4;

    invoke-direct {v2, p0}, Lcom/vungle/warren/log/LogPersister$4;-><init>(Lcom/vungle/warren/log/LogPersister;)V

    invoke-virtual {v0, v2}, Ljava/io/File;->listFiles(Ljava/io/FilenameFilter;)[Ljava/io/File;

    move-result-object v0

    if-eqz v0, :cond_31

    .line 4
    array-length v2, v0

    if-nez v2, :cond_1c

    goto :goto_31

    .line 5
    :cond_1c
    new-instance v1, Lcom/vungle/warren/log/LogPersister$5;

    invoke-direct {v1, p0}, Lcom/vungle/warren/log/LogPersister$5;-><init>(Lcom/vungle/warren/log/LogPersister;)V

    invoke-static {v0, v1}, Ljava/util/Arrays;->sort([Ljava/lang/Object;Ljava/util/Comparator;)V

    const/4 v1, 0x0

    .line 6
    array-length v2, v0

    invoke-static {v2, p1}, Ljava/lang/Math;->min(II)I

    move-result p1

    invoke-static {v0, v1, p1}, Ljava/util/Arrays;->copyOfRange([Ljava/lang/Object;II)[Ljava/lang/Object;

    move-result-object p1

    check-cast p1, [Ljava/io/File;

    return-object p1

    :cond_31
    :goto_31
    return-object v1
.end method

.method getOrCreateLogFile(Ljava/io/File;)Ljava/io/File;
    .registers 8

    .line 1
    new-instance v0, Lcom/vungle/warren/log/LogPersister$2;

    invoke-direct {v0, p0}, Lcom/vungle/warren/log/LogPersister$2;-><init>(Lcom/vungle/warren/log/LogPersister;)V

    invoke-virtual {p1, v0}, Ljava/io/File;->listFiles(Ljava/io/FilenameFilter;)[Ljava/io/File;

    move-result-object v0

    const/4 v1, 0x0

    if-eqz v0, :cond_57

    .line 2
    array-length v2, v0

    if-nez v2, :cond_10

    goto :goto_57

    .line 3
    :cond_10
    new-instance v2, Lcom/vungle/warren/log/LogPersister$3;

    invoke-direct {v2, p0}, Lcom/vungle/warren/log/LogPersister$3;-><init>(Lcom/vungle/warren/log/LogPersister;)V

    invoke-static {v0, v2}, Ljava/util/Arrays;->sort([Ljava/lang/Object;Ljava/util/Comparator;)V

    .line 4
    aget-object v0, v0, v1

    .line 5
    invoke-virtual {v0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v1

    invoke-static {v1}, Lcom/vungle/warren/log/LogPersister;->getFileLineCount(Ljava/lang/String;)I

    move-result v1

    if-lez v1, :cond_54

    .line 6
    iget v2, p0, Lcom/vungle/warren/log/LogPersister;->maximumEntries:I

    if-ge v1, v2, :cond_29

    goto :goto_54

    :cond_29
    const/4 v2, 0x0

    .line 7
    :try_start_2a
    iget-object v3, p0, Lcom/vungle/warren/log/LogPersister;->logFile:Ljava/io/File;

    new-instance v4, Ljava/lang/StringBuilder;

    invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V

    iget-object v5, p0, Lcom/vungle/warren/log/LogPersister;->logFile:Ljava/io/File;

    invoke-virtual {v5}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v5

    invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v5, "_pending"

    invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v4

    invoke-direct {p0, v3, v4}, Lcom/vungle/warren/log/LogPersister;->renameFile(Ljava/io/File;Ljava/lang/String;)Z

    move-result v3

    if-eqz v3, :cond_4d

    .line 8
    invoke-virtual {p0, p1}, Lcom/vungle/warren/log/LogPersister;->getOrCreateLogFile(Ljava/io/File;)Ljava/io/File;

    move-result-object v2
    :try_end_4d
    .catch Ljava/lang/Exception; {:try_start_2a .. :try_end_4d} :catch_4d

    :catch_4d
    :cond_4d
    if-nez v2, :cond_52

    .line 9
    iput v1, p0, Lcom/vungle/warren/log/LogPersister;->entryCount:I

    goto :goto_53

    :cond_52
    move-object v0, v2

    :goto_53
    return-object v0

    .line 10
    :cond_54
    :goto_54
    iput v1, p0, Lcom/vungle/warren/log/LogPersister;->entryCount:I

    return-object v0

    .line 11
    :cond_57
    :goto_57
    iput v1, p0, Lcom/vungle/warren/log/LogPersister;->entryCount:I

    .line 12
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v2, "log_"

    invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v2

    invoke-virtual {v0, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    invoke-static {}, Ljava/util/UUID;->randomUUID()Ljava/util/UUID;

    move-result-object v2

    invoke-virtual {v2}, Ljava/util/UUID;->toString()Ljava/lang/String;

    move-result-object v2

    invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    .line 13
    invoke-direct {p0, p1, v0, v1}, Lcom/vungle/warren/log/LogPersister;->createFileOrDirectory(Ljava/io/File;Ljava/lang/String;Z)Ljava/io/File;

    move-result-object p1

    return-object p1
.end method

.method getPendingFiles()[Ljava/io/File;
    .registers 3

    .line 1
    iget-object v0, p0, Lcom/vungle/warren/log/LogPersister;->logDir:Ljava/io/File;

    if-nez v0, :cond_d

    .line 2
    sget-object v0, Lcom/vungle/warren/log/LogPersister;->TAG:Ljava/lang/String;

    const-string v1, "No log cache dir found."

    invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I

    const/4 v0, 0x0

    return-object v0

    .line 3
    :cond_d
    new-instance v1, Lcom/vungle/warren/log/LogPersister$1;

    invoke-direct {v1, p0}, Lcom/vungle/warren/log/LogPersister$1;-><init>(Lcom/vungle/warren/log/LogPersister;)V

    invoke-virtual {v0, v1}, Ljava/io/File;->listFiles(Ljava/io/FilenameFilter;)[Ljava/io/File;

    move-result-object v0

    return-object v0
.end method

.method public saveCrashLogData(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
    .registers 24

    move-object v1, p0

    .line 1
    iget-object v0, v1, Lcom/vungle/warren/log/LogPersister;->logDir:Ljava/io/File;

    if-nez v0, :cond_d

    .line 2
    sget-object v0, Lcom/vungle/warren/log/LogPersister;->TAG:Ljava/lang/String;

    const-string v2, "No log cache dir found."

    invoke-static {v0, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    .line 3
    :cond_d
    invoke-static {}, Ljava/util/TimeZone;->getDefault()Ljava/util/TimeZone;

    move-result-object v0

    invoke-virtual {v0}, Ljava/util/TimeZone;->getID()Ljava/lang/String;

    move-result-object v9

    .line 4
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v2

    invoke-static {v2, v3}, Lcom/vungle/warren/log/LogPersister;->getDateText(J)Ljava/lang/String;

    move-result-object v10

    .line 5
    new-instance v0, Lcom/vungle/warren/log/LogEntry;

    move-object v2, v0

    move-object v3, p1

    move-object/from16 v4, p2

    move-object/from16 v5, p3

    move-object/from16 v6, p4

    move-object/from16 v7, p5

    move-object/from16 v8, p6

    move-object/from16 v11, p7

    move-object/from16 v12, p8

    move-object/from16 v13, p9

    invoke-direct/range {v2 .. v13}, Lcom/vungle/warren/log/LogEntry;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    .line 6
    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    const-string v3, "crash_"

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v3

    invoke-virtual {v2, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v2

    .line 7
    iget-object v3, v1, Lcom/vungle/warren/log/LogPersister;->logDir:Ljava/io/File;

    const/4 v4, 0x0

    invoke-direct {p0, v3, v2, v4}, Lcom/vungle/warren/log/LogPersister;->createFileOrDirectory(Ljava/io/File;Ljava/lang/String;Z)Ljava/io/File;

    move-result-object v2

    if-eqz v2, :cond_98

    const/4 v3, 0x0

    const/4 v5, 0x1

    .line 8
    :try_start_54
    new-instance v6, Ljava/io/FileWriter;

    invoke-direct {v6, v2, v5}, Ljava/io/FileWriter;-><init>(Ljava/io/File;Z)V
    :try_end_59
    .catch Ljava/io/IOException; {:try_start_54 .. :try_end_59} :catch_6f
    .catchall {:try_start_54 .. :try_end_59} :catchall_6d

    .line 9
    :try_start_59
    invoke-virtual {v0}, Lcom/vungle/warren/log/LogEntry;->toJsonString()Ljava/lang/String;

    move-result-object v0

    invoke-virtual {v6, v0}, Ljava/io/FileWriter;->append(Ljava/lang/CharSequence;)Ljava/io/Writer;

    .line 10
    invoke-virtual {v6}, Ljava/io/FileWriter;->flush()V
    :try_end_63
    .catch Ljava/io/IOException; {:try_start_59 .. :try_end_63} :catch_6b
    .catchall {:try_start_59 .. :try_end_63} :catchall_68

    .line 11
    invoke-static {v6}, Lcom/vungle/warren/utility/FileUtility;->closeQuietly(Ljava/io/Closeable;)V

    const/4 v4, 0x1

    goto :goto_79

    :catchall_68
    move-exception v0

    move-object v3, v6

    goto :goto_94

    :catch_6b
    move-object v3, v6

    goto :goto_6f

    :catchall_6d
    move-exception v0

    goto :goto_94

    .line 12
    :catch_6f
    :goto_6f
    :try_start_6f
    sget-object v0, Lcom/vungle/warren/log/LogPersister;->TAG:Ljava/lang/String;

    const-string v5, "Failed to write crash log."

    invoke-static {v0, v5}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_76
    .catchall {:try_start_6f .. :try_end_76} :catchall_6d

    .line 13
    invoke-static {v3}, Lcom/vungle/warren/utility/FileUtility;->closeQuietly(Ljava/io/Closeable;)V

    :goto_79
    if-eqz v4, :cond_98

    .line 14
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    invoke-virtual {v2}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v3

    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v3, "_crash"

    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    invoke-direct {p0, v2, v0}, Lcom/vungle/warren/log/LogPersister;->renameFile(Ljava/io/File;Ljava/lang/String;)Z

    goto :goto_98

    .line 15
    :goto_94
    invoke-static {v3}, Lcom/vungle/warren/utility/FileUtility;->closeQuietly(Ljava/io/Closeable;)V

    .line 16
    throw v0

    :cond_98
    :goto_98
    return-void
.end method

.method saveLogData(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
    .registers 24

    move-object v1, p0

    .line 1
    iget-object v0, v1, Lcom/vungle/warren/log/LogPersister;->logDir:Ljava/io/File;

    if-nez v0, :cond_d

    .line 2
    sget-object v0, Lcom/vungle/warren/log/LogPersister;->TAG:Ljava/lang/String;

    const-string v2, "No log cache dir found."

    invoke-static {v0, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    .line 3
    :cond_d
    iget-object v0, v1, Lcom/vungle/warren/log/LogPersister;->logFile:Ljava/io/File;

    if-eqz v0, :cond_17

    invoke-virtual {v0}, Ljava/io/File;->exists()Z

    move-result v0

    if-nez v0, :cond_32

    .line 4
    :cond_17
    sget-object v0, Lcom/vungle/warren/log/LogPersister;->TAG:Ljava/lang/String;

    const-string v2, "current log file maybe deleted, create new one."

    invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 5
    iget-object v0, v1, Lcom/vungle/warren/log/LogPersister;->logDir:Ljava/io/File;

    invoke-virtual {p0, v0}, Lcom/vungle/warren/log/LogPersister;->getOrCreateLogFile(Ljava/io/File;)Ljava/io/File;

    move-result-object v0

    iput-object v0, v1, Lcom/vungle/warren/log/LogPersister;->logFile:Ljava/io/File;

    .line 6
    iget-object v0, v1, Lcom/vungle/warren/log/LogPersister;->logFile:Ljava/io/File;

    if-eqz v0, :cond_cc

    invoke-virtual {v0}, Ljava/io/File;->exists()Z

    move-result v0

    if-nez v0, :cond_32

    goto/16 :goto_cc

    .line 7
    :cond_32
    invoke-static {}, Ljava/util/TimeZone;->getDefault()Ljava/util/TimeZone;

    move-result-object v0

    invoke-virtual {v0}, Ljava/util/TimeZone;->getID()Ljava/lang/String;

    move-result-object v9

    .line 8
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v2

    invoke-static {v2, v3}, Lcom/vungle/warren/log/LogPersister;->getDateText(J)Ljava/lang/String;

    move-result-object v10

    .line 9
    new-instance v0, Lcom/vungle/warren/log/LogEntry;

    move-object v2, v0

    move-object v3, p1

    move-object/from16 v4, p2

    move-object/from16 v5, p3

    move-object/from16 v6, p4

    move-object/from16 v7, p5

    move-object/from16 v8, p6

    move-object/from16 v11, p7

    move-object/from16 v12, p8

    move-object/from16 v13, p9

    invoke-direct/range {v2 .. v13}, Lcom/vungle/warren/log/LogEntry;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    const/4 v2, 0x0

    const/4 v3, 0x1

    .line 10
    :try_start_5b
    new-instance v4, Ljava/io/FileWriter;

    iget-object v5, v1, Lcom/vungle/warren/log/LogPersister;->logFile:Ljava/io/File;

    invoke-direct {v4, v5, v3}, Ljava/io/FileWriter;-><init>(Ljava/io/File;Z)V
    :try_end_62
    .catch Ljava/io/IOException; {:try_start_5b .. :try_end_62} :catch_81
    .catchall {:try_start_5b .. :try_end_62} :catchall_7f

    .line 11
    :try_start_62
    iget v2, v1, Lcom/vungle/warren/log/LogPersister;->entryCount:I

    if-lez v2, :cond_6b

    const-string v2, "\n"

    .line 12
    invoke-virtual {v4, v2}, Ljava/io/FileWriter;->append(Ljava/lang/CharSequence;)Ljava/io/Writer;

    .line 13
    :cond_6b
    invoke-virtual {v0}, Lcom/vungle/warren/log/LogEntry;->toJsonString()Ljava/lang/String;

    move-result-object v0

    invoke-virtual {v4, v0}, Ljava/io/FileWriter;->append(Ljava/lang/CharSequence;)Ljava/io/Writer;

    .line 14
    invoke-virtual {v4}, Ljava/io/FileWriter;->flush()V
    :try_end_75
    .catch Ljava/io/IOException; {:try_start_62 .. :try_end_75} :catch_7d
    .catchall {:try_start_62 .. :try_end_75} :catchall_7a

    .line 15
    invoke-static {v4}, Lcom/vungle/warren/utility/FileUtility;->closeQuietly(Ljava/io/Closeable;)V

    const/4 v0, 0x1

    goto :goto_8c

    :catchall_7a
    move-exception v0

    move-object v2, v4

    goto :goto_c8

    :catch_7d
    move-object v2, v4

    goto :goto_81

    :catchall_7f
    move-exception v0

    goto :goto_c8

    .line 16
    :catch_81
    :goto_81
    :try_start_81
    sget-object v0, Lcom/vungle/warren/log/LogPersister;->TAG:Ljava/lang/String;

    const-string v4, "Failed to write sdk logs."

    invoke-static {v0, v4}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_88
    .catchall {:try_start_81 .. :try_end_88} :catchall_7f

    const/4 v0, 0x0

    .line 17
    invoke-static {v2}, Lcom/vungle/warren/utility/FileUtility;->closeQuietly(Ljava/io/Closeable;)V

    :goto_8c
    if-eqz v0, :cond_c7

    .line 18
    iget v0, v1, Lcom/vungle/warren/log/LogPersister;->entryCount:I

    add-int/2addr v0, v3

    iput v0, v1, Lcom/vungle/warren/log/LogPersister;->entryCount:I

    .line 19
    iget v0, v1, Lcom/vungle/warren/log/LogPersister;->entryCount:I

    iget v2, v1, Lcom/vungle/warren/log/LogPersister;->maximumEntries:I

    if-lt v0, v2, :cond_c7

    .line 20
    iget-object v0, v1, Lcom/vungle/warren/log/LogPersister;->logFile:Ljava/io/File;

    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    iget-object v3, v1, Lcom/vungle/warren/log/LogPersister;->logFile:Ljava/io/File;

    invoke-virtual {v3}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v3

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v3, "_pending"

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v2

    invoke-direct {p0, v0, v2}, Lcom/vungle/warren/log/LogPersister;->renameFile(Ljava/io/File;Ljava/lang/String;)Z

    move-result v0

    if-eqz v0, :cond_c0

    .line 21
    iget-object v0, v1, Lcom/vungle/warren/log/LogPersister;->logDir:Ljava/io/File;

    invoke-virtual {p0, v0}, Lcom/vungle/warren/log/LogPersister;->getOrCreateLogFile(Ljava/io/File;)Ljava/io/File;

    move-result-object v0

    iput-object v0, v1, Lcom/vungle/warren/log/LogPersister;->logFile:Ljava/io/File;

    .line 22
    :cond_c0
    iget-object v0, v1, Lcom/vungle/warren/log/LogPersister;->listener:Lcom/vungle/warren/log/LogManager$SdkLoggingEventListener;

    if-eqz v0, :cond_c7

    .line 23
    invoke-interface {v0}, Lcom/vungle/warren/log/LogManager$SdkLoggingEventListener;->sendPendingLogs()V

    :cond_c7
    return-void

    .line 24
    :goto_c8
    invoke-static {v2}, Lcom/vungle/warren/utility/FileUtility;->closeQuietly(Ljava/io/Closeable;)V

    .line 25
    throw v0

    .line 26
    :cond_cc
    :goto_cc
    sget-object v0, Lcom/vungle/warren/log/LogPersister;->TAG:Ljava/lang/String;

    const-string v2, "Can\'t create log file, maybe no space left."

    invoke-static {v0, v2}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I

    return-void
.end method

.method setMaximumEntries(I)V
    .registers 2

    if-gtz p1, :cond_4

    const/16 p1, 0x64

    .line 1
    :cond_4
    iput p1, p0, Lcom/vungle/warren/log/LogPersister;->maximumEntries:I

    return-void
.end method

.method setSdkLoggingEventListener(Lcom/vungle/warren/log/LogManager$SdkLoggingEventListener;)V
    .registers 2

    .line 1
    iput-object p1, p0, Lcom/vungle/warren/log/LogPersister;->listener:Lcom/vungle/warren/log/LogManager$SdkLoggingEventListener;

    return-void
.end method