From e898454cb63520275b37f34ffef4a06515a8d713 Mon Sep 17 00:00:00 2001 From: Vasil Vasilev Date: Wed, 14 Jul 2021 00:08:41 +0200 Subject: [PATCH 1/2] Reimplement IO#guaranteeCase --- core/shared/src/main/scala/cats/effect/IO.scala | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/core/shared/src/main/scala/cats/effect/IO.scala b/core/shared/src/main/scala/cats/effect/IO.scala index e4d6b80c62..c418513d68 100644 --- a/core/shared/src/main/scala/cats/effect/IO.scala +++ b/core/shared/src/main/scala/cats/effect/IO.scala @@ -400,7 +400,15 @@ sealed abstract class IO[+A] private () extends IOPlatform[A] { * @see [[guarantee]] for the simpler version */ def guaranteeCase(finalizer: OutcomeIO[A @uncheckedVariance] => IO[Unit]): IO[A] = - IO.unit.bracketCase(_ => this)((_, oc) => finalizer(oc)) + IO.uncancelable { poll => + val finalized = poll(this).onCancel(finalizer(Outcome.canceled)) + val handled = finalized.onError { e => + finalizer(Outcome.errored(e)).handleErrorWith { t => + IO.executionContext.flatMap(ec => IO(ec.reportFailure(t))) + } + } + handled.flatTap(a => finalizer(Outcome.succeeded(IO.pure(a)))) + } /** * Handle any error, potentially recovering from it, by mapping it to another From eb33205f25c75b014a926e637ea9fac742f481b2 Mon Sep 17 00:00:00 2001 From: Vasil Vasilev Date: Wed, 14 Jul 2021 00:16:35 +0200 Subject: [PATCH 2/2] Simplify IO.bracketFull --- core/shared/src/main/scala/cats/effect/IO.scala | 13 +------------ 1 file changed, 1 insertion(+), 12 deletions(-) diff --git a/core/shared/src/main/scala/cats/effect/IO.scala b/core/shared/src/main/scala/cats/effect/IO.scala index c418513d68..a97dd4db21 100644 --- a/core/shared/src/main/scala/cats/effect/IO.scala +++ b/core/shared/src/main/scala/cats/effect/IO.scala @@ -1161,18 +1161,7 @@ object IO extends IOCompanionPlatform with IOLowPriorityImplicits { def bracketFull[A, B](acquire: Poll[IO] => IO[A])(use: A => IO[B])( release: (A, OutcomeIO[B]) => IO[Unit]): IO[B] = IO.uncancelable { poll => - acquire(poll).flatMap { a => - def fin(oc: OutcomeIO[B]) = IO.uncancelable(_ => release(a, oc)) - - val finalized = poll(IO.defer(use(a))).onCancel(fin(Outcome.canceled)) - val handled = finalized.onError { e => - fin(Outcome.errored(e)) handleErrorWith { t => - IO.executionContext.flatMap(ec => IO(ec.reportFailure(t))) - } - } - - handled.flatTap(b => fin(Outcome.succeeded(IO.pure(b)))) - } + acquire(poll).flatMap { a => IO.defer(poll(use(a))).guaranteeCase(release(a, _)) } } /*