|
|
@ -16,6 +16,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
package androidx.lifecycle;
|
|
|
|
package androidx.lifecycle;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import android.os.SystemClock;
|
|
|
|
|
|
|
|
|
|
|
|
import androidx.annotation.MainThread;
|
|
|
|
import androidx.annotation.MainThread;
|
|
|
|
import androidx.annotation.NonNull;
|
|
|
|
import androidx.annotation.NonNull;
|
|
|
|
import androidx.annotation.RestrictTo;
|
|
|
|
import androidx.annotation.RestrictTo;
|
|
|
@ -89,14 +91,22 @@ public abstract class ComputableLiveData<T> {
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
public void run() {
|
|
|
|
boolean computed;
|
|
|
|
boolean computed;
|
|
|
|
|
|
|
|
long age;
|
|
|
|
do {
|
|
|
|
do {
|
|
|
|
computed = false;
|
|
|
|
computed = false;
|
|
|
|
// compute can happen only in 1 thread but no reason to lock others.
|
|
|
|
// compute can happen only in 1 thread but no reason to lock others.
|
|
|
|
if (mComputing.compareAndSet(false, true)) {
|
|
|
|
if (mComputing.compareAndSet(false, true)) {
|
|
|
|
// as long as it is invalid, keep computing.
|
|
|
|
// as long as it is invalid, keep computing.
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
|
|
|
|
age = SystemClock.elapsedRealtime();
|
|
|
|
T value = null;
|
|
|
|
T value = null;
|
|
|
|
while (mInvalid.compareAndSet(true, false)) {
|
|
|
|
while (mInvalid.compareAndSet(true, false)) {
|
|
|
|
|
|
|
|
long now = SystemClock.elapsedRealtime();
|
|
|
|
|
|
|
|
if (age + 1500 < now && value != null) {
|
|
|
|
|
|
|
|
eu.faircode.email.Log.i(mLiveData + " post age=" + (now - age));
|
|
|
|
|
|
|
|
age = now;
|
|
|
|
|
|
|
|
mLiveData.postValue(value);
|
|
|
|
|
|
|
|
}
|
|
|
|
computed = true;
|
|
|
|
computed = true;
|
|
|
|
value = compute();
|
|
|
|
value = compute();
|
|
|
|
}
|
|
|
|
}
|
|
|
|