.class public final Landroidx/room/InvalidationTracker$refreshRunnable$1; .super Ljava/lang/Object; .source "SourceFile" # interfaces .implements Ljava/lang/Runnable; # annotations .annotation system Ldalvik/annotation/EnclosingMethod; value = Landroidx/room/InvalidationTracker;->(Landroidx/room/RoomDatabase;Ljava/util/Map;Ljava/util/Map;[Ljava/lang/String;)V .end annotation .annotation system Ldalvik/annotation/InnerClass; accessFlags = 0x19 name = null .end annotation .annotation build Lkotlin/jvm/internal/SourceDebugExtension; value = { "SMAP\nInvalidationTracker.kt\nKotlin\n*S Kotlin\n*F\n+ 1 InvalidationTracker.kt\nandroidx/room/InvalidationTracker$refreshRunnable$1\n+ 2 _Collections.kt\nkotlin/collections/CollectionsKt___CollectionsKt\n+ 3 CursorUtil.kt\nandroidx/room/util/CursorUtil\n*L\n1#1,840:1\n1855#2,2:841\n145#3,7:843\n*S KotlinDebug\n*F\n+ 1 InvalidationTracker.kt\nandroidx/room/InvalidationTracker$refreshRunnable$1\n*L\n399#1:841,2\n408#1:843,7\n*E\n" } .end annotation # instance fields .field final synthetic this$0:Landroidx/room/InvalidationTracker; # direct methods .method public constructor (Landroidx/room/InvalidationTracker;)V .locals 0 iput-object p1, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 347 invoke-direct {p0}, Ljava/lang/Object;->()V return-void .end method .method private final checkUpdatedTable()Ljava/util/Set; .locals 5 .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Set<", "Ljava/lang/Integer;", ">;" } .end annotation iget-object v0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 407 invoke-static {}, Lkotlin/collections/SetsKt;->createSetBuilder()Ljava/util/Set; move-result-object v1 .line 408 invoke-virtual {v0}, Landroidx/room/InvalidationTracker;->getDatabase$room_runtime_release()Landroidx/room/RoomDatabase; move-result-object v0 new-instance v2, Landroidx/sqlite/db/SimpleSQLiteQuery; const-string v3, "SELECT * FROM room_table_modification_log WHERE invalidated = 1;" invoke-direct {v2, v3}, Landroidx/sqlite/db/SimpleSQLiteQuery;->(Ljava/lang/String;)V const/4 v3, 0x2 const/4 v4, 0x0 invoke-static {v0, v2, v4, v3, v4}, Landroidx/room/RoomDatabase;->query$default(Landroidx/room/RoomDatabase;Landroidx/sqlite/db/SupportSQLiteQuery;Landroid/os/CancellationSignal;ILjava/lang/Object;)Landroid/database/Cursor; move-result-object v0 .line 409 :goto_0 :try_start_0 invoke-interface {v0}, Landroid/database/Cursor;->moveToNext()Z move-result v2 if-eqz v2, :cond_0 const/4 v2, 0x0 .line 410 invoke-interface {v0, v2}, Landroid/database/Cursor;->getInt(I)I move-result v2 invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v2 invoke-interface {v1, v2}, Ljava/util/Set;->add(Ljava/lang/Object;)Z goto :goto_0 :catchall_0 move-exception v1 goto :goto_2 .line 412 :cond_0 sget-object v2, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit; :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 146 invoke-static {v0, v4}, Lkotlin/io/CloseableKt;->closeFinally(Ljava/io/Closeable;Ljava/lang/Throwable;)V .line 407 invoke-static {v1}, Lkotlin/collections/SetsKt;->build(Ljava/util/Set;)Ljava/util/Set; move-result-object v0 .line 414 invoke-interface {v0}, Ljava/util/Collection;->isEmpty()Z move-result v1 xor-int/lit8 v1, v1, 0x1 if-eqz v1, :cond_3 iget-object v1, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 415 invoke-virtual {v1}, Landroidx/room/InvalidationTracker;->getCleanupStatement$room_runtime_release()Landroidx/sqlite/db/SupportSQLiteStatement; move-result-object v1 const-string v2, "Required value was null." if-eqz v1, :cond_2 iget-object v1, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 416 invoke-virtual {v1}, Landroidx/room/InvalidationTracker;->getCleanupStatement$room_runtime_release()Landroidx/sqlite/db/SupportSQLiteStatement; move-result-object v1 if-eqz v1, :cond_1 .line 418 invoke-interface {v1}, Landroidx/sqlite/db/SupportSQLiteStatement;->executeUpdateDelete()I goto :goto_1 .line 417 :cond_1 new-instance v0, Ljava/lang/IllegalArgumentException; invoke-virtual {v2}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v1 invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw v0 .line 415 :cond_2 new-instance v0, Ljava/lang/IllegalStateException; invoke-virtual {v2}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v1 invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;)V throw v0 :cond_3 :goto_1 return-object v0 .line 146 :goto_2 :try_start_1 throw v1 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_1 :catchall_1 move-exception v2 invoke-static {v0, v1}, Lkotlin/io/CloseableKt;->closeFinally(Ljava/io/Closeable;Ljava/lang/Throwable;)V throw v2 .end method # virtual methods .method public run()V .locals 5 iget-object v0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 349 invoke-virtual {v0}, Landroidx/room/InvalidationTracker;->getDatabase$room_runtime_release()Landroidx/room/RoomDatabase; move-result-object v0 invoke-virtual {v0}, Landroidx/room/RoomDatabase;->getCloseLock$room_runtime_release()Ljava/util/concurrent/locks/Lock; move-result-object v0 .line 350 invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->lock()V const/4 v1, 0x1 :try_start_0 iget-object v2, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 353 invoke-virtual {v2}, Landroidx/room/InvalidationTracker;->ensureInitialization$room_runtime_release()Z move-result v2 :try_end_0 .catch Ljava/lang/IllegalStateException; {: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 if-nez v2, :cond_1 .line 393 invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V iget-object v0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 394 invoke-static {v0}, Landroidx/room/InvalidationTracker;->access$getAutoCloser$p(Landroidx/room/InvalidationTracker;)Landroidx/room/AutoCloser; move-result-object v0 if-eqz v0, :cond_0 invoke-virtual {v0}, Landroidx/room/AutoCloser;->decrementCountAndScheduleClose()V :cond_0 return-void :cond_1 :try_start_1 iget-object v2, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 356 invoke-virtual {v2}, Landroidx/room/InvalidationTracker;->getPendingRefresh()Ljava/util/concurrent/atomic/AtomicBoolean; move-result-object v2 const/4 v3, 0x0 invoke-virtual {v2, v1, v3}, Ljava/util/concurrent/atomic/AtomicBoolean;->compareAndSet(ZZ)Z move-result v2 :try_end_1 .catch Ljava/lang/IllegalStateException; {:try_start_1 .. :try_end_1} :catch_1 .catch Landroid/database/sqlite/SQLiteException; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 if-nez v2, :cond_3 .line 393 invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V iget-object v0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 394 invoke-static {v0}, Landroidx/room/InvalidationTracker;->access$getAutoCloser$p(Landroidx/room/InvalidationTracker;)Landroidx/room/AutoCloser; move-result-object v0 if-eqz v0, :cond_2 invoke-virtual {v0}, Landroidx/room/AutoCloser;->decrementCountAndScheduleClose()V :cond_2 return-void :cond_3 :try_start_2 iget-object v2, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 360 invoke-virtual {v2}, Landroidx/room/InvalidationTracker;->getDatabase$room_runtime_release()Landroidx/room/RoomDatabase; move-result-object v2 invoke-virtual {v2}, Landroidx/room/RoomDatabase;->inTransaction()Z move-result v2 :try_end_2 .catch Ljava/lang/IllegalStateException; {:try_start_2 .. :try_end_2} :catch_1 .catch Landroid/database/sqlite/SQLiteException; {:try_start_2 .. :try_end_2} :catch_0 .catchall {:try_start_2 .. :try_end_2} :catchall_0 if-eqz v2, :cond_5 .line 393 invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V iget-object v0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 394 invoke-static {v0}, Landroidx/room/InvalidationTracker;->access$getAutoCloser$p(Landroidx/room/InvalidationTracker;)Landroidx/room/AutoCloser; move-result-object v0 if-eqz v0, :cond_4 invoke-virtual {v0}, Landroidx/room/AutoCloser;->decrementCountAndScheduleClose()V :cond_4 return-void :cond_5 :try_start_3 iget-object v2, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 369 invoke-virtual {v2}, Landroidx/room/InvalidationTracker;->getDatabase$room_runtime_release()Landroidx/room/RoomDatabase; move-result-object v2 invoke-virtual {v2}, Landroidx/room/RoomDatabase;->getOpenHelper()Landroidx/sqlite/db/SupportSQLiteOpenHelper; move-result-object v2 invoke-interface {v2}, Landroidx/sqlite/db/SupportSQLiteOpenHelper;->getWritableDatabase()Landroidx/sqlite/db/SupportSQLiteDatabase; move-result-object v2 .line 370 invoke-interface {v2}, Landroidx/sqlite/db/SupportSQLiteDatabase;->beginTransactionNonExclusive()V :try_end_3 .catch Ljava/lang/IllegalStateException; {:try_start_3 .. :try_end_3} :catch_1 .catch Landroid/database/sqlite/SQLiteException; {:try_start_3 .. :try_end_3} :catch_0 .catchall {:try_start_3 .. :try_end_3} :catchall_0 .line 373 :try_start_4 invoke-direct {p0}, Landroidx/room/InvalidationTracker$refreshRunnable$1;->checkUpdatedTable()Ljava/util/Set; move-result-object v3 .line 374 invoke-interface {v2}, Landroidx/sqlite/db/SupportSQLiteDatabase;->setTransactionSuccessful()V :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_1 .line 376 :try_start_5 invoke-interface {v2}, Landroidx/sqlite/db/SupportSQLiteDatabase;->endTransaction()V :try_end_5 .catch Ljava/lang/IllegalStateException; {:try_start_5 .. :try_end_5} :catch_1 .catch Landroid/database/sqlite/SQLiteException; {:try_start_5 .. :try_end_5} :catch_0 .catchall {:try_start_5 .. :try_end_5} :catchall_0 .line 393 invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V iget-object v0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 394 invoke-static {v0}, Landroidx/room/InvalidationTracker;->access$getAutoCloser$p(Landroidx/room/InvalidationTracker;)Landroidx/room/AutoCloser; move-result-object v0 if-eqz v0, :cond_6 :goto_0 invoke-virtual {v0}, Landroidx/room/AutoCloser;->decrementCountAndScheduleClose()V goto :goto_3 :catchall_0 move-exception v1 goto/16 :goto_7 :catch_0 move-exception v2 goto :goto_1 :catch_1 move-exception v2 goto :goto_2 :catchall_1 move-exception v3 .line 376 :try_start_6 invoke-interface {v2}, Landroidx/sqlite/db/SupportSQLiteDatabase;->endTransaction()V throw v3 :try_end_6 .catch Ljava/lang/IllegalStateException; {:try_start_6 .. :try_end_6} :catch_1 .catch Landroid/database/sqlite/SQLiteException; {:try_start_6 .. :try_end_6} :catch_0 .catchall {:try_start_6 .. :try_end_6} :catchall_0 :goto_1 :try_start_7 const-string v3, "ROOM" const-string v4, "Cannot run invalidation tracker. Is the db closed?" .line 387 invoke-static {v3, v4, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I .line 391 invoke-static {}, Lkotlin/collections/SetsKt;->emptySet()Ljava/util/Set; move-result-object v3 :try_end_7 .catchall {:try_start_7 .. :try_end_7} :catchall_0 .line 393 invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V iget-object v0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 394 invoke-static {v0}, Landroidx/room/InvalidationTracker;->access$getAutoCloser$p(Landroidx/room/InvalidationTracker;)Landroidx/room/AutoCloser; move-result-object v0 if-eqz v0, :cond_6 goto :goto_0 :goto_2 :try_start_8 const-string v3, "ROOM" const-string v4, "Cannot run invalidation tracker. Is the db closed?" .line 381 invoke-static {v3, v4, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I .line 385 invoke-static {}, Lkotlin/collections/SetsKt;->emptySet()Ljava/util/Set; move-result-object v3 :try_end_8 .catchall {:try_start_8 .. :try_end_8} :catchall_0 .line 393 invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V iget-object v0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 394 invoke-static {v0}, Landroidx/room/InvalidationTracker;->access$getAutoCloser$p(Landroidx/room/InvalidationTracker;)Landroidx/room/AutoCloser; move-result-object v0 if-eqz v0, :cond_6 goto :goto_0 .line 397 :cond_6 :goto_3 invoke-interface {v3}, Ljava/util/Collection;->isEmpty()Z move-result v0 xor-int/2addr v0, v1 if-eqz v0, :cond_8 iget-object v0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 398 invoke-virtual {v0}, Landroidx/room/InvalidationTracker;->getObserverMap$room_runtime_release()Landroidx/arch/core/internal/SafeIterableMap; move-result-object v0 iget-object v1, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; monitor-enter v0 .line 399 :try_start_9 invoke-virtual {v1}, Landroidx/room/InvalidationTracker;->getObserverMap$room_runtime_release()Landroidx/arch/core/internal/SafeIterableMap; move-result-object v1 .line 1855 invoke-interface {v1}, Ljava/lang/Iterable;->iterator()Ljava/util/Iterator; move-result-object v1 :goto_4 invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z move-result v2 if-eqz v2, :cond_7 invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v2 check-cast v2, Ljava/util/Map$Entry; .line 400 invoke-interface {v2}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object; move-result-object v2 check-cast v2, Landroidx/room/InvalidationTracker$ObserverWrapper; invoke-virtual {v2, v3}, Landroidx/room/InvalidationTracker$ObserverWrapper;->notifyByTableInvalidStatus$room_runtime_release(Ljava/util/Set;)V goto :goto_4 :catchall_2 move-exception v1 goto :goto_5 .line 402 :cond_7 sget-object v1, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit; :try_end_9 .catchall {:try_start_9 .. :try_end_9} :catchall_2 .line 398 monitor-exit v0 goto :goto_6 :goto_5 monitor-exit v0 throw v1 :cond_8 :goto_6 return-void .line 393 :goto_7 invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V iget-object v0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker; .line 394 invoke-static {v0}, Landroidx/room/InvalidationTracker;->access$getAutoCloser$p(Landroidx/room/InvalidationTracker;)Landroidx/room/AutoCloser; move-result-object v0 if-eqz v0, :cond_9 invoke-virtual {v0}, Landroidx/room/AutoCloser;->decrementCountAndScheduleClose()V :cond_9 throw v1 .end method