Prevent ROOM tracker from looping

pull/160/head
M66B 6 years ago
parent abbd89eece
commit 9f1f446210

@ -93,6 +93,8 @@ class RoomTrackingLiveData<T> extends LiveData<T> {
//throw new RuntimeException("Exception while computing database" //throw new RuntimeException("Exception while computing database"
// + " live data.", e); // + " live data.", e);
computed = false; computed = false;
mInvalid.set(false);
break;
} }
} }
if (computed) { if (computed) {
@ -127,6 +129,7 @@ class RoomTrackingLiveData<T> extends LiveData<T> {
} }
} }
}; };
@SuppressLint("RestrictedApi") @SuppressLint("RestrictedApi")
RoomTrackingLiveData( RoomTrackingLiveData(
RoomDatabase database, RoomDatabase database,

@ -1,8 +1,6 @@
diff --git a/app/src/main/java/androidx/room/RoomTrackingLiveData.java b/app/src/main/java/androidx/room/RoomTrackingLiveData.java --- /home/marcel/support/room/runtime/src/main/java/androidx/room/RoomTrackingLiveData.java 2019-07-27 12:47:44.950985792 +0200
index 8df1014a4..f6086584b 100644 +++ app/src/main/java/androidx/room/RoomTrackingLiveData.java 2019-07-28 15:50:45.670936158 +0200
--- a/app/src/main/java/androidx/room/RoomTrackingLiveData.java @@ -89,8 +89,12 @@ class RoomTrackingLiveData<T> extends Li
+++ b/app/src/main/java/androidx/room/RoomTrackingLiveData.java
@@ -89,8 +89,10 @@ class RoomTrackingLiveData<T> extends LiveData<T> {
try { try {
value = mComputeFunction.call(); value = mComputeFunction.call();
} catch (Exception e) { } catch (Exception e) {
@ -12,6 +10,16 @@ index 8df1014a4..f6086584b 100644
+ //throw new RuntimeException("Exception while computing database" + //throw new RuntimeException("Exception while computing database"
+ // + " live data.", e); + // + " live data.", e);
+ computed = false; + computed = false;
+ mInvalid.set(false);
+ break;
} }
} }
if (computed) { if (computed) {
@@ -125,6 +129,7 @@ class RoomTrackingLiveData<T> extends Li
}
}
};
+
@SuppressLint("RestrictedApi")
RoomTrackingLiveData(
RoomDatabase database,

Loading…
Cancel
Save