All Downloads are FREE. Search and download functionalities are using the official Maven repository.

trace4cats.context.Unlift.scala Maven / Gradle / Ivy

There is a newer version: 0.14.7
Show newest version
package trace4cats.context

import cats.{~>, Monad}

trait Unlift[Low[_], F[_]] extends Lift[Low, F] { self =>
  def askUnlift: F[F ~> Low]

  def withUnlift[A](f: F ~> Low => Low[A]): F[A] = F.flatMap(askUnlift)(f.andThen(lift))

  def imapK[G[_]: Monad](fk: F ~> G, gk: G ~> F): Unlift[Low, G] = new Unlift[Low, G] {
    val Low: Monad[Low] = self.Low
    val F: Monad[G] = implicitly
    def lift[A](la: Low[A]): G[A] = fk(self.lift(la))
    def askUnlift: G[G ~> Low] = fk(self.F.map(self.askUnlift)(_.compose(gk)))
  }
}

object Unlift {
  def apply[Low[_], F[_]](implicit ev: Unlift[Low, F]): Unlift[Low, F] = ev
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy