Updated AndroidX

pull/215/head
M66B 7 months ago
parent 36f9282d8c
commit eebdff9fda

@ -526,7 +526,7 @@ configurations.configureEach {
} else if (details.requested.group == "androidx.lifecycle" && } else if (details.requested.group == "androidx.lifecycle" &&
details.requested.name != "lifecycle-extensions") { details.requested.name != "lifecycle-extensions") {
//print("Pinning " + details.requested.group + ":" + details.requested.name + "\n") //print("Pinning " + details.requested.group + ":" + details.requested.name + "\n")
details.useVersion "2.7.0" details.useVersion "2.8.1"
} else if (details.requested.group == "org.apache.poi") { } else if (details.requested.group == "org.apache.poi") {
//print("Pinning " + details.requested.group + ":" + details.requested.name + "\n") //print("Pinning " + details.requested.group + ":" + details.requested.name + "\n")
details.useVersion "3.17" details.useVersion "3.17"
@ -547,11 +547,11 @@ dependencies {
def startup_version = "1.2.0-alpha02" def startup_version = "1.2.0-alpha02"
def annotation_version_experimental = "1.4.1" def annotation_version_experimental = "1.4.1"
def core_version = "1.13.1" // 1.15.0-alpha01 def core_version = "1.13.1" // 1.15.0-alpha01
def appcompat_version = "1.6.1" // 1.7.0-rc01 def appcompat_version = "1.7.0"
def emoji_version = "1.4.0" // 1.5.0-alpha01 def emoji_version = "1.4.0" // 1.5.0-alpha01
def flatbuffers_version = "2.0.0" def flatbuffers_version = "2.0.0"
def activity_version = " 1.9.0" def activity_version = " 1.9.0"
def fragment_version = "1.7.1" // 1.8.0 def fragment_version = "1.8.0"
def windows_version = "1.2.0" // 1.3.0-rc01 def windows_version = "1.2.0" // 1.3.0-rc01
def webkit_version = "1.10.0" // 1.11.0/1.12.0-alpha02 def webkit_version = "1.10.0" // 1.11.0/1.12.0-alpha02
def recyclerview_version = "1.3.2" // 1.4.0-alpha01 def recyclerview_version = "1.3.2" // 1.4.0-alpha01
@ -562,7 +562,7 @@ dependencies {
def lbm_version = "1.1.0" def lbm_version = "1.1.0"
def swiperefresh_version = "1.2.0-alpha01" def swiperefresh_version = "1.2.0-alpha01"
def documentfile_version = "1.1.0-alpha01" def documentfile_version = "1.1.0-alpha01"
def lifecycle_version = "2.7.0" // 2.8.1 def lifecycle_version = "2.8.1"
def lifecycle_extensions_version = "2.2.0" def lifecycle_extensions_version = "2.2.0"
def room_version = "2.4.3" // 2.5.2/2.6.1/2.7.0-alpha04 def room_version = "2.4.3" // 2.5.2/2.6.1/2.7.0-alpha04
def sqlite_version = "2.4.0" // 2.5.0-alpha04 def sqlite_version = "2.4.0" // 2.5.0-alpha04

@ -18,22 +18,19 @@
package androidx.lifecycle package androidx.lifecycle
import android.annotation.SuppressLint
import android.os.Build import android.os.Build
import androidx.annotation.RequiresApi import androidx.annotation.RequiresApi
import androidx.arch.core.executor.ArchTaskExecutor import androidx.arch.core.executor.ArchTaskExecutor
import java.time.Duration import java.time.Duration
import kotlin.coroutines.CoroutineContext import kotlin.coroutines.CoroutineContext
import kotlin.coroutines.EmptyCoroutineContext import kotlin.coroutines.EmptyCoroutineContext
import kotlinx.coroutines.DelicateCoroutinesApi
import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.GlobalScope import kotlinx.coroutines.NonCancellable
import kotlinx.coroutines.channels.awaitClose import kotlinx.coroutines.awaitCancellation
import kotlinx.coroutines.flow.Flow import kotlinx.coroutines.flow.Flow
import kotlinx.coroutines.flow.StateFlow import kotlinx.coroutines.flow.StateFlow
import kotlinx.coroutines.flow.callbackFlow import kotlinx.coroutines.flow.callbackFlow
import kotlinx.coroutines.flow.conflate import kotlinx.coroutines.flow.conflate
import kotlinx.coroutines.launch
import kotlinx.coroutines.withContext import kotlinx.coroutines.withContext
/** /**
@ -84,7 +81,6 @@ public fun <T> Flow<T>.asLiveData(
}.also { liveData -> }.also { liveData ->
val flow = this val flow = this
if (flow is StateFlow<T>) { if (flow is StateFlow<T>) {
@SuppressLint("RestrictedApi")
if (ArchTaskExecutor.getInstance().isMainThread) { if (ArchTaskExecutor.getInstance().isMainThread) {
liveData.value = flow.value liveData.value = flow.value
} else { } else {
@ -104,7 +100,6 @@ public fun <T> Flow<T>.asLiveData(
* BackPressure: the returned flow is conflated. There is no mechanism to suspend an emission by * BackPressure: the returned flow is conflated. There is no mechanism to suspend an emission by
* LiveData due to a slow collector, so collector always gets the most recent value emitted. * LiveData due to a slow collector, so collector always gets the most recent value emitted.
*/ */
@OptIn(DelicateCoroutinesApi::class)
public fun <T> LiveData<T>.asFlow(): Flow<T> = callbackFlow { public fun <T> LiveData<T>.asFlow(): Flow<T> = callbackFlow {
val observer = Observer<T> { val observer = Observer<T> {
trySend(it) trySend(it)
@ -113,8 +108,10 @@ public fun <T> LiveData<T>.asFlow(): Flow<T> = callbackFlow {
observeForever(observer) observeForever(observer)
} }
awaitClose { try {
GlobalScope.launch(Dispatchers.Main.immediate) { awaitCancellation()
} finally {
withContext(Dispatchers.Main.immediate + NonCancellable) {
removeObserver(observer) removeObserver(observer)
} }
} }

@ -0,0 +1,55 @@
/*
* Copyright 2018 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package androidx.lifecycle
import androidx.annotation.MainThread
/**
* Adds the given [onChanged] lambda as an observer within the lifespan of the given
* [owner] and returns a reference to observer.
* The events are dispatched on the main thread. If LiveData already has data
* set, it will be delivered to the onChanged.
*
* The observer will only receive events if the owner is in [Lifecycle.State.STARTED]
* or [Lifecycle.State.RESUMED] state (active).
*
* If the owner moves to the [Lifecycle.State.DESTROYED] state, the observer will
* automatically be removed.
*
* When data changes while the [owner] is not active, it will not receive any updates.
* If it becomes active again, it will receive the last available data automatically.
*
* LiveData keeps a strong reference to the observer and the owner as long as the
* given LifecycleOwner is not destroyed. When it is destroyed, LiveData removes references to
* the observer and the owner.
*
* If the given owner is already in [Lifecycle.State.DESTROYED] state, LiveData
* ignores the call.
*/
@Deprecated(
"This extension method is not required when using Kotlin 1.4. " +
"You should remove \"import androidx.lifecycle.observe\""
)
@MainThread
public inline fun <T> LiveData<T>.observe(
owner: LifecycleOwner,
crossinline onChanged: (T) -> Unit
): Observer<T> {
val wrappedObserver = Observer<T> { t -> onChanged.invoke(t) }
observe(owner, wrappedObserver)
return wrappedObserver
}

@ -49,9 +49,10 @@ import androidx.arch.core.util.Function
fun <X, Y> LiveData<X>.map( fun <X, Y> LiveData<X>.map(
transform: (@JvmSuppressWildcards X) -> (@JvmSuppressWildcards Y) transform: (@JvmSuppressWildcards X) -> (@JvmSuppressWildcards Y)
): LiveData<Y> { ): LiveData<Y> {
val result = MediatorLiveData<Y>() val result = if (isInitialized) {
if (isInitialized) { MediatorLiveData(transform(value as X))
result.value = transform(value as X) } else {
MediatorLiveData()
} }
result.addSource(this) { x -> result.value = transform(x) } result.addSource(this) { x -> result.value = transform(x) }
return result return result
@ -121,13 +122,16 @@ fun <X, Y> LiveData<X>.map(mapFunction: Function<X, Y>): LiveData<Y> {
fun <X, Y> LiveData<X>.switchMap( fun <X, Y> LiveData<X>.switchMap(
transform: (@JvmSuppressWildcards X) -> (@JvmSuppressWildcards LiveData<Y>)? transform: (@JvmSuppressWildcards X) -> (@JvmSuppressWildcards LiveData<Y>)?
): LiveData<Y> { ): LiveData<Y> {
val result = MediatorLiveData<Y>()
var liveData: LiveData<Y>? = null var liveData: LiveData<Y>? = null
if (isInitialized) { val result = if (isInitialized) {
val initialLiveData = transform(value as X) val initialLiveData = transform(value as X)
if (initialLiveData != null && initialLiveData.isInitialized) { if (initialLiveData != null && initialLiveData.isInitialized) {
result.value = initialLiveData.value MediatorLiveData<Y>(initialLiveData.value)
} else {
MediatorLiveData<Y>()
} }
} else {
MediatorLiveData<Y>()
} }
result.addSource(this) { value: X -> result.addSource(this) { value: X ->
val newLiveData = transform(value) val newLiveData = transform(value)
@ -183,11 +187,12 @@ fun <X, Y> LiveData<X>.switchMap(switchMapFunction: Function<X, LiveData<Y>>): L
@MainThread @MainThread
@CheckResult @CheckResult
fun <X> LiveData<X>.distinctUntilChanged(): LiveData<X> { fun <X> LiveData<X>.distinctUntilChanged(): LiveData<X> {
val outputLiveData = MediatorLiveData<X>()
var firstTime = true var firstTime = true
if (isInitialized) { val outputLiveData = if (isInitialized) {
outputLiveData.value = value
firstTime = false firstTime = false
MediatorLiveData<X>(value)
} else {
MediatorLiveData<X>()
} }
outputLiveData.addSource(this) { value -> outputLiveData.addSource(this) { value ->
val previousValue = outputLiveData.value val previousValue = outputLiveData.value

Loading…
Cancel
Save