2022-06-10 21:38:30 +09:00

2006 lines
52 KiB
Smali

.class public final Lcom/google/android/gms/measurement/internal/zzea;
.super Lcom/google/android/gms/measurement/internal/zzf;
.source "com.google.android.gms:play-services-measurement-impl@@20.1.0"
# instance fields
.field private final zza:Lcom/google/android/gms/measurement/internal/zzdz;
.field private zzb:Z
# direct methods
.method public constructor <init>(Lcom/google/android/gms/measurement/internal/zzfr;)V
.locals 2
.line 1
invoke-direct {p0, p1}, Lcom/google/android/gms/measurement/internal/zzf;-><init>(Lcom/google/android/gms/measurement/internal/zzfr;)V
new-instance p1, Lcom/google/android/gms/measurement/internal/zzdz;
iget-object v0, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 2
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzfr;->zzau()Landroid/content/Context;
move-result-object v0
iget-object v1, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 3
invoke-virtual {v1}, Lcom/google/android/gms/measurement/internal/zzfr;->zzf()Lcom/google/android/gms/measurement/internal/zzaf;
const-string v1, "google_app_measurement_local.db"
.line 4
invoke-direct {p1, p0, v0, v1}, Lcom/google/android/gms/measurement/internal/zzdz;-><init>(Lcom/google/android/gms/measurement/internal/zzea;Landroid/content/Context;Ljava/lang/String;)V
iput-object p1, p0, Lcom/google/android/gms/measurement/internal/zzea;->zza:Lcom/google/android/gms/measurement/internal/zzdz;
return-void
.end method
.method private final zzq(I[B)Z
.locals 13
.annotation build Landroidx/annotation/WorkerThread;
.end annotation
.line 1
invoke-virtual {p0}, Lcom/google/android/gms/measurement/internal/zze;->zzg()V
iget-boolean v0, p0, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
const/4 v1, 0x0
if-eqz v0, :cond_0
return v1
:cond_0
new-instance v0, Landroid/content/ContentValues;
.line 2
invoke-direct {v0}, Landroid/content/ContentValues;-><init>()V
.line 3
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p1
const-string v2, "type"
invoke-virtual {v0, v2, p1}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/Integer;)V
const-string p1, "entry"
.line 4
invoke-virtual {v0, p1, p2}, Landroid/content/ContentValues;->put(Ljava/lang/String;[B)V
iget-object p1, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 5
invoke-virtual {p1}, Lcom/google/android/gms/measurement/internal/zzfr;->zzf()Lcom/google/android/gms/measurement/internal/zzaf;
const/4 p1, 0x5
move p2, p1
move v2, v1
:goto_0
if-ge v1, p1, :cond_c
const/4 p1, 0x1
const/4 v3, 0x0
.line 6
:try_start_0
invoke-virtual {p0}, Lcom/google/android/gms/measurement/internal/zzea;->zzh()Landroid/database/sqlite/SQLiteDatabase;
move-result-object v4
:try_end_0
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_0 .. :try_end_0} :catch_8
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_0 .. :try_end_0} :catch_6
.catch Landroid/database/sqlite/SQLiteException; {:try_start_0 .. :try_end_0} :catch_5
.catchall {:try_start_0 .. :try_end_0} :catchall_2
if-nez v4, :cond_1
:try_start_1
iput-boolean p1, p0, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
return v2
.line 7
:cond_1
invoke-virtual {v4}, Landroid/database/sqlite/SQLiteDatabase;->beginTransaction()V
const-string v5, "select count(1) from messages"
.line 8
invoke-virtual {v4, v5, v3}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v5
:try_end_1
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_1 .. :try_end_1} :catch_4
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_1 .. :try_end_1} :catch_7
.catch Landroid/database/sqlite/SQLiteException; {:try_start_1 .. :try_end_1} :catch_3
.catchall {:try_start_1 .. :try_end_1} :catchall_1
const-wide/16 v6, 0x0
if-eqz v5, :cond_2
.line 9
:try_start_2
invoke-interface {v5}, Landroid/database/Cursor;->moveToFirst()Z
move-result v8
if-eqz v8, :cond_2
.line 10
invoke-interface {v5, v2}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v6
:try_end_2
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_2 .. :try_end_2} :catch_1
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_2 .. :try_end_2} :catch_2
.catch Landroid/database/sqlite/SQLiteException; {:try_start_2 .. :try_end_2} :catch_0
.catchall {:try_start_2 .. :try_end_2} :catchall_0
goto :goto_1
:catchall_0
move-exception p1
goto :goto_2
:catch_0
move-exception p1
goto :goto_3
:catch_1
move-exception p1
goto :goto_4
:cond_2
:goto_1
const-wide/32 v8, 0x186a0
cmp-long v10, v6, v8
const-string v11, "messages"
if-ltz v10, :cond_3
:try_start_3
iget-object v10, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 11
invoke-virtual {v10}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v10
.line 12
invoke-virtual {v10}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v10
const-string v12, "Data loss, local db full"
invoke-virtual {v10, v12}, Lcom/google/android/gms/measurement/internal/zzef;->zza(Ljava/lang/String;)V
sub-long/2addr v8, v6
const-wide/16 v6, 0x1
add-long/2addr v8, v6
new-array p1, p1, [Ljava/lang/String;
.line 13
invoke-static {v8, v9}, Ljava/lang/Long;->toString(J)Ljava/lang/String;
move-result-object v6
aput-object v6, p1, v2
const-string v2, "rowid in (select rowid from messages order by rowid asc limit ?)"
.line 14
invoke-virtual {v4, v11, v2, p1}, Landroid/database/sqlite/SQLiteDatabase;->delete(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)I
move-result p1
int-to-long v6, p1
cmp-long p1, v6, v8
if-eqz p1, :cond_3
iget-object p1, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 15
invoke-virtual {p1}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object p1
.line 16
invoke-virtual {p1}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object p1
const-string v2, "Different delete count than expected in local db. expected, received, difference"
.line 17
invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v10
.line 18
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v12
sub-long/2addr v8, v6
.line 19
invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v6
.line 20
invoke-virtual {p1, v2, v10, v12, v6}, Lcom/google/android/gms/measurement/internal/zzef;->zzd(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
.line 21
:cond_3
invoke-virtual {v4, v11, v3, v0}, Landroid/database/sqlite/SQLiteDatabase;->insertOrThrow(Ljava/lang/String;Ljava/lang/String;Landroid/content/ContentValues;)J
.line 22
invoke-virtual {v4}, Landroid/database/sqlite/SQLiteDatabase;->setTransactionSuccessful()V
.line 23
invoke-virtual {v4}, Landroid/database/sqlite/SQLiteDatabase;->endTransaction()V
:try_end_3
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_3 .. :try_end_3} :catch_1
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_3 .. :try_end_3} :catch_2
.catch Landroid/database/sqlite/SQLiteException; {:try_start_3 .. :try_end_3} :catch_0
.catchall {:try_start_3 .. :try_end_3} :catchall_0
if-eqz v5, :cond_4
.line 24
invoke-interface {v5}, Landroid/database/Cursor;->close()V
.line 25
:cond_4
invoke-virtual {v4}, Landroid/database/sqlite/SQLiteDatabase;->close()V
const/4 p1, 0x1
return p1
:goto_2
move-object v3, v5
goto/16 :goto_c
:goto_3
move-object v3, v5
goto :goto_5
:catch_2
move-object v3, v5
goto :goto_7
:goto_4
move-object v3, v5
goto :goto_8
:catchall_1
move-exception p1
goto/16 :goto_c
:catch_3
move-exception p1
:goto_5
move-object v2, v3
move-object v3, v4
goto :goto_6
:catch_4
move-exception p1
goto :goto_8
:catchall_2
move-exception p1
move-object v4, v3
goto/16 :goto_c
:catch_5
move-exception p1
move-object v2, v3
:goto_6
if-eqz v3, :cond_5
.line 26
:try_start_4
invoke-virtual {v3}, Landroid/database/sqlite/SQLiteDatabase;->inTransaction()Z
move-result v4
if-eqz v4, :cond_5
.line 27
invoke-virtual {v3}, Landroid/database/sqlite/SQLiteDatabase;->endTransaction()V
:cond_5
iget-object v4, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 28
invoke-virtual {v4}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v4
.line 29
invoke-virtual {v4}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v4
const-string v5, "Error writing entry to local database"
invoke-virtual {v4, v5, p1}, Lcom/google/android/gms/measurement/internal/zzef;->zzb(Ljava/lang/String;Ljava/lang/Object;)V
const/4 p1, 0x1
iput-boolean p1, p0, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
:try_end_4
.catchall {:try_start_4 .. :try_end_4} :catchall_3
if-eqz v2, :cond_6
.line 30
invoke-interface {v2}, Landroid/database/Cursor;->close()V
:cond_6
if-eqz v3, :cond_9
goto :goto_9
:catchall_3
move-exception p1
goto :goto_b
:catch_6
move-object v4, v3
:catch_7
:goto_7
int-to-long v5, p2
.line 31
:try_start_5
invoke-static {v5, v6}, Landroid/os/SystemClock;->sleep(J)V
:try_end_5
.catchall {:try_start_5 .. :try_end_5} :catchall_1
add-int/lit8 p2, p2, 0x14
if-eqz v3, :cond_7
.line 32
invoke-interface {v3}, Landroid/database/Cursor;->close()V
:cond_7
if-eqz v4, :cond_9
.line 33
invoke-virtual {v4}, Landroid/database/sqlite/SQLiteDatabase;->close()V
goto :goto_a
:catch_8
move-exception p1
move-object v4, v3
.line 34
:goto_8
:try_start_6
iget-object v2, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 35
invoke-virtual {v2}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v2
.line 36
invoke-virtual {v2}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v2
const-string v5, "Error writing entry; local database full"
invoke-virtual {v2, v5, p1}, Lcom/google/android/gms/measurement/internal/zzef;->zzb(Ljava/lang/String;Ljava/lang/Object;)V
const/4 p1, 0x1
iput-boolean p1, p0, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
:try_end_6
.catchall {:try_start_6 .. :try_end_6} :catchall_4
if-eqz v3, :cond_8
.line 37
invoke-interface {v3}, Landroid/database/Cursor;->close()V
:cond_8
if-eqz v4, :cond_9
move-object v3, v4
.line 38
:goto_9
invoke-virtual {v3}, Landroid/database/sqlite/SQLiteDatabase;->close()V
:cond_9
:goto_a
add-int/lit8 v1, v1, 0x1
const/4 v2, 0x0
const/4 p1, 0x5
goto/16 :goto_0
:catchall_4
move-exception p1
move-object v2, v3
move-object v3, v4
:goto_b
move-object v4, v3
move-object v3, v2
:goto_c
if-eqz v3, :cond_a
.line 39
invoke-interface {v3}, Landroid/database/Cursor;->close()V
:cond_a
if-eqz v4, :cond_b
.line 40
invoke-virtual {v4}, Landroid/database/sqlite/SQLiteDatabase;->close()V
.line 41
:cond_b
throw p1
.line 42
:cond_c
iget-object p1, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
const-string p2, "Failed to write entry to local database"
.line 43
invoke-static {p1, p2}, Lcom/google/android/gms/measurement/internal/c;->a(Lcom/google/android/gms/measurement/internal/zzfr;Ljava/lang/String;)V
const/4 p1, 0x0
return p1
.end method
# virtual methods
.method public final zzf()Z
.locals 1
const/4 v0, 0x0
return v0
.end method
.method public final zzh()Landroid/database/sqlite/SQLiteDatabase;
.locals 2
.annotation build Landroidx/annotation/WorkerThread;
.end annotation
.annotation build Lcom/google/android/gms/common/util/VisibleForTesting;
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Landroid/database/sqlite/SQLiteException;
}
.end annotation
.line 1
iget-boolean v0, p0, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
const/4 v1, 0x0
if-eqz v0, :cond_0
return-object v1
:cond_0
iget-object v0, p0, Lcom/google/android/gms/measurement/internal/zzea;->zza:Lcom/google/android/gms/measurement/internal/zzdz;
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzdz;->getWritableDatabase()Landroid/database/sqlite/SQLiteDatabase;
move-result-object v0
if-nez v0, :cond_1
const/4 v0, 0x1
iput-boolean v0, p0, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
return-object v1
:cond_1
return-object v0
.end method
.method public final zzi(I)Ljava/util/List;
.locals 22
move-object/from16 v1, p0
const-string v2, "rowid"
const-string v3, "Error reading entries from local database"
.line 1
invoke-virtual/range {p0 .. p0}, Lcom/google/android/gms/measurement/internal/zze;->zzg()V
iget-boolean v0, v1, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
const/4 v4, 0x0
if-eqz v0, :cond_0
return-object v4
:cond_0
new-instance v5, Ljava/util/ArrayList;
.line 2
invoke-direct {v5}, Ljava/util/ArrayList;-><init>()V
.line 3
invoke-virtual/range {p0 .. p0}, Lcom/google/android/gms/measurement/internal/zzea;->zzl()Z
move-result v0
if-eqz v0, :cond_14
const/4 v6, 0x5
const/4 v7, 0x0
move v9, v6
move v8, v7
:goto_0
if-ge v8, v6, :cond_13
const/4 v10, 0x1
.line 4
:try_start_0
invoke-virtual/range {p0 .. p0}, Lcom/google/android/gms/measurement/internal/zzea;->zzh()Landroid/database/sqlite/SQLiteDatabase;
move-result-object v15
:try_end_0
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_0 .. :try_end_0} :catch_14
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_0 .. :try_end_0} :catch_13
.catch Landroid/database/sqlite/SQLiteException; {:try_start_0 .. :try_end_0} :catch_12
.catchall {:try_start_0 .. :try_end_0} :catchall_b
if-nez v15, :cond_1
:try_start_1
iput-boolean v10, v1, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
return-object v4
.line 5
:cond_1
invoke-virtual {v15}, Landroid/database/sqlite/SQLiteDatabase;->beginTransaction()V
const-string v0, "3"
:try_end_1
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_1 .. :try_end_1} :catch_11
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_1 .. :try_end_1} :catch_e
.catch Landroid/database/sqlite/SQLiteException; {:try_start_1 .. :try_end_1} :catch_d
.catchall {:try_start_1 .. :try_end_1} :catchall_a
:try_start_2
const-string v12, "messages"
filled-new-array {v2}, [Ljava/lang/String;
move-result-object v13
const-string v14, "type=?"
filled-new-array {v0}, [Ljava/lang/String;
move-result-object v0
const/16 v16, 0x0
const/16 v17, 0x0
const-string v18, "rowid desc"
const-string v19, "1"
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_8
move-object v11, v15
move-object/from16 p1, v15
move-object v15, v0
.line 6
:try_start_3
invoke-virtual/range {v11 .. v19}, 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;Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v11
:try_end_3
.catchall {:try_start_3 .. :try_end_3} :catchall_7
.line 7
:try_start_4
invoke-interface {v11}, Landroid/database/Cursor;->moveToFirst()Z
move-result v0
const-wide/16 v20, -0x1
if-eqz v0, :cond_2
.line 8
invoke-interface {v11, v7}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v12
:try_end_4
.catchall {:try_start_4 .. :try_end_4} :catchall_6
.line 9
:try_start_5
invoke-interface {v11}, Landroid/database/Cursor;->close()V
goto :goto_1
:cond_2
invoke-interface {v11}, Landroid/database/Cursor;->close()V
move-wide/from16 v12, v20
:goto_1
cmp-long v0, v12, v20
if-eqz v0, :cond_3
const-string v0, "rowid<?"
new-array v11, v10, [Ljava/lang/String;
.line 10
invoke-static {v12, v13}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v12
aput-object v12, v11, v7
move-object v14, v0
move-object v15, v11
goto :goto_2
:cond_3
move-object v14, v4
move-object v15, v14
:goto_2
const-string v0, "type"
const-string v11, "entry"
filled-new-array {v2, v0, v11}, [Ljava/lang/String;
move-result-object v13
const-string v12, "messages"
const/16 v16, 0x0
const/16 v17, 0x0
const-string v18, "rowid asc"
const/16 v0, 0x64
.line 11
invoke-static {v0}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v19
move-object/from16 v11, p1
.line 12
invoke-virtual/range {v11 .. v19}, 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;Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v11
:try_end_5
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_5 .. :try_end_5} :catch_a
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_5 .. :try_end_5} :catch_9
.catch Landroid/database/sqlite/SQLiteException; {:try_start_5 .. :try_end_5} :catch_8
.catchall {:try_start_5 .. :try_end_5} :catchall_5
.line 13
:cond_4
:goto_3
:try_start_6
invoke-interface {v11}, Landroid/database/Cursor;->moveToNext()Z
move-result v0
if-eqz v0, :cond_9
.line 14
invoke-interface {v11, v7}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v20
.line 15
invoke-interface {v11, v10}, Landroid/database/Cursor;->getInt(I)I
move-result v0
const/4 v12, 0x2
.line 16
invoke-interface {v11, v12}, Landroid/database/Cursor;->getBlob(I)[B
move-result-object v13
if-nez v0, :cond_5
.line 17
invoke-static {}, Landroid/os/Parcel;->obtain()Landroid/os/Parcel;
move-result-object v12
:try_end_6
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_6 .. :try_end_6} :catch_7
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_6 .. :try_end_6} :catch_6
.catch Landroid/database/sqlite/SQLiteException; {:try_start_6 .. :try_end_6} :catch_5
.catchall {:try_start_6 .. :try_end_6} :catchall_4
.line 18
:try_start_7
array-length v0, v13
invoke-virtual {v12, v13, v7, v0}, Landroid/os/Parcel;->unmarshall([BII)V
.line 19
invoke-virtual {v12, v7}, Landroid/os/Parcel;->setDataPosition(I)V
.line 20
sget-object v0, Lcom/google/android/gms/measurement/internal/zzau;->CREATOR:Landroid/os/Parcelable$Creator;
invoke-interface {v0, v12}, Landroid/os/Parcelable$Creator;->createFromParcel(Landroid/os/Parcel;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/measurement/internal/zzau;
:try_end_7
.catch Lcom/google/android/gms/common/internal/safeparcel/SafeParcelReader$ParseException; {:try_start_7 .. :try_end_7} :catch_0
.catchall {:try_start_7 .. :try_end_7} :catchall_0
.line 21
:try_start_8
invoke-virtual {v12}, Landroid/os/Parcel;->recycle()V
if-eqz v0, :cond_4
.line 22
invoke-virtual {v5, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
:try_end_8
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_8 .. :try_end_8} :catch_7
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_8 .. :try_end_8} :catch_6
.catch Landroid/database/sqlite/SQLiteException; {:try_start_8 .. :try_end_8} :catch_5
.catchall {:try_start_8 .. :try_end_8} :catchall_4
goto :goto_3
:catchall_0
move-exception v0
goto :goto_4
.line 23
:catch_0
:try_start_9
iget-object v0, v1, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 24
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v0
.line 25
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v0
const-string v13, "Failed to load event from local database"
invoke-virtual {v0, v13}, Lcom/google/android/gms/measurement/internal/zzef;->zza(Ljava/lang/String;)V
:try_end_9
.catchall {:try_start_9 .. :try_end_9} :catchall_0
.line 26
:try_start_a
invoke-virtual {v12}, Landroid/os/Parcel;->recycle()V
goto :goto_3
:goto_4
invoke-virtual {v12}, Landroid/os/Parcel;->recycle()V
.line 27
throw v0
:cond_5
if-ne v0, v10, :cond_6
.line 28
invoke-static {}, Landroid/os/Parcel;->obtain()Landroid/os/Parcel;
move-result-object v12
:try_end_a
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_a .. :try_end_a} :catch_7
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_a .. :try_end_a} :catch_6
.catch Landroid/database/sqlite/SQLiteException; {:try_start_a .. :try_end_a} :catch_5
.catchall {:try_start_a .. :try_end_a} :catchall_4
.line 29
:try_start_b
array-length v0, v13
invoke-virtual {v12, v13, v7, v0}, Landroid/os/Parcel;->unmarshall([BII)V
.line 30
invoke-virtual {v12, v7}, Landroid/os/Parcel;->setDataPosition(I)V
.line 31
sget-object v0, Lcom/google/android/gms/measurement/internal/zzks;->CREATOR:Landroid/os/Parcelable$Creator;
invoke-interface {v0, v12}, Landroid/os/Parcelable$Creator;->createFromParcel(Landroid/os/Parcel;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/measurement/internal/zzks;
:try_end_b
.catch Lcom/google/android/gms/common/internal/safeparcel/SafeParcelReader$ParseException; {:try_start_b .. :try_end_b} :catch_1
.catchall {:try_start_b .. :try_end_b} :catchall_1
.line 32
:try_start_c
invoke-virtual {v12}, Landroid/os/Parcel;->recycle()V
:try_end_c
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_c .. :try_end_c} :catch_7
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_c .. :try_end_c} :catch_6
.catch Landroid/database/sqlite/SQLiteException; {:try_start_c .. :try_end_c} :catch_5
.catchall {:try_start_c .. :try_end_c} :catchall_4
goto :goto_5
:catchall_1
move-exception v0
goto :goto_6
.line 33
:catch_1
:try_start_d
iget-object v0, v1, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 34
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v0
.line 35
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v0
const-string v13, "Failed to load user property from local database"
invoke-virtual {v0, v13}, Lcom/google/android/gms/measurement/internal/zzef;->zza(Ljava/lang/String;)V
:try_end_d
.catchall {:try_start_d .. :try_end_d} :catchall_1
.line 36
:try_start_e
invoke-virtual {v12}, Landroid/os/Parcel;->recycle()V
move-object v0, v4
:goto_5
if-eqz v0, :cond_4
.line 37
invoke-virtual {v5, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_3
.line 38
:goto_6
invoke-virtual {v12}, Landroid/os/Parcel;->recycle()V
.line 39
throw v0
:cond_6
if-ne v0, v12, :cond_7
.line 40
invoke-static {}, Landroid/os/Parcel;->obtain()Landroid/os/Parcel;
move-result-object v12
:try_end_e
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_e .. :try_end_e} :catch_7
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_e .. :try_end_e} :catch_6
.catch Landroid/database/sqlite/SQLiteException; {:try_start_e .. :try_end_e} :catch_5
.catchall {:try_start_e .. :try_end_e} :catchall_4
.line 41
:try_start_f
array-length v0, v13
invoke-virtual {v12, v13, v7, v0}, Landroid/os/Parcel;->unmarshall([BII)V
.line 42
invoke-virtual {v12, v7}, Landroid/os/Parcel;->setDataPosition(I)V
.line 43
sget-object v0, Lcom/google/android/gms/measurement/internal/zzab;->CREATOR:Landroid/os/Parcelable$Creator;
.line 44
invoke-interface {v0, v12}, Landroid/os/Parcelable$Creator;->createFromParcel(Landroid/os/Parcel;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/android/gms/measurement/internal/zzab;
:try_end_f
.catch Lcom/google/android/gms/common/internal/safeparcel/SafeParcelReader$ParseException; {:try_start_f .. :try_end_f} :catch_2
.catchall {:try_start_f .. :try_end_f} :catchall_2
.line 45
:try_start_10
invoke-virtual {v12}, Landroid/os/Parcel;->recycle()V
:try_end_10
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_10 .. :try_end_10} :catch_7
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_10 .. :try_end_10} :catch_6
.catch Landroid/database/sqlite/SQLiteException; {:try_start_10 .. :try_end_10} :catch_5
.catchall {:try_start_10 .. :try_end_10} :catchall_4
goto :goto_7
:catchall_2
move-exception v0
goto :goto_8
.line 46
:catch_2
:try_start_11
iget-object v0, v1, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 47
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v0
.line 48
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v0
const-string v13, "Failed to load conditional user property from local database"
.line 49
invoke-virtual {v0, v13}, Lcom/google/android/gms/measurement/internal/zzef;->zza(Ljava/lang/String;)V
:try_end_11
.catchall {:try_start_11 .. :try_end_11} :catchall_2
.line 50
:try_start_12
invoke-virtual {v12}, Landroid/os/Parcel;->recycle()V
move-object v0, v4
:goto_7
if-eqz v0, :cond_4
.line 51
invoke-virtual {v5, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto/16 :goto_3
.line 52
:goto_8
invoke-virtual {v12}, Landroid/os/Parcel;->recycle()V
.line 53
throw v0
:cond_7
const/4 v12, 0x3
if-ne v0, v12, :cond_8
.line 54
iget-object v0, v1, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 55
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v0
.line 56
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzeh;->zzk()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v0
const-string v12, "Skipping app launch break"
invoke-virtual {v0, v12}, Lcom/google/android/gms/measurement/internal/zzef;->zza(Ljava/lang/String;)V
goto/16 :goto_3
:cond_8
iget-object v0, v1, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 57
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v0
.line 58
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v0
const-string v12, "Unknown record type in local database"
invoke-virtual {v0, v12}, Lcom/google/android/gms/measurement/internal/zzef;->zza(Ljava/lang/String;)V
goto/16 :goto_3
:cond_9
new-array v0, v10, [Ljava/lang/String;
.line 59
invoke-static/range {v20 .. v21}, Ljava/lang/Long;->toString(J)Ljava/lang/String;
move-result-object v12
aput-object v12, v0, v7
const-string v12, "messages"
const-string v13, "rowid <= ?"
:try_end_12
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_12 .. :try_end_12} :catch_7
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_12 .. :try_end_12} :catch_6
.catch Landroid/database/sqlite/SQLiteException; {:try_start_12 .. :try_end_12} :catch_5
.catchall {:try_start_12 .. :try_end_12} :catchall_4
move-object/from16 v14, p1
.line 60
:try_start_13
invoke-virtual {v14, v12, v13, v0}, Landroid/database/sqlite/SQLiteDatabase;->delete(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)I
move-result v0
.line 61
invoke-virtual {v5}, Ljava/util/ArrayList;->size()I
move-result v12
if-ge v0, v12, :cond_a
iget-object v0, v1, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 62
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v0
.line 63
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v0
const-string v12, "Fewer entries removed from local database than expected"
invoke-virtual {v0, v12}, Lcom/google/android/gms/measurement/internal/zzef;->zza(Ljava/lang/String;)V
.line 64
:cond_a
invoke-virtual {v14}, Landroid/database/sqlite/SQLiteDatabase;->setTransactionSuccessful()V
.line 65
invoke-virtual {v14}, Landroid/database/sqlite/SQLiteDatabase;->endTransaction()V
:try_end_13
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_13 .. :try_end_13} :catch_4
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_13 .. :try_end_13} :catch_10
.catch Landroid/database/sqlite/SQLiteException; {:try_start_13 .. :try_end_13} :catch_3
.catchall {:try_start_13 .. :try_end_13} :catchall_3
.line 66
invoke-interface {v11}, Landroid/database/Cursor;->close()V
.line 67
invoke-virtual {v14}, Landroid/database/sqlite/SQLiteDatabase;->close()V
return-object v5
:catchall_3
move-exception v0
goto :goto_9
:catch_3
move-exception v0
goto :goto_d
:catch_4
move-exception v0
goto/16 :goto_11
:catchall_4
move-exception v0
move-object/from16 v14, p1
:goto_9
move-object v4, v11
goto/16 :goto_17
:catch_5
move-exception v0
move-object/from16 v14, p1
goto :goto_d
:catch_6
move-object/from16 v14, p1
goto :goto_f
:catch_7
move-exception v0
move-object/from16 v14, p1
goto :goto_11
:catchall_5
move-exception v0
move-object/from16 v14, p1
goto/16 :goto_17
:catch_8
move-exception v0
move-object/from16 v14, p1
goto :goto_c
:catch_9
move-object/from16 v14, p1
goto :goto_e
:catch_a
move-exception v0
move-object/from16 v14, p1
goto :goto_10
:catchall_6
move-exception v0
move-object/from16 v14, p1
goto :goto_b
:catchall_7
move-exception v0
move-object/from16 v14, p1
goto :goto_a
:catchall_8
move-exception v0
move-object v14, v15
:goto_a
move-object v11, v4
:goto_b
if-eqz v11, :cond_b
.line 68
:try_start_14
invoke-interface {v11}, Landroid/database/Cursor;->close()V
.line 69
:cond_b
throw v0
:try_end_14
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_14 .. :try_end_14} :catch_c
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_14 .. :try_end_14} :catch_f
.catch Landroid/database/sqlite/SQLiteException; {:try_start_14 .. :try_end_14} :catch_b
.catchall {:try_start_14 .. :try_end_14} :catchall_9
:catchall_9
move-exception v0
goto/16 :goto_17
:catch_b
move-exception v0
goto :goto_c
:catch_c
move-exception v0
goto :goto_10
:catchall_a
move-exception v0
goto/16 :goto_16
:catch_d
move-exception v0
move-object v14, v15
:goto_c
move-object v11, v4
:goto_d
move-object v15, v14
goto :goto_12
:catch_e
move-object v14, v15
:catch_f
:goto_e
move-object v11, v4
:catch_10
:goto_f
move-object v15, v14
goto :goto_13
:catch_11
move-exception v0
move-object v14, v15
:goto_10
move-object v11, v4
:goto_11
move-object v15, v14
goto :goto_14
:catchall_b
move-exception v0
move-object v14, v4
goto :goto_17
:catch_12
move-exception v0
move-object v11, v4
move-object v15, v11
:goto_12
if-eqz v15, :cond_c
.line 70
:try_start_15
invoke-virtual {v15}, Landroid/database/sqlite/SQLiteDatabase;->inTransaction()Z
move-result v12
if-eqz v12, :cond_c
.line 71
invoke-virtual {v15}, Landroid/database/sqlite/SQLiteDatabase;->endTransaction()V
:cond_c
iget-object v12, v1, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 72
invoke-virtual {v12}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v12
.line 73
invoke-virtual {v12}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v12
invoke-virtual {v12, v3, v0}, Lcom/google/android/gms/measurement/internal/zzef;->zzb(Ljava/lang/String;Ljava/lang/Object;)V
iput-boolean v10, v1, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
:try_end_15
.catchall {:try_start_15 .. :try_end_15} :catchall_c
if-eqz v11, :cond_d
.line 74
invoke-interface {v11}, Landroid/database/Cursor;->close()V
:cond_d
if-eqz v15, :cond_10
goto :goto_15
:catch_13
move-object v11, v4
move-object v15, v11
:goto_13
int-to-long v12, v9
.line 75
:try_start_16
invoke-static {v12, v13}, Landroid/os/SystemClock;->sleep(J)V
:try_end_16
.catchall {:try_start_16 .. :try_end_16} :catchall_c
add-int/lit8 v9, v9, 0x14
if-eqz v11, :cond_e
.line 76
invoke-interface {v11}, Landroid/database/Cursor;->close()V
:cond_e
if-eqz v15, :cond_10
goto :goto_15
:catch_14
move-exception v0
move-object v11, v4
move-object v15, v11
.line 77
:goto_14
:try_start_17
iget-object v12, v1, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 78
invoke-virtual {v12}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v12
.line 79
invoke-virtual {v12}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v12
invoke-virtual {v12, v3, v0}, Lcom/google/android/gms/measurement/internal/zzef;->zzb(Ljava/lang/String;Ljava/lang/Object;)V
iput-boolean v10, v1, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
:try_end_17
.catchall {:try_start_17 .. :try_end_17} :catchall_c
if-eqz v11, :cond_f
.line 80
invoke-interface {v11}, Landroid/database/Cursor;->close()V
:cond_f
if-eqz v15, :cond_10
.line 81
:goto_15
invoke-virtual {v15}, Landroid/database/sqlite/SQLiteDatabase;->close()V
:cond_10
add-int/lit8 v8, v8, 0x1
goto/16 :goto_0
:catchall_c
move-exception v0
move-object v4, v11
:goto_16
move-object v14, v15
:goto_17
if-eqz v4, :cond_11
.line 82
invoke-interface {v4}, Landroid/database/Cursor;->close()V
:cond_11
if-eqz v14, :cond_12
.line 83
invoke-virtual {v14}, Landroid/database/sqlite/SQLiteDatabase;->close()V
.line 84
:cond_12
throw v0
.line 85
:cond_13
iget-object v0, v1, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
const-string v2, "Failed to read events from database in reasonable time"
.line 86
invoke-static {v0, v2}, Lcom/google/android/gms/measurement/internal/b;->a(Lcom/google/android/gms/measurement/internal/zzfr;Ljava/lang/String;)V
return-object v4
:cond_14
return-object v5
.end method
.method public final zzj()V
.locals 3
.annotation build Landroidx/annotation/WorkerThread;
.end annotation
.line 1
invoke-virtual {p0}, Lcom/google/android/gms/measurement/internal/zze;->zzg()V
.line 2
:try_start_0
invoke-virtual {p0}, Lcom/google/android/gms/measurement/internal/zzea;->zzh()Landroid/database/sqlite/SQLiteDatabase;
move-result-object v0
if-eqz v0, :cond_0
const-string v1, "messages"
const/4 v2, 0x0
.line 3
invoke-virtual {v0, v1, v2, v2}, Landroid/database/sqlite/SQLiteDatabase;->delete(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)I
move-result v0
if-lez v0, :cond_0
iget-object v1, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 4
invoke-virtual {v1}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v1
.line 5
invoke-virtual {v1}, Lcom/google/android/gms/measurement/internal/zzeh;->zzj()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v1
const-string v2, "Reset local analytics data. records"
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
invoke-virtual {v1, v2, v0}, Lcom/google/android/gms/measurement/internal/zzef;->zzb(Ljava/lang/String;Ljava/lang/Object;)V
:try_end_0
.catch Landroid/database/sqlite/SQLiteException; {:try_start_0 .. :try_end_0} :catch_0
:cond_0
return-void
:catch_0
move-exception v0
iget-object v1, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 6
invoke-virtual {v1}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v1
.line 7
invoke-virtual {v1}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v1
const-string v2, "Error resetting local analytics data. error"
invoke-virtual {v1, v2, v0}, Lcom/google/android/gms/measurement/internal/zzef;->zzb(Ljava/lang/String;Ljava/lang/Object;)V
return-void
.end method
.method public final zzk()Z
.locals 2
.annotation build Landroidx/annotation/WorkerThread;
.end annotation
const/4 v0, 0x0
new-array v0, v0, [B
const/4 v1, 0x3
.line 1
invoke-direct {p0, v1, v0}, Lcom/google/android/gms/measurement/internal/zzea;->zzq(I[B)Z
move-result v0
return v0
.end method
.method public final zzl()Z
.locals 2
.annotation build Lcom/google/android/gms/common/util/VisibleForTesting;
.end annotation
.line 1
iget-object v0, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzfr;->zzau()Landroid/content/Context;
move-result-object v0
iget-object v1, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 2
invoke-virtual {v1}, Lcom/google/android/gms/measurement/internal/zzfr;->zzf()Lcom/google/android/gms/measurement/internal/zzaf;
const-string v1, "google_app_measurement_local.db"
.line 3
invoke-virtual {v0, v1}, Landroid/content/Context;->getDatabasePath(Ljava/lang/String;)Ljava/io/File;
move-result-object v0
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v0
return v0
.end method
.method public final zzm()Z
.locals 10
.annotation build Landroidx/annotation/WorkerThread;
.end annotation
const-string v0, "Error deleting app launch break from local database"
.line 1
invoke-virtual {p0}, Lcom/google/android/gms/measurement/internal/zze;->zzg()V
iget-boolean v1, p0, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
const/4 v2, 0x0
if-eqz v1, :cond_0
return v2
.line 2
:cond_0
invoke-virtual {p0}, Lcom/google/android/gms/measurement/internal/zzea;->zzl()Z
move-result v1
if-eqz v1, :cond_6
const/4 v1, 0x5
move v4, v1
move v3, v2
:goto_0
if-ge v3, v1, :cond_5
const/4 v5, 0x0
const/4 v6, 0x1
.line 3
:try_start_0
invoke-virtual {p0}, Lcom/google/android/gms/measurement/internal/zzea;->zzh()Landroid/database/sqlite/SQLiteDatabase;
move-result-object v5
if-nez v5, :cond_1
iput-boolean v6, p0, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
return v2
.line 4
:cond_1
invoke-virtual {v5}, Landroid/database/sqlite/SQLiteDatabase;->beginTransaction()V
new-array v7, v6, [Ljava/lang/String;
const/4 v8, 0x3
.line 5
invoke-static {v8}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v8
aput-object v8, v7, v2
const-string v8, "messages"
const-string v9, "type == ?"
.line 6
invoke-virtual {v5, v8, v9, v7}, Landroid/database/sqlite/SQLiteDatabase;->delete(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;)I
.line 7
invoke-virtual {v5}, Landroid/database/sqlite/SQLiteDatabase;->setTransactionSuccessful()V
.line 8
invoke-virtual {v5}, Landroid/database/sqlite/SQLiteDatabase;->endTransaction()V
:try_end_0
.catch Landroid/database/sqlite/SQLiteFullException; {:try_start_0 .. :try_end_0} :catch_2
.catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_0 .. :try_end_0} :catch_1
.catch Landroid/database/sqlite/SQLiteException; {:try_start_0 .. :try_end_0} :catch_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
.line 9
invoke-virtual {v5}, Landroid/database/sqlite/SQLiteDatabase;->close()V
return v6
:catchall_0
move-exception v0
goto :goto_2
:catch_0
move-exception v7
if-eqz v5, :cond_2
.line 10
:try_start_1
invoke-virtual {v5}, Landroid/database/sqlite/SQLiteDatabase;->inTransaction()Z
move-result v8
if-eqz v8, :cond_2
.line 11
invoke-virtual {v5}, Landroid/database/sqlite/SQLiteDatabase;->endTransaction()V
:cond_2
iget-object v8, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 12
invoke-virtual {v8}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v8
.line 13
invoke-virtual {v8}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v8
invoke-virtual {v8, v0, v7}, Lcom/google/android/gms/measurement/internal/zzef;->zzb(Ljava/lang/String;Ljava/lang/Object;)V
iput-boolean v6, p0, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
if-eqz v5, :cond_3
goto :goto_1
:catch_1
int-to-long v6, v4
.line 14
invoke-static {v6, v7}, Landroid/os/SystemClock;->sleep(J)V
add-int/lit8 v4, v4, 0x14
if-eqz v5, :cond_3
goto :goto_1
:catch_2
move-exception v7
.line 15
iget-object v8, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 16
invoke-virtual {v8}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object v8
.line 17
invoke-virtual {v8}, Lcom/google/android/gms/measurement/internal/zzeh;->zzd()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object v8
invoke-virtual {v8, v0, v7}, Lcom/google/android/gms/measurement/internal/zzef;->zzb(Ljava/lang/String;Ljava/lang/Object;)V
iput-boolean v6, p0, Lcom/google/android/gms/measurement/internal/zzea;->zzb:Z
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
if-eqz v5, :cond_3
.line 18
:goto_1
invoke-virtual {v5}, Landroid/database/sqlite/SQLiteDatabase;->close()V
:cond_3
add-int/lit8 v3, v3, 0x1
goto :goto_0
:goto_2
if-eqz v5, :cond_4
invoke-virtual {v5}, Landroid/database/sqlite/SQLiteDatabase;->close()V
.line 19
:cond_4
throw v0
.line 20
:cond_5
iget-object v0, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
const-string v1, "Error deleting app launch break from local database in reasonable time"
.line 21
invoke-static {v0, v1}, Lcom/google/android/gms/measurement/internal/b;->a(Lcom/google/android/gms/measurement/internal/zzfr;Ljava/lang/String;)V
:cond_6
return v2
.end method
.method public final zzn(Lcom/google/android/gms/measurement/internal/zzab;)Z
.locals 2
.line 1
iget-object v0, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
invoke-virtual {v0}, Lcom/google/android/gms/measurement/internal/zzfr;->zzv()Lcom/google/android/gms/measurement/internal/zzkw;
move-result-object v0
.line 2
invoke-virtual {v0, p1}, Lcom/google/android/gms/measurement/internal/zzkw;->zzan(Landroid/os/Parcelable;)[B
move-result-object p1
.line 3
array-length v0, p1
const/high16 v1, 0x20000
if-le v0, v1, :cond_0
iget-object p1, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 4
invoke-virtual {p1}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object p1
.line 5
invoke-virtual {p1}, Lcom/google/android/gms/measurement/internal/zzeh;->zzh()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object p1
const-string v0, "Conditional user property too long for local database. Sending directly to service"
.line 6
invoke-virtual {p1, v0}, Lcom/google/android/gms/measurement/internal/zzef;->zza(Ljava/lang/String;)V
const/4 p1, 0x0
return p1
:cond_0
const/4 v0, 0x2
.line 7
invoke-direct {p0, v0, p1}, Lcom/google/android/gms/measurement/internal/zzea;->zzq(I[B)Z
move-result p1
return p1
.end method
.method public final zzo(Lcom/google/android/gms/measurement/internal/zzau;)Z
.locals 3
.line 1
invoke-static {}, Landroid/os/Parcel;->obtain()Landroid/os/Parcel;
move-result-object v0
const/4 v1, 0x0
.line 2
invoke-static {p1, v0, v1}, Lcom/google/android/gms/measurement/internal/zzav;->zza(Lcom/google/android/gms/measurement/internal/zzau;Landroid/os/Parcel;I)V
.line 3
invoke-virtual {v0}, Landroid/os/Parcel;->marshall()[B
move-result-object p1
.line 4
invoke-virtual {v0}, Landroid/os/Parcel;->recycle()V
.line 5
array-length v0, p1
const/high16 v2, 0x20000
if-le v0, v2, :cond_0
iget-object p1, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 6
invoke-virtual {p1}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object p1
.line 7
invoke-virtual {p1}, Lcom/google/android/gms/measurement/internal/zzeh;->zzh()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object p1
const-string v0, "Event is too long for local database. Sending event directly to service"
.line 8
invoke-virtual {p1, v0}, Lcom/google/android/gms/measurement/internal/zzef;->zza(Ljava/lang/String;)V
return v1
.line 9
:cond_0
invoke-direct {p0, v1, p1}, Lcom/google/android/gms/measurement/internal/zzea;->zzq(I[B)Z
move-result p1
return p1
.end method
.method public final zzp(Lcom/google/android/gms/measurement/internal/zzks;)Z
.locals 3
.line 1
invoke-static {}, Landroid/os/Parcel;->obtain()Landroid/os/Parcel;
move-result-object v0
const/4 v1, 0x0
.line 2
invoke-static {p1, v0, v1}, Lcom/google/android/gms/measurement/internal/zzkt;->zza(Lcom/google/android/gms/measurement/internal/zzks;Landroid/os/Parcel;I)V
.line 3
invoke-virtual {v0}, Landroid/os/Parcel;->marshall()[B
move-result-object p1
.line 4
invoke-virtual {v0}, Landroid/os/Parcel;->recycle()V
.line 5
array-length v0, p1
const/high16 v2, 0x20000
if-le v0, v2, :cond_0
iget-object p1, p0, Lcom/google/android/gms/measurement/internal/zzgk;->zzs:Lcom/google/android/gms/measurement/internal/zzfr;
.line 6
invoke-virtual {p1}, Lcom/google/android/gms/measurement/internal/zzfr;->zzay()Lcom/google/android/gms/measurement/internal/zzeh;
move-result-object p1
.line 7
invoke-virtual {p1}, Lcom/google/android/gms/measurement/internal/zzeh;->zzh()Lcom/google/android/gms/measurement/internal/zzef;
move-result-object p1
const-string v0, "User property too long for local database. Sending directly to service"
.line 8
invoke-virtual {p1, v0}, Lcom/google/android/gms/measurement/internal/zzef;->zza(Ljava/lang/String;)V
return v1
:cond_0
const/4 v0, 0x1
.line 9
invoke-direct {p0, v0, p1}, Lcom/google/android/gms/measurement/internal/zzea;->zzq(I[B)Z
move-result p1
return p1
.end method