Rabbit-R1/switch port/smali/smali_classes2/androidx/room/InvalidationTracker$refreshRunnable$1.smali
2024-05-21 17:08:36 -04:00

606 lines
18 KiB
Smali

.class public final Landroidx/room/InvalidationTracker$refreshRunnable$1;
.super Ljava/lang/Object;
.source "InvalidationTracker.kt"
# interfaces
.implements Ljava/lang/Runnable;
# annotations
.annotation system Ldalvik/annotation/EnclosingMethod;
value = Landroidx/room/InvalidationTracker;-><init>(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 system Ldalvik/annotation/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,846:1\n1851#2,2:847\n145#3,7:849\n*S KotlinDebug\n*F\n+ 1 InvalidationTracker.kt\nandroidx/room/InvalidationTracker$refreshRunnable$1\n*L\n401#1:847,2\n410#1:849,7\n*E\n"
.end annotation
.annotation runtime Lkotlin/Metadata;
d1 = {
"\u0000\u001b\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\"\n\u0002\u0010\u0008\n\u0000\n\u0002\u0010\u0002\n\u0000*\u0001\u0000\u0008\n\u0018\u00002\u00020\u0001J\u000e\u0010\u0002\u001a\u0008\u0012\u0004\u0012\u00020\u00040\u0003H\u0002J\u0008\u0010\u0005\u001a\u00020\u0006H\u0016\u00a8\u0006\u0007"
}
d2 = {
"androidx/room/InvalidationTracker$refreshRunnable$1",
"Ljava/lang/Runnable;",
"checkUpdatedTable",
"",
"",
"run",
"",
"room-runtime_release"
}
k = 0x1
mv = {
0x1,
0x7,
0x1
}
xi = 0x30
.end annotation
# instance fields
.field final synthetic this$0:Landroidx/room/InvalidationTracker;
# direct methods
.method constructor <init>(Landroidx/room/InvalidationTracker;)V
.locals 0
iput-object p1, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker;
.line 349
invoke-direct {p0}, Ljava/lang/Object;-><init>()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 409
invoke-static {}, Lkotlin/collections/SetsKt;->createSetBuilder()Ljava/util/Set;
move-result-object v1
.line 410
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;-><init>(Ljava/lang/String;)V
check-cast v2, Landroidx/sqlite/db/SupportSQLiteQuery;
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 850
check-cast v0, Ljava/io/Closeable;
:try_start_0
move-object v2, v0
check-cast v2, Landroid/database/Cursor;
.line 411
:goto_0
invoke-interface {v2}, Landroid/database/Cursor;->moveToNext()Z
move-result v3
if-eqz v3, :cond_0
const/4 v3, 0x0
.line 412
invoke-interface {v2, v3}, Landroid/database/Cursor;->getInt(I)I
move-result v3
invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v3
invoke-interface {v1, v3}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
goto :goto_0
.line 414
:cond_0
sget-object v2, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit;
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
.line 850
invoke-static {v0, v4}, Lkotlin/io/CloseableKt;->closeFinally(Ljava/io/Closeable;Ljava/lang/Throwable;)V
.line 409
invoke-static {v1}, Lkotlin/collections/SetsKt;->build(Ljava/util/Set;)Ljava/util/Set;
move-result-object v0
.line 416
move-object v1, v0
check-cast v1, Ljava/util/Collection;
invoke-interface {v1}, 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 417
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 p0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker;
.line 418
invoke-virtual {p0}, Landroidx/room/InvalidationTracker;->getCleanupStatement$room_runtime_release()Landroidx/sqlite/db/SupportSQLiteStatement;
move-result-object p0
if-eqz p0, :cond_1
.line 420
invoke-interface {p0}, Landroidx/sqlite/db/SupportSQLiteStatement;->executeUpdateDelete()I
goto :goto_1
.line 419
:cond_1
new-instance p0, Ljava/lang/IllegalArgumentException;
invoke-virtual {v2}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {p0, v0}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p0
.line 417
:cond_2
new-instance p0, Ljava/lang/IllegalStateException;
invoke-virtual {v2}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {p0, v0}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p0
:cond_3
:goto_1
return-object v0
:catchall_0
move-exception p0
.line 850
:try_start_1
throw p0
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_1
:catchall_1
move-exception v1
invoke-static {v0, p0}, Lkotlin/io/CloseableKt;->closeFinally(Ljava/io/Closeable;Ljava/lang/Throwable;)V
throw v1
.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 351
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 352
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 355
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_1
if-nez v2, :cond_1
.line 395
invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V
iget-object p0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker;
.line 396
invoke-static {p0}, Landroidx/room/InvalidationTracker;->access$getAutoCloser$p(Landroidx/room/InvalidationTracker;)Landroidx/room/AutoCloser;
move-result-object p0
if-eqz p0, :cond_0
invoke-virtual {p0}, 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 358
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_1
if-nez v2, :cond_3
.line 395
invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V
iget-object p0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker;
.line 396
invoke-static {p0}, Landroidx/room/InvalidationTracker;->access$getAutoCloser$p(Landroidx/room/InvalidationTracker;)Landroidx/room/AutoCloser;
move-result-object p0
if-eqz p0, :cond_2
invoke-virtual {p0}, 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 362
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_1
if-eqz v2, :cond_5
.line 395
invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V
iget-object p0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker;
.line 396
invoke-static {p0}, Landroidx/room/InvalidationTracker;->access$getAutoCloser$p(Landroidx/room/InvalidationTracker;)Landroidx/room/AutoCloser;
move-result-object p0
if-eqz p0, :cond_4
invoke-virtual {p0}, 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 371
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 372
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_1
.line 375
:try_start_4
invoke-direct {p0}, Landroidx/room/InvalidationTracker$refreshRunnable$1;->checkUpdatedTable()Ljava/util/Set;
move-result-object v3
.line 376
invoke-interface {v2}, Landroidx/sqlite/db/SupportSQLiteDatabase;->setTransactionSuccessful()V
:try_end_4
.catchall {:try_start_4 .. :try_end_4} :catchall_0
.line 378
: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_1
.line 395
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 396
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_1
:catchall_0
move-exception v3
.line 378
: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_1
:catchall_1
move-exception v1
goto :goto_4
:catch_0
move-exception v2
:try_start_7
const-string v3, "ROOM"
const-string v4, "Cannot run invalidation tracker. Is the db closed?"
.line 391
check-cast v2, Ljava/lang/Throwable;
.line 389
invoke-static {v3, v4, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 393
invoke-static {}, Lkotlin/collections/SetsKt;->emptySet()Ljava/util/Set;
move-result-object v3
:try_end_7
.catchall {:try_start_7 .. :try_end_7} :catchall_1
.line 395
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 396
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
:catch_1
move-exception v2
:try_start_8
const-string v3, "ROOM"
const-string v4, "Cannot run invalidation tracker. Is the db closed?"
.line 385
check-cast v2, Ljava/lang/Throwable;
.line 383
invoke-static {v3, v4, v2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 387
invoke-static {}, Lkotlin/collections/SetsKt;->emptySet()Ljava/util/Set;
move-result-object v3
:try_end_8
.catchall {:try_start_8 .. :try_end_8} :catchall_1
.line 395
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 396
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 399
:cond_6
:goto_1
move-object v0, v3
check-cast v0, Ljava/util/Collection;
invoke-interface {v0}, 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 400
invoke-virtual {v0}, Landroidx/room/InvalidationTracker;->getObserverMap$room_runtime_release()Landroidx/arch/core/internal/SafeIterableMap;
move-result-object v0
iget-object p0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker;
monitor-enter v0
.line 401
:try_start_9
invoke-virtual {p0}, Landroidx/room/InvalidationTracker;->getObserverMap$room_runtime_release()Landroidx/arch/core/internal/SafeIterableMap;
move-result-object p0
check-cast p0, Ljava/lang/Iterable;
.line 847
invoke-interface {p0}, Ljava/lang/Iterable;->iterator()Ljava/util/Iterator;
move-result-object p0
:goto_2
invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_7
invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/util/Map$Entry;
.line 402
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
check-cast v1, Landroidx/room/InvalidationTracker$ObserverWrapper;
invoke-virtual {v1, v3}, Landroidx/room/InvalidationTracker$ObserverWrapper;->notifyByTableInvalidStatus$room_runtime_release(Ljava/util/Set;)V
goto :goto_2
.line 404
:cond_7
sget-object p0, Lkotlin/Unit;->INSTANCE:Lkotlin/Unit;
:try_end_9
.catchall {:try_start_9 .. :try_end_9} :catchall_2
.line 400
monitor-exit v0
goto :goto_3
:catchall_2
move-exception p0
monitor-exit v0
throw p0
:cond_8
:goto_3
return-void
.line 395
:goto_4
invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V
iget-object p0, p0, Landroidx/room/InvalidationTracker$refreshRunnable$1;->this$0:Landroidx/room/InvalidationTracker;
.line 396
invoke-static {p0}, Landroidx/room/InvalidationTracker;->access$getAutoCloser$p(Landroidx/room/InvalidationTracker;)Landroidx/room/AutoCloser;
move-result-object p0
if-eqz p0, :cond_9
invoke-virtual {p0}, Landroidx/room/AutoCloser;->decrementCountAndScheduleClose()V
:cond_9
throw v1
.end method