zzaz.smali
.class final Lcom/google/android/gms/internal/gtm/zzaz;
.super Landroid/database/sqlite/SQLiteOpenHelper;
# instance fields
.field private final synthetic zzxo:Lcom/google/android/gms/internal/gtm/zzay;
# direct methods
.method constructor <init>(Lcom/google/android/gms/internal/gtm/zzay;Landroid/content/Context;Ljava/lang/String;)V
.registers 5
.line 1
iput-object p1, p0, Lcom/google/android/gms/internal/gtm/zzaz;->zzxo:Lcom/google/android/gms/internal/gtm/zzay;
const/4 p1, 0x0
const/4 v0, 0x1
.line 2
invoke-direct {p0, p2, p3, p1, v0}, Landroid/database/sqlite/SQLiteOpenHelper;-><init>(Landroid/content/Context;Ljava/lang/String;Landroid/database/sqlite/SQLiteDatabase$CursorFactory;I)V
return-void
.end method
.method private final zza(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Z
.registers 13
const/4 v0, 0x0
const/4 v1, 0x0
:try_start_2
const-string v3, "SQLITE_MASTER"
const-string v2, "name"
.line 20
filled-new-array {v2}, [Ljava/lang/String;
move-result-object v4
const-string v5, "name=?"
const/4 v2, 0x1
new-array v6, v2, [Ljava/lang/String;
aput-object p2, v6, v0
const/4 v7, 0x0
const/4 v8, 0x0
const/4 v9, 0x0
move-object v2, p1
.line 21
invoke-virtual/range {v2 .. v9}, Landroid/database/sqlite/SQLiteDatabase;->query(Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v1
.line 22
invoke-interface {v1}, Landroid/database/Cursor;->moveToFirst()Z
move-result p1
:try_end_1d
.catch Landroid/database/sqlite/SQLiteException; {:try_start_2 .. :try_end_1d} :catch_25
.catchall {:try_start_2 .. :try_end_1d} :catchall_23
if-eqz v1, :cond_22
.line 24
invoke-interface {v1}, Landroid/database/Cursor;->close()V
:cond_22
return p1
:catchall_23
move-exception p1
goto :goto_33
:catch_25
move-exception p1
.line 27
:try_start_26
iget-object v2, p0, Lcom/google/android/gms/internal/gtm/zzaz;->zzxo:Lcom/google/android/gms/internal/gtm/zzay;
const-string v3, "Error querying for table"
invoke-virtual {v2, v3, p2, p1}, Lcom/google/android/gms/internal/gtm/zzam;->zzc(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
:try_end_2d
.catchall {:try_start_26 .. :try_end_2d} :catchall_23
if-eqz v1, :cond_32
.line 29
invoke-interface {v1}, Landroid/database/Cursor;->close()V
:cond_32
return v0
:goto_33
if-eqz v1, :cond_38
.line 32
invoke-interface {v1}, Landroid/database/Cursor;->close()V
:cond_38
throw p1
.end method
.method private static zzb(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Ljava/util/Set;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Landroid/database/sqlite/SQLiteDatabase;",
"Ljava/lang/String;",
")",
"Ljava/util/Set<",
"Ljava/lang/String;",
">;"
}
.end annotation
.line 33
new-instance v0, Ljava/util/HashSet;
invoke-direct {v0}, Ljava/util/HashSet;-><init>()V
.line 34
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v1
add-int/lit8 v1, v1, 0x16
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2, v1}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v1, "SELECT * FROM "
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, " LIMIT 0"
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const/4 v1, 0x0
.line 35
invoke-virtual {p0, p1, v1}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object p0
.line 36
:try_start_2a
invoke-interface {p0}, Landroid/database/Cursor;->getColumnNames()[Ljava/lang/String;
move-result-object p1
const/4 v1, 0x0
.line 37
:goto_2f
array-length v2, p1
if-ge v1, v2, :cond_3a
.line 38
aget-object v2, p1, v1
invoke-interface {v0, v2}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
:try_end_37
.catchall {:try_start_2a .. :try_end_37} :catchall_3e
add-int/lit8 v1, v1, 0x1
goto :goto_2f
.line 40
:cond_3a
invoke-interface {p0}, Landroid/database/Cursor;->close()V
return-object v0
:catchall_3e
move-exception p1
.line 42
invoke-interface {p0}, Landroid/database/Cursor;->close()V
throw p1
.end method
# virtual methods
.method public final getWritableDatabase()Landroid/database/sqlite/SQLiteDatabase;
.registers 4
.line 4
iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzaz;->zzxo:Lcom/google/android/gms/internal/gtm/zzay;
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzay;->zza(Lcom/google/android/gms/internal/gtm/zzay;)Lcom/google/android/gms/internal/gtm/zzcv;
move-result-object v0
const-wide/32 v1, 0x36ee80
invoke-virtual {v0, v1, v2}, Lcom/google/android/gms/internal/gtm/zzcv;->zzj(J)Z
move-result v0
if-eqz v0, :cond_4e
.line 6
:try_start_f
invoke-super {p0}, Landroid/database/sqlite/SQLiteOpenHelper;->getWritableDatabase()Landroid/database/sqlite/SQLiteDatabase;
move-result-object v0
:try_end_13
.catch Landroid/database/sqlite/SQLiteException; {:try_start_f .. :try_end_13} :catch_14
return-object v0
.line 9
:catch_14
iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzaz;->zzxo:Lcom/google/android/gms/internal/gtm/zzay;
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzay;->zza(Lcom/google/android/gms/internal/gtm/zzay;)Lcom/google/android/gms/internal/gtm/zzcv;
move-result-object v0
invoke-virtual {v0}, Lcom/google/android/gms/internal/gtm/zzcv;->start()V
.line 10
iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzaz;->zzxo:Lcom/google/android/gms/internal/gtm/zzay;
const-string v1, "Opening the database failed, dropping the table and recreating it"
invoke-virtual {v0, v1}, Lcom/google/android/gms/internal/gtm/zzam;->zzu(Ljava/lang/String;)V
.line 11
iget-object v0, p0, Lcom/google/android/gms/internal/gtm/zzaz;->zzxo:Lcom/google/android/gms/internal/gtm/zzay;
invoke-static {v0}, Lcom/google/android/gms/internal/gtm/zzay;->zzb(Lcom/google/android/gms/internal/gtm/zzay;)Ljava/lang/String;
move-result-object v0
.line 12
iget-object v1, p0, Lcom/google/android/gms/internal/gtm/zzaz;->zzxo:Lcom/google/android/gms/internal/gtm/zzay;
invoke-virtual {v1}, Lcom/google/android/gms/internal/gtm/zzam;->getContext()Landroid/content/Context;
move-result-object v1
invoke-virtual {v1, v0}, Landroid/content/Context;->getDatabasePath(Ljava/lang/String;)Ljava/io/File;
move-result-object v0
invoke-virtual {v0}, Ljava/io/File;->delete()Z
.line 13
:try_start_37
invoke-super {p0}, Landroid/database/sqlite/SQLiteOpenHelper;->getWritableDatabase()Landroid/database/sqlite/SQLiteDatabase;
move-result-object v0
.line 14
iget-object v1, p0, Lcom/google/android/gms/internal/gtm/zzaz;->zzxo:Lcom/google/android/gms/internal/gtm/zzay;
invoke-static {v1}, Lcom/google/android/gms/internal/gtm/zzay;->zza(Lcom/google/android/gms/internal/gtm/zzay;)Lcom/google/android/gms/internal/gtm/zzcv;
move-result-object v1
invoke-virtual {v1}, Lcom/google/android/gms/internal/gtm/zzcv;->clear()V
:try_end_44
.catch Landroid/database/sqlite/SQLiteException; {:try_start_37 .. :try_end_44} :catch_45
return-object v0
:catch_45
move-exception v0
.line 17
iget-object v1, p0, Lcom/google/android/gms/internal/gtm/zzaz;->zzxo:Lcom/google/android/gms/internal/gtm/zzay;
const-string v2, "Failed to open freshly created database"
invoke-virtual {v1, v2, v0}, Lcom/google/android/gms/internal/gtm/zzam;->zze(Ljava/lang/String;Ljava/lang/Object;)V
.line 18
throw v0
.line 5
:cond_4e
new-instance v0, Landroid/database/sqlite/SQLiteException;
const-string v1, "Database open failed"
invoke-direct {v0, v1}, Landroid/database/sqlite/SQLiteException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public final onCreate(Landroid/database/sqlite/SQLiteDatabase;)V
.registers 4
.line 77
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->getPath()Ljava/lang/String;
move-result-object p1
.line 78
invoke-static {}, Lcom/google/android/gms/internal/gtm/zzbx;->version()I
move-result v0
const/16 v1, 0x9
if-ge v0, v1, :cond_d
goto :goto_20
.line 81
:cond_d
new-instance v0, Ljava/io/File;
invoke-direct {v0, p1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
const/4 p1, 0x0
.line 82
invoke-virtual {v0, p1, p1}, Ljava/io/File;->setReadable(ZZ)Z
.line 83
invoke-virtual {v0, p1, p1}, Ljava/io/File;->setWritable(ZZ)Z
const/4 p1, 0x1
.line 84
invoke-virtual {v0, p1, p1}, Ljava/io/File;->setReadable(ZZ)Z
.line 85
invoke-virtual {v0, p1, p1}, Ljava/io/File;->setWritable(ZZ)Z
:goto_20
return-void
.end method
.method public final onOpen(Landroid/database/sqlite/SQLiteDatabase;)V
.registers 11
.line 44
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0xf
if-ge v0, v1, :cond_19
const/4 v0, 0x0
const-string v1, "PRAGMA journal_mode=memory"
.line 45
invoke-virtual {p1, v1, v0}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v0
.line 46
:try_start_d
invoke-interface {v0}, Landroid/database/Cursor;->moveToFirst()Z
:try_end_10
.catchall {:try_start_d .. :try_end_10} :catchall_14
.line 47
invoke-interface {v0}, Landroid/database/Cursor;->close()V
goto :goto_19
:catchall_14
move-exception p1
.line 49
invoke-interface {v0}, Landroid/database/Cursor;->close()V
throw p1
:cond_19
:goto_19
const-string v0, "hits2"
.line 50
invoke-direct {p0, p1, v0}, Lcom/google/android/gms/internal/gtm/zzaz;->zza(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Z
move-result v1
const/4 v2, 0x0
if-nez v1, :cond_2a
.line 51
invoke-static {}, Lcom/google/android/gms/internal/gtm/zzay;->zzdu()Ljava/lang/String;
move-result-object v0
invoke-virtual {p1, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
goto :goto_7b
.line 53
:cond_2a
invoke-static {p1, v0}, Lcom/google/android/gms/internal/gtm/zzaz;->zzb(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Ljava/util/Set;
move-result-object v0
const-string v1, "hit_id"
const-string v3, "hit_string"
const-string v4, "hit_time"
const-string v5, "hit_url"
.line 54
filled-new-array {v1, v3, v4, v5}, [Ljava/lang/String;
move-result-object v1
const/4 v3, 0x0
:goto_3b
const/4 v4, 0x4
if-ge v3, v4, :cond_66
.line 55
aget-object v4, v1, v3
.line 56
invoke-interface {v0, v4}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
move-result v5
if-nez v5, :cond_63
.line 57
new-instance p1, Landroid/database/sqlite/SQLiteException;
const-string v0, "Database hits2 is missing required column: "
invoke-static {v4}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v2
if-eqz v2, :cond_59
invoke-virtual {v0, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_5f
:cond_59
new-instance v1, Ljava/lang/String;
invoke-direct {v1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object v0, v1
:goto_5f
invoke-direct {p1, v0}, Landroid/database/sqlite/SQLiteException;-><init>(Ljava/lang/String;)V
throw p1
:cond_63
add-int/lit8 v3, v3, 0x1
goto :goto_3b
:cond_66
const-string v1, "hit_app_id"
.line 59
invoke-interface {v0, v1}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
move-result v1
xor-int/lit8 v1, v1, 0x1
.line 60
invoke-interface {v0}, Ljava/util/Set;->isEmpty()Z
move-result v0
if-eqz v0, :cond_d7
if-eqz v1, :cond_7b
const-string v0, "ALTER TABLE hits2 ADD COLUMN hit_app_id INTEGER"
.line 64
invoke-virtual {p1, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
:cond_7b
:goto_7b
const-string v0, "properties"
.line 65
invoke-direct {p0, p1, v0}, Lcom/google/android/gms/internal/gtm/zzaz;->zza(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Z
move-result v1
if-nez v1, :cond_89
const-string v0, "CREATE TABLE IF NOT EXISTS properties ( app_uid INTEGER NOT NULL, cid TEXT NOT NULL, tid TEXT NOT NULL, params TEXT NOT NULL, adid INTEGER NOT NULL, hits_count INTEGER NOT NULL, PRIMARY KEY (app_uid, cid, tid)) ;"
.line 66
invoke-virtual {p1, v0}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
return-void
.line 68
:cond_89
invoke-static {p1, v0}, Lcom/google/android/gms/internal/gtm/zzaz;->zzb(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;)Ljava/util/Set;
move-result-object p1
const-string v3, "app_uid"
const-string v4, "cid"
const-string v5, "tid"
const-string v6, "params"
const-string v7, "adid"
const-string v8, "hits_count"
.line 69
filled-new-array/range {v3 .. v8}, [Ljava/lang/String;
move-result-object v0
:goto_9d
const/4 v1, 0x6
if-ge v2, v1, :cond_c8
.line 70
aget-object v1, v0, v2
.line 71
invoke-interface {p1, v1}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
move-result v3
if-nez v3, :cond_c5
.line 72
new-instance p1, Landroid/database/sqlite/SQLiteException;
const-string v0, "Database properties is missing required column: "
invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v2
if-eqz v2, :cond_bb
invoke-virtual {v0, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
goto :goto_c1
:cond_bb
new-instance v1, Ljava/lang/String;
invoke-direct {v1, v0}, Ljava/lang/String;-><init>(Ljava/lang/String;)V
move-object v0, v1
:goto_c1
invoke-direct {p1, v0}, Landroid/database/sqlite/SQLiteException;-><init>(Ljava/lang/String;)V
throw p1
:cond_c5
add-int/lit8 v2, v2, 0x1
goto :goto_9d
.line 74
:cond_c8
invoke-interface {p1}, Ljava/util/Set;->isEmpty()Z
move-result p1
if-eqz p1, :cond_cf
return-void
.line 75
:cond_cf
new-instance p1, Landroid/database/sqlite/SQLiteException;
const-string v0, "Database properties table has extra columns"
invoke-direct {p1, v0}, Landroid/database/sqlite/SQLiteException;-><init>(Ljava/lang/String;)V
throw p1
.line 61
:cond_d7
new-instance p1, Landroid/database/sqlite/SQLiteException;
const-string v0, "Database hits2 has extra columns"
invoke-direct {p1, v0}, Landroid/database/sqlite/SQLiteException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method public final onUpgrade(Landroid/database/sqlite/SQLiteDatabase;II)V
.registers 4
return-void
.end method