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

doobieroll.LeafDef.scala Maven / Gradle / Ivy

The newest version!
package doobieroll

import cats.Id
import cats.arrow.FunctionK

/**
  * Definition of a domain type with no children, converting from a database columns group type ADb
  * The construction may or may not fail, represented by the error context F
  * @tparam F The validation context. For example Either[MyDbConversionError, ?] or Validated[MyDbConversionError, ?]
  * @tparam A The domain type
  * @tparam ADb The database column group type
  */
trait LeafDef[F[_], A, ADb] { self =>
  def construct(db: ADb): F[A]

  final def mapK[G[_]](transform: FunctionK[F, G]): LeafDef[G, A, ADb] =
    LeafDef.makeF[G, A, ADb](adb => transform(self.construct(adb)))

}

object LeafDef {
  def make[A, ADb](f: ADb => A): LeafDef[Id, A, ADb] =
    new LeafDef[cats.Id, A, ADb] {
      override def construct(db: ADb): A = f(db)
    }

  def makeF[F[_], A, ADb](f: ADb => F[A]): LeafDef[F, A, ADb] =
    new LeafDef[F, A, ADb] {
      override def construct(db: ADb): F[A] = f(db)
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy