h0.smali
.class final Lf/b/b/a/i/x/j/h0;
.super Landroid/database/sqlite/SQLiteOpenHelper;
.source ""
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lf/b/b/a/i/x/j/h0$a;
}
.end annotation
# static fields
.field static g:I = 0x4
.field private static final h:Lf/b/b/a/i/x/j/h0$a;
.field private static final i:Lf/b/b/a/i/x/j/h0$a;
.field private static final j:Lf/b/b/a/i/x/j/h0$a;
.field private static final k:Lf/b/b/a/i/x/j/h0$a;
.field private static final l:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Lf/b/b/a/i/x/j/h0$a;",
">;"
}
.end annotation
.end field
# instance fields
.field private final e:I
.field private f:Z
# direct methods
.method static constructor <clinit>()V
.registers 6
invoke-static {}, Lf/b/b/a/i/x/j/d0;->b()Lf/b/b/a/i/x/j/h0$a;
move-result-object v0
sput-object v0, Lf/b/b/a/i/x/j/h0;->h:Lf/b/b/a/i/x/j/h0$a;
invoke-static {}, Lf/b/b/a/i/x/j/e0;->b()Lf/b/b/a/i/x/j/h0$a;
move-result-object v1
sput-object v1, Lf/b/b/a/i/x/j/h0;->i:Lf/b/b/a/i/x/j/h0$a;
invoke-static {}, Lf/b/b/a/i/x/j/f0;->b()Lf/b/b/a/i/x/j/h0$a;
move-result-object v2
sput-object v2, Lf/b/b/a/i/x/j/h0;->j:Lf/b/b/a/i/x/j/h0$a;
invoke-static {}, Lf/b/b/a/i/x/j/g0;->b()Lf/b/b/a/i/x/j/h0$a;
move-result-object v3
sput-object v3, Lf/b/b/a/i/x/j/h0;->k:Lf/b/b/a/i/x/j/h0$a;
const/4 v4, 0x4
new-array v4, v4, [Lf/b/b/a/i/x/j/h0$a;
const/4 v5, 0x0
aput-object v0, v4, v5
const/4 v0, 0x1
aput-object v1, v4, v0
const/4 v0, 0x2
aput-object v2, v4, v0
const/4 v0, 0x3
aput-object v3, v4, v0
invoke-static {v4}, Ljava/util/Arrays;->asList([Ljava/lang/Object;)Ljava/util/List;
move-result-object v0
sput-object v0, Lf/b/b/a/i/x/j/h0;->l:Ljava/util/List;
return-void
.end method
.method constructor <init>(Landroid/content/Context;Ljava/lang/String;I)V
.registers 5
const/4 v0, 0x0
invoke-direct {p0, p1, p2, v0, p3}, Landroid/database/sqlite/SQLiteOpenHelper;-><init>(Landroid/content/Context;Ljava/lang/String;Landroid/database/sqlite/SQLiteDatabase$CursorFactory;I)V
const/4 p1, 0x0
iput-boolean p1, p0, Lf/b/b/a/i/x/j/h0;->f:Z
iput p3, p0, Lf/b/b/a/i/x/j/h0;->e:I
return-void
.end method
.method static synthetic G(Landroid/database/sqlite/SQLiteDatabase;)V
.registers 2
const-string v0, "ALTER TABLE events ADD COLUMN inline BOOLEAN NOT NULL DEFAULT 1"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
const-string v0, "DROP TABLE IF EXISTS event_payloads"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
const-string v0, "CREATE TABLE event_payloads (sequence_num INTEGER NOT NULL, event_id INTEGER NOT NULL, bytes BLOB NOT NULL,FOREIGN KEY (event_id) REFERENCES events(_id) ON DELETE CASCADE,PRIMARY KEY (sequence_num, event_id))"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
return-void
.end method
.method private N(Landroid/database/sqlite/SQLiteDatabase;I)V
.registers 4
invoke-direct {p0, p1}, Lf/b/b/a/i/x/j/h0;->k(Landroid/database/sqlite/SQLiteDatabase;)V
const/4 v0, 0x0
invoke-direct {p0, p1, v0, p2}, Lf/b/b/a/i/x/j/h0;->O(Landroid/database/sqlite/SQLiteDatabase;II)V
return-void
.end method
.method private O(Landroid/database/sqlite/SQLiteDatabase;II)V
.registers 7
sget-object v0, Lf/b/b/a/i/x/j/h0;->l:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v1
if-gt p3, v1, :cond_19
:goto_8
if-ge p2, p3, :cond_18
sget-object v0, Lf/b/b/a/i/x/j/h0;->l:Ljava/util/List;
invoke-interface {v0, p2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lf/b/b/a/i/x/j/h0$a;
invoke-interface {v0, p1}, Lf/b/b/a/i/x/j/h0$a;->a(Landroid/database/sqlite/SQLiteDatabase;)V
add-int/lit8 p2, p2, 0x1
goto :goto_8
:cond_18
return-void
:cond_19
new-instance p1, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Migration from "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p2, " to "
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p2, " was requested, but cannot be performed. Only "
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-interface {v0}, Ljava/util/List;->size()I
move-result p2
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p2, " migrations are provided"
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
goto :goto_4a
:goto_49
throw p1
:goto_4a
goto :goto_49
.end method
.method private k(Landroid/database/sqlite/SQLiteDatabase;)V
.registers 3
iget-boolean v0, p0, Lf/b/b/a/i/x/j/h0;->f:Z
if-nez v0, :cond_7
invoke-virtual {p0, p1}, Lf/b/b/a/i/x/j/h0;->onConfigure(Landroid/database/sqlite/SQLiteDatabase;)V
:cond_7
return-void
.end method
.method static synthetic m(Landroid/database/sqlite/SQLiteDatabase;)V
.registers 2
const-string v0, "CREATE TABLE events (_id INTEGER PRIMARY KEY, context_id INTEGER NOT NULL, transport_name TEXT NOT NULL, timestamp_ms INTEGER NOT NULL, uptime_ms INTEGER NOT NULL, payload BLOB NOT NULL, code INTEGER, num_attempts INTEGER NOT NULL,FOREIGN KEY (context_id) REFERENCES transport_contexts(_id) ON DELETE CASCADE)"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
const-string v0, "CREATE TABLE event_metadata (_id INTEGER PRIMARY KEY, event_id INTEGER NOT NULL, name TEXT NOT NULL, value TEXT NOT NULL,FOREIGN KEY (event_id) REFERENCES events(_id) ON DELETE CASCADE)"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
const-string v0, "CREATE TABLE transport_contexts (_id INTEGER PRIMARY KEY, backend_name TEXT NOT NULL, priority INTEGER NOT NULL, next_request_ms INTEGER NOT NULL)"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
const-string v0, "CREATE INDEX events_backend_id on events(context_id)"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
const-string v0, "CREATE UNIQUE INDEX contexts_backend_priority on transport_contexts(backend_name, priority)"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
return-void
.end method
.method static synthetic r(Landroid/database/sqlite/SQLiteDatabase;)V
.registers 2
const-string v0, "ALTER TABLE transport_contexts ADD COLUMN extras BLOB"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
const-string v0, "CREATE UNIQUE INDEX contexts_backend_priority_extras on transport_contexts(backend_name, priority, extras)"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
const-string v0, "DROP INDEX contexts_backend_priority"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
return-void
.end method
.method static synthetic x(Landroid/database/sqlite/SQLiteDatabase;)V
.registers 2
const-string v0, "ALTER TABLE events ADD COLUMN payload_encoding TEXT"
invoke-virtual {p0, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
return-void
.end method
# virtual methods
.method public onConfigure(Landroid/database/sqlite/SQLiteDatabase;)V
.registers 5
const/4 v0, 0x1
iput-boolean v0, p0, Lf/b/b/a/i/x/j/h0;->f:Z
const/4 v1, 0x0
new-array v1, v1, [Ljava/lang/String;
const-string v2, "PRAGMA busy_timeout=0;"
invoke-virtual {p1, v2, v1}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v1
invoke-interface {v1}, Landroid/database/Cursor;->close()V
sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v2, 0x10
if-lt v1, v2, :cond_18
invoke-virtual {p1, v0}, Landroid/database/sqlite/SQLiteDatabase;->setForeignKeyConstraintsEnabled(Z)V
:cond_18
return-void
.end method
.method public onCreate(Landroid/database/sqlite/SQLiteDatabase;)V
.registers 3
iget v0, p0, Lf/b/b/a/i/x/j/h0;->e:I
invoke-direct {p0, p1, v0}, Lf/b/b/a/i/x/j/h0;->N(Landroid/database/sqlite/SQLiteDatabase;I)V
return-void
.end method
.method public onDowngrade(Landroid/database/sqlite/SQLiteDatabase;II)V
.registers 4
const-string p2, "DROP TABLE events"
invoke-virtual {p1, p2}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
const-string p2, "DROP TABLE event_metadata"
invoke-virtual {p1, p2}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
const-string p2, "DROP TABLE transport_contexts"
invoke-virtual {p1, p2}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
const-string p2, "DROP TABLE IF EXISTS event_payloads"
invoke-virtual {p1, p2}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
invoke-direct {p0, p1, p3}, Lf/b/b/a/i/x/j/h0;->N(Landroid/database/sqlite/SQLiteDatabase;I)V
return-void
.end method
.method public onOpen(Landroid/database/sqlite/SQLiteDatabase;)V
.registers 2
invoke-direct {p0, p1}, Lf/b/b/a/i/x/j/h0;->k(Landroid/database/sqlite/SQLiteDatabase;)V
return-void
.end method
.method public onUpgrade(Landroid/database/sqlite/SQLiteDatabase;II)V
.registers 4
invoke-direct {p0, p1}, Lf/b/b/a/i/x/j/h0;->k(Landroid/database/sqlite/SQLiteDatabase;)V
invoke-direct {p0, p1, p2, p3}, Lf/b/b/a/i/x/j/h0;->O(Landroid/database/sqlite/SQLiteDatabase;II)V
return-void
.end method