b$a.smali

.class Lcom/alibaba/mtl/log/c/b$a;
.super Landroid/database/sqlite/SQLiteOpenHelper;
.source "LogSqliteStore.java"


# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
    value = Lcom/alibaba/mtl/log/c/b;
.end annotation

.annotation system Ldalvik/annotation/InnerClass;
    accessFlags = 0x0
    name = "a"
.end annotation


# instance fields
.field private a:Landroid/database/sqlite/SQLiteDatabase;

.field final synthetic a:Lcom/alibaba/mtl/log/c/b;

.field private e:Ljava/util/concurrent/atomic/AtomicInteger;


# direct methods
.method constructor <init>(Lcom/alibaba/mtl/log/c/b;Landroid/content/Context;)V
    .registers 5

    .line 1
    iput-object p1, p0, Lcom/alibaba/mtl/log/c/b$a;->a:Lcom/alibaba/mtl/log/c/b;

    const-string/jumbo p1, "ut.db"

    const/4 v0, 0x0

    const/4 v1, 0x2

    .line 2
    invoke-direct {p0, p2, p1, v0, v1}, Landroid/database/sqlite/SQLiteOpenHelper;-><init>(Landroid/content/Context;Ljava/lang/String;Landroid/database/sqlite/SQLiteDatabase$CursorFactory;I)V

    .line 3
    new-instance p1, Ljava/util/concurrent/atomic/AtomicInteger;

    invoke-direct {p1}, Ljava/util/concurrent/atomic/AtomicInteger;-><init>()V

    iput-object p1, p0, Lcom/alibaba/mtl/log/c/b$a;->e:Ljava/util/concurrent/atomic/AtomicInteger;

    return-void
.end method


# virtual methods
.method public declared-synchronized a(Landroid/database/sqlite/SQLiteDatabase;)V
    .registers 2

    monitor-enter p0

    if-nez p1, :cond_5

    .line 1
    monitor-exit p0

    return-void

    .line 2
    :cond_5
    :try_start_5
    iget-object p1, p0, Lcom/alibaba/mtl/log/c/b$a;->e:Ljava/util/concurrent/atomic/AtomicInteger;

    invoke-virtual {p1}, Ljava/util/concurrent/atomic/AtomicInteger;->decrementAndGet()I

    move-result p1

    if-nez p1, :cond_1d

    .line 3
    iget-object p1, p0, Lcom/alibaba/mtl/log/c/b$a;->a:Landroid/database/sqlite/SQLiteDatabase;

    if-eqz p1, :cond_1d

    .line 4
    iget-object p1, p0, Lcom/alibaba/mtl/log/c/b$a;->a:Landroid/database/sqlite/SQLiteDatabase;

    invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->close()V

    const/4 p1, 0x0

    .line 5
    iput-object p1, p0, Lcom/alibaba/mtl/log/c/b$a;->a:Landroid/database/sqlite/SQLiteDatabase;
    :try_end_19
    .catch Ljava/lang/Throwable; {:try_start_5 .. :try_end_19} :catch_1d
    .catchall {:try_start_5 .. :try_end_19} :catchall_1a

    goto :goto_1d

    :catchall_1a
    move-exception p1

    monitor-exit p0

    throw p1

    .line 6
    :catch_1d
    :cond_1d
    :goto_1d
    monitor-exit p0

    return-void
.end method

.method public declared-synchronized getWritableDatabase()Landroid/database/sqlite/SQLiteDatabase;
    .registers 4

    monitor-enter p0

    .line 1
    :try_start_1
    iget-object v0, p0, Lcom/alibaba/mtl/log/c/b$a;->e:Ljava/util/concurrent/atomic/AtomicInteger;

    invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicInteger;->incrementAndGet()I

    move-result v0

    const/4 v1, 0x1

    if-ne v0, v1, :cond_1e

    .line 2
    invoke-super {p0}, Landroid/database/sqlite/SQLiteOpenHelper;->getWritableDatabase()Landroid/database/sqlite/SQLiteDatabase;

    move-result-object v0

    iput-object v0, p0, Lcom/alibaba/mtl/log/c/b$a;->a:Landroid/database/sqlite/SQLiteDatabase;
    :try_end_10
    .catch Ljava/lang/Throwable; {:try_start_1 .. :try_end_10} :catch_13
    .catchall {:try_start_1 .. :try_end_10} :catchall_11

    goto :goto_1e

    :catchall_11
    move-exception v0

    goto :goto_22

    :catch_13
    move-exception v0

    :try_start_14
    const-string v1, "TAG"

    const-string v2, "e"

    .line 3
    invoke-static {v1, v2, v0}, Lcom/alibaba/mtl/log/d/i;->a(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Throwable;)V

    .line 4
    invoke-static {v0}, Lcom/alibaba/mtl/appmonitor/b/b;->a(Ljava/lang/Throwable;)V

    .line 5
    :cond_1e
    :goto_1e
    iget-object v0, p0, Lcom/alibaba/mtl/log/c/b$a;->a:Landroid/database/sqlite/SQLiteDatabase;
    :try_end_20
    .catchall {:try_start_14 .. :try_end_20} :catchall_11

    monitor-exit p0

    return-object v0

    :goto_22
    monitor-exit p0

    throw v0
.end method

.method public onCreate(Landroid/database/sqlite/SQLiteDatabase;)V
    .registers 3

    const-string v0, "CREATE TABLE IF NOT EXISTS log (_id INTEGER PRIMARY KEY AUTOINCREMENT, eventId TEXT,priority TEXT, streamId TEXT, time TEXT, content TEXT, _index TEXT )"

    .line 1
    invoke-virtual {p1, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V

    return-void
.end method

.method public onOpen(Landroid/database/sqlite/SQLiteDatabase;)V
    .registers 4

    const/4 v0, 0x0

    :try_start_1
    const-string v1, "PRAGMA journal_mode=DELETE"

    .line 1
    invoke-virtual {p1, v1, v0}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;

    move-result-object v0
    :try_end_7
    .catch Ljava/lang/Throwable; {:try_start_1 .. :try_end_7} :catch_f
    .catchall {:try_start_1 .. :try_end_7} :catchall_8

    goto :goto_f

    :catchall_8
    move-exception p1

    .line 2
    iget-object v1, p0, Lcom/alibaba/mtl/log/c/b$a;->a:Lcom/alibaba/mtl/log/c/b;

    invoke-static {v1, v0}, Lcom/alibaba/mtl/log/c/b;->a(Lcom/alibaba/mtl/log/c/b;Landroid/database/Cursor;)V

    throw p1

    :catch_f
    :goto_f
    iget-object v1, p0, Lcom/alibaba/mtl/log/c/b$a;->a:Lcom/alibaba/mtl/log/c/b;

    invoke-static {v1, v0}, Lcom/alibaba/mtl/log/c/b;->a(Lcom/alibaba/mtl/log/c/b;Landroid/database/Cursor;)V

    .line 3
    invoke-super {p0, p1}, Landroid/database/sqlite/SQLiteOpenHelper;->onOpen(Landroid/database/sqlite/SQLiteDatabase;)V

    return-void
.end method

.method public onUpgrade(Landroid/database/sqlite/SQLiteDatabase;II)V
    .registers 5

    const/4 v0, 0x1

    if-ne p2, v0, :cond_14

    const/4 p2, 0x2

    if-ne p3, p2, :cond_14

    :try_start_6
    const-string p2, "ALTER TABLE log ADD COLUMN _index TEXT "

    .line 1
    invoke-virtual {p1, p2}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
    :try_end_b
    .catch Ljava/lang/Throwable; {:try_start_6 .. :try_end_b} :catch_c

    goto :goto_14

    :catch_c
    move-exception p1

    const-string p2, "UTSqliteLogStore"

    const-string p3, "DB Upgrade Error"

    .line 2
    invoke-static {p2, p3, p1}, Lcom/alibaba/mtl/log/d/i;->a(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Throwable;)V

    :cond_14
    :goto_14
    return-void
.end method