2020-05-11 18:07:26 +00:00
|
|
|
diff --git a/home/marcel/tmp/RoomTrackingLiveData.java b/app/src/main/java/androidx/room/RoomTrackingLiveData.java
|
|
|
|
index 8df1014a4..875beba9b 100644
|
|
|
|
--- a/home/marcel/tmp/RoomTrackingLiveData.java
|
|
|
|
+++ b/app/src/main/java/androidx/room/RoomTrackingLiveData.java
|
|
|
|
@@ -86,11 +86,22 @@ class RoomTrackingLiveData<T> extends LiveData<T> {
|
2019-08-01 07:37:09 +00:00
|
|
|
T value = null;
|
2020-05-11 18:07:26 +00:00
|
|
|
while (mInvalid.compareAndSet(true, false)) {
|
|
|
|
computed = true;
|
|
|
|
- try {
|
|
|
|
- value = mComputeFunction.call();
|
|
|
|
- } catch (Exception e) {
|
2019-07-27 11:53:30 +00:00
|
|
|
- throw new RuntimeException("Exception while computing database"
|
|
|
|
- + " live data.", e);
|
2020-05-11 18:07:26 +00:00
|
|
|
+ int retry = 0;
|
|
|
|
+ boolean done = false;
|
|
|
|
+ while (!done) {
|
2019-07-28 16:13:13 +00:00
|
|
|
+ try {
|
2020-05-11 18:07:26 +00:00
|
|
|
+ value = mComputeFunction.call();
|
|
|
|
+ done = true;
|
|
|
|
+ } catch (Exception e) {
|
|
|
|
+ if (++retry > 10)
|
|
|
|
+ throw new RuntimeException(
|
|
|
|
+ "Exception while computing database live data.", e);
|
|
|
|
+ eu.faircode.email.Log.w(e);
|
|
|
|
+ try {
|
|
|
|
+ Thread.sleep(3000L);
|
|
|
|
+ } catch (InterruptedException ignored) {
|
|
|
|
+ }
|
2019-07-28 16:13:13 +00:00
|
|
|
+ }
|
2019-07-27 11:53:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (computed) {
|
2020-05-11 18:07:26 +00:00
|
|
|
@@ -125,6 +136,7 @@ class RoomTrackingLiveData<T> extends LiveData<T> {
|
2019-07-28 13:49:06 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
+
|
|
|
|
@SuppressLint("RestrictedApi")
|
|
|
|
RoomTrackingLiveData(
|
|
|
|
RoomDatabase database,
|