From 4a5fea2b9ec38afbbd495a55c3b95e15f4f1d2eb Mon Sep 17 00:00:00 2001 From: tbrown1979 Date: Sat, 4 Jun 2016 13:58:05 -0500 Subject: [PATCH 1/4] Adding a way to create a Kleisli with just F[B] --- core/src/main/scala/cats/data/Kleisli.scala | 3 +++ 1 file changed, 3 insertions(+) diff --git a/core/src/main/scala/cats/data/Kleisli.scala b/core/src/main/scala/cats/data/Kleisli.scala index 6f06bb1e17..6d3778911e 100644 --- a/core/src/main/scala/cats/data/Kleisli.scala +++ b/core/src/main/scala/cats/data/Kleisli.scala @@ -67,6 +67,9 @@ object Kleisli extends KleisliInstances with KleisliFunctions private[data] sealed trait KleisliFunctions { + def pureF[F[_], A, B](x: F[B])(implicit F: Applicative[F]): Kleisli[F, A, B] = + Kleisli(_ => x) + def pure[F[_], A, B](x: B)(implicit F: Applicative[F]): Kleisli[F, A, B] = Kleisli(_ => F.pure(x)) From 6f9deb68e25c14354d96a355c02a19c62d467e8f Mon Sep 17 00:00:00 2001 From: tbrown1979 Date: Sat, 4 Jun 2016 16:42:02 -0500 Subject: [PATCH 2/4] Don't actually need the applicative --- core/src/main/scala/cats/data/Kleisli.scala | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/src/main/scala/cats/data/Kleisli.scala b/core/src/main/scala/cats/data/Kleisli.scala index 6d3778911e..cce790fb06 100644 --- a/core/src/main/scala/cats/data/Kleisli.scala +++ b/core/src/main/scala/cats/data/Kleisli.scala @@ -67,7 +67,7 @@ object Kleisli extends KleisliInstances with KleisliFunctions private[data] sealed trait KleisliFunctions { - def pureF[F[_], A, B](x: F[B])(implicit F: Applicative[F]): Kleisli[F, A, B] = + def pureF[F[_], A, B](x: F[B]): Kleisli[F, A, B] = Kleisli(_ => x) def pure[F[_], A, B](x: B)(implicit F: Applicative[F]): Kleisli[F, A, B] = From 026cdeae39e9ff29186670027a1bb8892ff871da Mon Sep 17 00:00:00 2001 From: tbrown1979 Date: Sun, 5 Jun 2016 14:00:17 -0500 Subject: [PATCH 3/4] Changing .pureF to .const and having the liftT on TransLift use .const --- core/src/main/scala/cats/data/Kleisli.scala | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/core/src/main/scala/cats/data/Kleisli.scala b/core/src/main/scala/cats/data/Kleisli.scala index cce790fb06..8cf5953c67 100644 --- a/core/src/main/scala/cats/data/Kleisli.scala +++ b/core/src/main/scala/cats/data/Kleisli.scala @@ -67,7 +67,7 @@ object Kleisli extends KleisliInstances with KleisliFunctions private[data] sealed trait KleisliFunctions { - def pureF[F[_], A, B](x: F[B]): Kleisli[F, A, B] = + def const[F[_], A, B](x: F[B]): Kleisli[F, A, B] = Kleisli(_ => x) def pure[F[_], A, B](x: B)(implicit F: Applicative[F]): Kleisli[F, A, B] = @@ -124,7 +124,7 @@ private[data] sealed abstract class KleisliInstances extends KleisliInstances0 { new TransLift[Kleisli[?[_], A, ?]] { type TC[M[_]] = Trivial - def liftT[M[_], B](ma: M[B])(implicit ev: Trivial): Kleisli[M, A, B] = Kleisli[M, A, B](a => ma) + def liftT[M[_], B](ma: M[B])(implicit ev: Trivial): Kleisli[M, A, B] = Kleisli.const(ma) } implicit def catsDataApplicativeErrorForKleisli[F[_], A, E](implicit AE: ApplicativeError[F, E]): ApplicativeError[Kleisli[F, A, ?], E] From 08675c1151cf0292a6b0e0471b8ac4b181e0083b Mon Sep 17 00:00:00 2001 From: tbrown1979 Date: Tue, 7 Jun 2016 09:57:26 -0500 Subject: [PATCH 4/4] Renaming to Kleisli.lift, from Kleisli.const --- core/src/main/scala/cats/data/Kleisli.scala | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/core/src/main/scala/cats/data/Kleisli.scala b/core/src/main/scala/cats/data/Kleisli.scala index 8cf5953c67..a66ba2f8f8 100644 --- a/core/src/main/scala/cats/data/Kleisli.scala +++ b/core/src/main/scala/cats/data/Kleisli.scala @@ -67,7 +67,7 @@ object Kleisli extends KleisliInstances with KleisliFunctions private[data] sealed trait KleisliFunctions { - def const[F[_], A, B](x: F[B]): Kleisli[F, A, B] = + def lift[F[_], A, B](x: F[B]): Kleisli[F, A, B] = Kleisli(_ => x) def pure[F[_], A, B](x: B)(implicit F: Applicative[F]): Kleisli[F, A, B] = @@ -124,7 +124,7 @@ private[data] sealed abstract class KleisliInstances extends KleisliInstances0 { new TransLift[Kleisli[?[_], A, ?]] { type TC[M[_]] = Trivial - def liftT[M[_], B](ma: M[B])(implicit ev: Trivial): Kleisli[M, A, B] = Kleisli.const(ma) + def liftT[M[_], B](ma: M[B])(implicit ev: Trivial): Kleisli[M, A, B] = Kleisli.lift(ma) } implicit def catsDataApplicativeErrorForKleisli[F[_], A, E](implicit AE: ApplicativeError[F, E]): ApplicativeError[Kleisli[F, A, ?], E]