.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 (Lcom/google/android/gms/measurement/internal/zzfr;)V .locals 2 .line 1 invoke-direct {p0, p1}, Lcom/google/android/gms/measurement/internal/zzf;->(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;->(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;->()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;->()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, "rowidvalueOf(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