Merge branch 'master' into devel
This commit is contained in:
@@ -1,14 +1,14 @@
|
||||
package org.koitharu.kotatsu.utils
|
||||
|
||||
import android.util.ArrayMap
|
||||
import java.util.*
|
||||
import kotlin.coroutines.coroutineContext
|
||||
import kotlin.coroutines.resume
|
||||
import kotlinx.coroutines.CancellableContinuation
|
||||
import kotlinx.coroutines.currentCoroutineContext
|
||||
import kotlinx.coroutines.isActive
|
||||
import kotlinx.coroutines.suspendCancellableCoroutine
|
||||
import kotlinx.coroutines.sync.Mutex
|
||||
import kotlinx.coroutines.sync.withLock
|
||||
import java.util.*
|
||||
import kotlin.coroutines.resume
|
||||
|
||||
class CompositeMutex<T : Any> : Set<T> {
|
||||
|
||||
@@ -35,7 +35,7 @@ class CompositeMutex<T : Any> : Set<T> {
|
||||
}
|
||||
|
||||
suspend fun lock(element: T) {
|
||||
while (currentCoroutineContext().isActive) {
|
||||
while (coroutineContext.isActive) {
|
||||
waitForRemoval(element)
|
||||
mutex.withLock {
|
||||
if (data[element] == null) {
|
||||
@@ -46,11 +46,9 @@ class CompositeMutex<T : Any> : Set<T> {
|
||||
}
|
||||
}
|
||||
|
||||
suspend fun unlock(element: T) {
|
||||
val continuations = mutex.withLock {
|
||||
checkNotNull(data.remove(element)) {
|
||||
"CompositeMutex is not locked for $element"
|
||||
}
|
||||
fun unlock(element: T) {
|
||||
val continuations = checkNotNull(data.remove(element)) {
|
||||
"CompositeMutex is not locked for $element"
|
||||
}
|
||||
continuations.forEach { c ->
|
||||
if (c.isActive) {
|
||||
@@ -68,4 +66,4 @@ class CompositeMutex<T : Any> : Set<T> {
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,45 +0,0 @@
|
||||
package org.koitharu.kotatsu.utils
|
||||
|
||||
import android.app.Activity
|
||||
import android.content.ComponentName
|
||||
import android.content.Intent
|
||||
import android.content.ServiceConnection
|
||||
import android.os.IBinder
|
||||
import androidx.lifecycle.DefaultLifecycleObserver
|
||||
import androidx.lifecycle.LifecycleOwner
|
||||
import kotlinx.coroutines.flow.MutableStateFlow
|
||||
import kotlinx.coroutines.flow.StateFlow
|
||||
|
||||
class LifecycleAwareServiceConnection(
|
||||
private val host: Activity,
|
||||
) : ServiceConnection, DefaultLifecycleObserver {
|
||||
|
||||
private val serviceStateFlow = MutableStateFlow<IBinder?>(null)
|
||||
|
||||
val service: StateFlow<IBinder?>
|
||||
get() = serviceStateFlow
|
||||
|
||||
override fun onServiceConnected(name: ComponentName?, service: IBinder?) {
|
||||
serviceStateFlow.value = service
|
||||
}
|
||||
|
||||
override fun onServiceDisconnected(name: ComponentName?) {
|
||||
serviceStateFlow.value = null
|
||||
}
|
||||
|
||||
override fun onDestroy(owner: LifecycleOwner) {
|
||||
super.onDestroy(owner)
|
||||
host.unbindService(this)
|
||||
}
|
||||
}
|
||||
|
||||
fun Activity.bindServiceWithLifecycle(
|
||||
owner: LifecycleOwner,
|
||||
service: Intent,
|
||||
flags: Int
|
||||
): LifecycleAwareServiceConnection {
|
||||
val connection = LifecycleAwareServiceConnection(this)
|
||||
bindService(service, connection, flags)
|
||||
owner.lifecycle.addObserver(connection)
|
||||
return connection
|
||||
}
|
||||
Reference in New Issue
Block a user