From 1411dcf9712c726ec581dd81282d11875092915f Mon Sep 17 00:00:00 2001 From: "Diego E. Alonso Blas" Date: Sun, 21 Jun 2020 18:03:02 +0200 Subject: [PATCH] Add raiseOption method to as an extension method of Option. (#3358) Within an effect F with ApplicativeError instance, this allows us to raise an option if there is Some error, or skip if it there is None. --- core/src/main/scala/cats/syntax/option.scala | 21 ++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/core/src/main/scala/cats/syntax/option.scala b/core/src/main/scala/cats/syntax/option.scala index cb4c74a45c..3550377fcc 100644 --- a/core/src/main/scala/cats/syntax/option.scala +++ b/core/src/main/scala/cats/syntax/option.scala @@ -334,6 +334,27 @@ final class OptionOps[A](private val oa: Option[A]) extends AnyVal { */ def liftTo[F[_]]: LiftToPartiallyApplied[F, A] = new LiftToPartiallyApplied(oa) + /** + * Raise to an F[Unit], as long as it has an ApplicativeError[F, A] instance + * If the option is empty, an empty unit effect is given. + * If the option contains an error, it is raised. + * + * Example: + * {{{ + * scala> import cats.implicits._ + * + * scala> type F[A] = Either[String, A] + * + * scala> Option.empty[String].raiseTo[F] + * res0: scala.Either[String, Unit] = Right(()) + * + * scala> Option("Failed").raiseTo[F] + * res1: scala.Either[String, Unit] = Left(Failed) + * }}} + */ + def raiseTo[F[_]](implicit F: ApplicativeError[F, A]): F[Unit] = + oa.fold(F.unit)(F.raiseError) + /** * Transform the `Option` into a [[cats.data.OptionT]] while lifting it into the specified Applicative. *