FairEmail/patches/room.patch

41 lines
2.0 KiB
Diff
Raw Normal View History

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) {
- 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
+ }
}
}
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,