From 5e3b9c17f7aa31ce65f3b3770b7ec85a8dc3ab5a Mon Sep 17 00:00:00 2001 From: Uwe Trottmann Date: Wed, 18 May 2022 15:34:42 +0200 Subject: [PATCH] ANR: do not use main thread to check to update single show. This should fix the top reported ANR. --- .../seriesguide/ui/BaseActivity.kt | 28 +++++++------------ 1 file changed, 10 insertions(+), 18 deletions(-) diff --git a/app/src/main/java/com/battlelancer/seriesguide/ui/BaseActivity.kt b/app/src/main/java/com/battlelancer/seriesguide/ui/BaseActivity.kt index f01c4945a8..69bbefa6b6 100644 --- a/app/src/main/java/com/battlelancer/seriesguide/ui/BaseActivity.kt +++ b/app/src/main/java/com/battlelancer/seriesguide/ui/BaseActivity.kt @@ -1,15 +1,17 @@ package com.battlelancer.seriesguide.ui -import android.os.Handler -import android.os.Looper import android.text.format.DateUtils +import androidx.lifecycle.lifecycleScope import com.battlelancer.seriesguide.dataliberation.BackupSettings +import com.battlelancer.seriesguide.shows.tools.AddShowTask.OnShowAddedEvent import com.battlelancer.seriesguide.sync.SgSyncAdapter import com.battlelancer.seriesguide.sync.SgSyncAdapter.Companion.requestSyncIfTime import com.battlelancer.seriesguide.traktapi.TraktTask.TraktActionCompleteEvent -import com.battlelancer.seriesguide.shows.tools.AddShowTask.OnShowAddedEvent import com.battlelancer.seriesguide.util.DBUtils.DatabaseErrorEvent import com.battlelancer.seriesguide.util.TaskManager +import kotlinx.coroutines.Dispatchers +import kotlinx.coroutines.delay +import kotlinx.coroutines.launch import org.greenrobot.eventbus.EventBus import org.greenrobot.eventbus.Subscribe import org.greenrobot.eventbus.ThreadMode @@ -22,9 +24,6 @@ import org.greenrobot.eventbus.ThreadMode */ abstract class BaseActivity : BaseThemeActivity() { - private var handler: Handler? = null - private var updateShowRunnable: Runnable? = null - override fun onStart() { super.onStart() // make sync interfering with backup task less likely @@ -45,11 +44,6 @@ abstract class BaseActivity : BaseThemeActivity() { override fun onStop() { super.onStop() - val handler = handler - val updateShowRunnable = updateShowRunnable - if (handler != null && updateShowRunnable != null) { - handler.removeCallbacks(updateShowRunnable) - } unregisterEventBus() } @@ -126,13 +120,11 @@ abstract class BaseActivity : BaseThemeActivity() { * See [SgSyncAdapter.requestSyncIfTime]. */ protected fun updateShowDelayed(showId: Long) { - val handler = handler ?: Handler(Looper.getMainLooper()) - .also { handler = it } - - // delay sync request to avoid slowing down UI val context = applicationContext - val updateShowRunnable = Runnable { requestSyncIfTime(context, showId) } - .also { updateShowRunnable = it } - handler.postDelayed(updateShowRunnable, DateUtils.SECOND_IN_MILLIS) + lifecycleScope.launch(Dispatchers.IO) { + // Delay sync request to avoid slowing down UI. + delay(DateUtils.SECOND_IN_MILLIS) + requestSyncIfTime(context, showId) + } } } \ No newline at end of file