Skip to content

Commit

Permalink
Revert "Fold RequestDelegate.assertActive into RequestDelegate.start. (
Browse files Browse the repository at this point in the history
…#2683)" (#2687)

This reverts commit f93ac43.
  • Loading branch information
colinrtwhite authored Nov 14, 2024
1 parent 49b92e9 commit 49b5441
Show file tree
Hide file tree
Showing 3 changed files with 8 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -52,14 +52,14 @@ internal class ViewTargetRequestDelegate(
imageLoader.enqueue(initialRequest)
}

override fun start() {
// Cancel the request before starting if the view is not attached.
// It will be restarted automatically when the view is attached.
override fun assertActive() {
if (!target.view.isAttachedToWindow) {
target.view.requestManager.setRequest(this)
throw CancellationException("'ViewTarget.view' must be attached to a window.")
}
}

override fun start() {
lifecycle?.addObserver(this)
if (target is LifecycleObserver) {
lifecycle?.removeAndAddObserver(target)
Expand Down
2 changes: 1 addition & 1 deletion coil-core/src/commonMain/kotlin/coil3/RealImageLoader.kt
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ internal class RealImageLoader(
request = initialRequest,
job = coroutineContext.job,
findLifecycle = type == REQUEST_TYPE_ENQUEUE,
)
).apply { assertActive() }

// Apply this image loader's defaults and other configuration to this request.
val request = requestService.updateRequest(initialRequest)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,10 +1,14 @@
package coil3.request

import kotlin.jvm.JvmInline
import kotlinx.coroutines.CancellationException
import kotlinx.coroutines.Job

internal interface RequestDelegate {

/** Throw a [CancellationException] if this request should be cancelled before starting. */
fun assertActive() {}

/** Register all lifecycle observers. */
fun start() {}

Expand Down

0 comments on commit 49b5441

Please sign in to comment.