From 73901f50c0aee1cb82695642af72ff6ac7bc232d Mon Sep 17 00:00:00 2001 From: Andreas Date: Mon, 25 Jul 2022 14:31:41 +0200 Subject: [PATCH] Use SharedFlow for available extensions to always emit the value (#7609) - Fixes Extension screen being stuck refreshing due to StateFlow not emitting due to the value being the same --- .../eu/kanade/tachiyomi/extension/ExtensionManager.kt | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/extension/ExtensionManager.kt b/app/src/main/java/eu/kanade/tachiyomi/extension/ExtensionManager.kt index b872987cb..aa9570770 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/extension/ExtensionManager.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/extension/ExtensionManager.kt @@ -19,8 +19,11 @@ import eu.kanade.tachiyomi.util.preference.plusAssign import eu.kanade.tachiyomi.util.system.logcat import eu.kanade.tachiyomi.util.system.toast import kotlinx.coroutines.async +import kotlinx.coroutines.flow.Flow +import kotlinx.coroutines.flow.MutableSharedFlow import kotlinx.coroutines.flow.MutableStateFlow import kotlinx.coroutines.flow.StateFlow +import kotlinx.coroutines.flow.asSharedFlow import kotlinx.coroutines.flow.asStateFlow import logcat.LogPriority import rx.Observable @@ -93,15 +96,15 @@ class ExtensionManager( var availableExtensions = emptyList() private set(value) { field = value - availableExtensionsFlow.value = field + availableExtensionsFlow.tryEmit(field) updatedInstalledExtensionsStatuses(value) setupAvailableExtensionsSourcesDataMap(value) } - private val availableExtensionsFlow = MutableStateFlow(availableExtensions) + private val availableExtensionsFlow = MutableSharedFlow>(replay = 1) - fun getAvailableExtensionsFlow(): StateFlow> { - return availableExtensionsFlow.asStateFlow() + fun getAvailableExtensionsFlow(): Flow> { + return availableExtensionsFlow.asSharedFlow() } private var availableExtensionsSourcesData: Map = mapOf()