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