From 61e60777e614b28523b54b1b2a611e93c768c58a Mon Sep 17 00:00:00 2001 From: mpilquist Date: Tue, 10 Oct 2023 20:28:44 -0400 Subject: [PATCH] Scalafmt --- .scalafmt.conf | 10 ++++++++++ .../src/main/scala/leopards/ApplicativeError.scala | 3 +-- core/shared/src/main/scala/leopards/Apply.scala | 4 ++-- core/shared/src/main/scala/leopards/FlatMap.scala | 6 ++---- core/shared/src/main/scala/leopards/Foldable.scala | 2 +- core/shared/src/main/scala/leopards/Functor.scala | 2 +- core/shared/src/main/scala/leopards/Kleisli.scala | 5 ++--- core/shared/src/main/scala/leopards/Monad.scala | 3 +-- core/shared/src/main/scala/leopards/Monoid.scala | 2 +- core/shared/src/main/scala/leopards/OptionT.scala | 5 ++--- core/shared/src/main/scala/leopards/Semigroup.scala | 4 ++-- core/shared/src/main/scala/leopards/Semigroupal.scala | 3 +-- core/shared/src/main/scala/leopards/Traverse.scala | 3 +-- .../src/main/scala/leopards/instances/function1.scala | 2 +- .../src/main/scala/leopards/instances/list.scala | 2 +- .../src/main/scala/leopards/instances/option.scala | 4 ++-- .../shared/src/main/scala/leopards/instances/try.scala | 8 ++++---- core/shared/src/main/scala/leopards/syntax.scala | 2 +- core/shared/src/test/scala/leopards/SyntaxTest.scala | 6 +++--- 19 files changed, 39 insertions(+), 37 deletions(-) create mode 100644 .scalafmt.conf diff --git a/.scalafmt.conf b/.scalafmt.conf new file mode 100644 index 0000000..b60a992 --- /dev/null +++ b/.scalafmt.conf @@ -0,0 +1,10 @@ +version = "3.7.14" + +style = default + +runner.dialect = scala3 + +docstrings.wrap = "no" + +maxColumn = 100 + diff --git a/core/shared/src/main/scala/leopards/ApplicativeError.scala b/core/shared/src/main/scala/leopards/ApplicativeError.scala index ff5b4da..ff5672b 100644 --- a/core/shared/src/main/scala/leopards/ApplicativeError.scala +++ b/core/shared/src/main/scala/leopards/ApplicativeError.scala @@ -18,5 +18,4 @@ package leopards trait ApplicativeError[F[_], E] extends Applicative[F]: def raiseError[A](e: E): F[A] - extension [A](fa: F[A]) - def handleError(f: Throwable => A): F[A] \ No newline at end of file + extension [A](fa: F[A]) def handleError(f: Throwable => A): F[A] diff --git a/core/shared/src/main/scala/leopards/Apply.scala b/core/shared/src/main/scala/leopards/Apply.scala index a2e94f2..10b3577 100644 --- a/core/shared/src/main/scala/leopards/Apply.scala +++ b/core/shared/src/main/scala/leopards/Apply.scala @@ -21,7 +21,7 @@ import scala.annotation.alpha trait Apply[F[_]] extends Functor[F], Semigroupal[F]: extension [A, B](ff: F[A => B]) @alpha("ap") - def <*> (fa: F[A]): F[B] + def <*>(fa: F[A]): F[B] // note: we should be able to take `Tuple.IsMappedBy[F]` constraint here but https://github.com/lampepfl/dotty/issues/14165 extension [T <: NonEmptyTuple](t: T) @@ -30,7 +30,7 @@ trait Apply[F[_]] extends Functor[F], Semigroupal[F]: def tupled(using Tuple.IsMappedBy[F][T]): F[Tuple.InverseMap[T, F]] = def loop[X <: NonEmptyTuple](x: X): F[NonEmptyTuple] = x match - case hd *: EmptyTuple => hd.asInstanceOf[F[Any]].map(_ *: EmptyTuple) + case hd *: EmptyTuple => hd.asInstanceOf[F[Any]].map(_ *: EmptyTuple) case hd *: (tl: NonEmptyTuple) => hd.asInstanceOf[F[Any]].map2(loop(tl))(_ *: _) loop(t).asInstanceOf[F[Tuple.InverseMap[T, F]]] diff --git a/core/shared/src/main/scala/leopards/FlatMap.scala b/core/shared/src/main/scala/leopards/FlatMap.scala index 7b7104a..376fe55 100644 --- a/core/shared/src/main/scala/leopards/FlatMap.scala +++ b/core/shared/src/main/scala/leopards/FlatMap.scala @@ -17,12 +17,10 @@ package leopards trait FlatMap[F[_]] extends Apply[F]: - extension [A](fa: F[A]) - def flatMap[B](f: A => F[B]): F[B] + extension [A](fa: F[A]) def flatMap[B](f: A => F[B]): F[B] extension [A, B](ff: F[A => B]) override def <*>(fa: F[A]): F[B] = ff.flatMap(f => fa.map(f)) - extension [A](ffa: F[F[A]]) - def flatten: F[A] = ffa.flatMap(identity) + extension [A](ffa: F[F[A]]) def flatten: F[A] = ffa.flatMap(identity) diff --git a/core/shared/src/main/scala/leopards/Foldable.scala b/core/shared/src/main/scala/leopards/Foldable.scala index a4e5afb..29741ea 100644 --- a/core/shared/src/main/scala/leopards/Foldable.scala +++ b/core/shared/src/main/scala/leopards/Foldable.scala @@ -27,4 +27,4 @@ object Foldable: export leopards.stdListInstances export leopards.stdOptionInstances export leopards.stdTryInstances - export leopards.stdFunction1Instances \ No newline at end of file + export leopards.stdFunction1Instances diff --git a/core/shared/src/main/scala/leopards/Functor.scala b/core/shared/src/main/scala/leopards/Functor.scala index 82f364a..b51ddf7 100644 --- a/core/shared/src/main/scala/leopards/Functor.scala +++ b/core/shared/src/main/scala/leopards/Functor.scala @@ -28,4 +28,4 @@ object Functor: export leopards.stdListInstances export leopards.stdOptionInstances export leopards.stdTryInstances - export leopards.stdFunction1Instances \ No newline at end of file + export leopards.stdFunction1Instances diff --git a/core/shared/src/main/scala/leopards/Kleisli.scala b/core/shared/src/main/scala/leopards/Kleisli.scala index 9c0264b..403531b 100644 --- a/core/shared/src/main/scala/leopards/Kleisli.scala +++ b/core/shared/src/main/scala/leopards/Kleisli.scala @@ -18,14 +18,13 @@ package leopards opaque type Kleisli[F[_], A, B] = A => F[B] -extension [F[_], A, B](k: Kleisli[F, A, B]) - def apply(a: A): F[B] = k(a) +extension [F[_], A, B](k: Kleisli[F, A, B]) def apply(a: A): F[B] = k(a) object Kleisli: def apply[F[_], A, B](f: A => F[B]): Kleisli[F, A, B] = f given [F[_], A](using F: Monad[F]): Monad[[B] =>> Kleisli[F, A, B]] with def pure[B](b: B) = Kleisli(_ => F.pure(b)) - extension[B](k: Kleisli[F, A, B]) + extension [B](k: Kleisli[F, A, B]) def flatMap[C](f: B => Kleisli[F, A, C]) = a => k(a).flatMap(b => f(b)(a)) diff --git a/core/shared/src/main/scala/leopards/Monad.scala b/core/shared/src/main/scala/leopards/Monad.scala index 1beab53..f0270cf 100644 --- a/core/shared/src/main/scala/leopards/Monad.scala +++ b/core/shared/src/main/scala/leopards/Monad.scala @@ -17,8 +17,7 @@ package leopards trait Monad[F[_]] extends FlatMap[F], Applicative[F]: - extension [A](fa: F[A]) - override def map[B](f: A => B): F[B] = fa.flatMap(f andThen pure) + extension [A](fa: F[A]) override def map[B](f: A => B): F[B] = fa.flatMap(f andThen pure) object Monad: def apply[F[_]](using m: Monad[F]) = m diff --git a/core/shared/src/main/scala/leopards/Monoid.scala b/core/shared/src/main/scala/leopards/Monoid.scala index 5c122b5..1675c05 100644 --- a/core/shared/src/main/scala/leopards/Monoid.scala +++ b/core/shared/src/main/scala/leopards/Monoid.scala @@ -17,4 +17,4 @@ package leopards trait Monoid[A] extends Semigroup[A]: - def empty: A \ No newline at end of file + def empty: A diff --git a/core/shared/src/main/scala/leopards/OptionT.scala b/core/shared/src/main/scala/leopards/OptionT.scala index b3f6261..66ff849 100644 --- a/core/shared/src/main/scala/leopards/OptionT.scala +++ b/core/shared/src/main/scala/leopards/OptionT.scala @@ -27,7 +27,7 @@ object OptionT: def liftF[F[_], A](fa: F[A])(using Functor[F]): OptionT[F, A] = apply(fa.map(Some(_))) - def liftK[F[_]](using Functor[F]): F ~> ([X] =>> OptionT[F, X]) = + def liftK[F[_]](using Functor[F]): F ~> ([X] =>> OptionT[F, X]) = [X] => liftF(_: F[X]) extension [F[_], A](fa: OptionT[F, A]) @@ -38,8 +38,7 @@ object OptionT: new OptionTFunctor[F] {} private trait OptionTFunctor[F[_]](using F: Functor[F]) extends Functor[[X] =>> OptionT[F, X]]: - extension [A](ota: OptionT[F, A]) - def map[B](f: A => B) = F.map(ota)(_.map(f)) + extension [A](ota: OptionT[F, A]) def map[B](f: A => B) = F.map(ota)(_.map(f)) given [F[_]](using F: Monad[F]): Monad[[X] =>> OptionT[F, X]] = new OptionTFunctor[F] with Monad[[X] =>> OptionT[F, X]]: diff --git a/core/shared/src/main/scala/leopards/Semigroup.scala b/core/shared/src/main/scala/leopards/Semigroup.scala index a3c0793..557a57b 100644 --- a/core/shared/src/main/scala/leopards/Semigroup.scala +++ b/core/shared/src/main/scala/leopards/Semigroup.scala @@ -21,10 +21,10 @@ import scala.annotation.alpha trait Semigroup[A]: extension (x: A) @alpha("combine") - def |+| (y: A): A + def |+|(y: A): A object Semigroup: given Semigroup[Int] with extension (x: Int) @alpha("combine") - def |+| (y: Int) = x + y \ No newline at end of file + def |+|(y: Int) = x + y diff --git a/core/shared/src/main/scala/leopards/Semigroupal.scala b/core/shared/src/main/scala/leopards/Semigroupal.scala index 967c877..02ed2b4 100644 --- a/core/shared/src/main/scala/leopards/Semigroupal.scala +++ b/core/shared/src/main/scala/leopards/Semigroupal.scala @@ -17,5 +17,4 @@ package leopards trait Semigroupal[F[_]]: - extension [A] (fa: F[A]) - def product[B](fb: F[B]): F[(A, B)] + extension [A](fa: F[A]) def product[B](fb: F[B]): F[(A, B)] diff --git a/core/shared/src/main/scala/leopards/Traverse.scala b/core/shared/src/main/scala/leopards/Traverse.scala index ca06188..511d734 100644 --- a/core/shared/src/main/scala/leopards/Traverse.scala +++ b/core/shared/src/main/scala/leopards/Traverse.scala @@ -17,7 +17,6 @@ package leopards trait Traverse[F[_]] extends Functor[F], Foldable[F]: - extension [A](fa: F[A]) - def traverse[G[_], B](f: A => G[B])(using G: Applicative[G]): G[F[B]] + extension [A](fa: F[A]) def traverse[G[_], B](f: A => G[B])(using G: Applicative[G]): G[F[B]] extension [G[_], A](fga: F[G[A]]) def sequence(using Applicative[G]): G[F[A]] = fga.traverse(identity) diff --git a/core/shared/src/main/scala/leopards/instances/function1.scala b/core/shared/src/main/scala/leopards/instances/function1.scala index a79fb7d..e375bf9 100644 --- a/core/shared/src/main/scala/leopards/instances/function1.scala +++ b/core/shared/src/main/scala/leopards/instances/function1.scala @@ -20,4 +20,4 @@ given stdFunction1Instances[X]: Monad[[A] =>> X => A] with def pure[A](a: A): X => A = _ => a extension [A](fa: X => A) def flatMap[B](f: A => X => B) = - x => f(fa(x))(x) \ No newline at end of file + x => f(fa(x))(x) diff --git a/core/shared/src/main/scala/leopards/instances/list.scala b/core/shared/src/main/scala/leopards/instances/list.scala index 9799786..ff9acfc 100644 --- a/core/shared/src/main/scala/leopards/instances/list.scala +++ b/core/shared/src/main/scala/leopards/instances/list.scala @@ -18,7 +18,7 @@ package leopards given stdListInstances: Monad[List] with Traverse[List] with def pure[A](a: A) = List(a) - extension[A](fa: List[A]) + extension [A](fa: List[A]) def flatMap[B](f: A => List[B]) = fa.flatMap(f) def traverse[G[_], B](f: A => G[B])(using G: Applicative[G]): G[List[B]] = fa.foldRight(G.pure(Nil: List[B]))((a, acc) => f(a).map2(acc)(_ :: _)) diff --git a/core/shared/src/main/scala/leopards/instances/option.scala b/core/shared/src/main/scala/leopards/instances/option.scala index e449913..70d35bb 100644 --- a/core/shared/src/main/scala/leopards/instances/option.scala +++ b/core/shared/src/main/scala/leopards/instances/option.scala @@ -18,9 +18,9 @@ package leopards given stdOptionInstances: Monad[Option] with Traverse[Option] with def pure[A](a: A) = Some(a) - extension[A](fa: Option[A]) + extension [A](fa: Option[A]) def flatMap[B](f: A => Option[B]) = fa.flatMap(f) def traverse[G[_], B](f: A => G[B])(using G: Applicative[G]): G[Option[B]] = fa.fold(G.pure(None: Option[B]))(a => f(a).map(Some(_))) def foldLeft[B](b: B)(f: (B, A) => B): B = fa.fold(b)(a => f(b, a)) - def foldRight[B](b: B)(f: (A, B) => B): B = fa.fold(b)(a => f(a, b)) \ No newline at end of file + def foldRight[B](b: B)(f: (A, B) => B): B = fa.fold(b)(a => f(a, b)) diff --git a/core/shared/src/main/scala/leopards/instances/try.scala b/core/shared/src/main/scala/leopards/instances/try.scala index cff0758..a1f6faa 100644 --- a/core/shared/src/main/scala/leopards/instances/try.scala +++ b/core/shared/src/main/scala/leopards/instances/try.scala @@ -21,12 +21,12 @@ import scala.util.control.NonFatal given stdTryInstances: ApplicativeError[Try, Throwable] with override def pure[A](a: A): Try[A] = Try(a) - override def raiseError[A](e: Throwable): Try[A] = Failure(e) - + override def raiseError[A](e: Throwable): Try[A] = Failure(e) + extension [A](fa: Try[A]) override def map[B](f: A => B): Try[B] = fa.map(f) override def handleError(f: Throwable => A): Try[A] = fa.recover[A] { case e => f(e) } - + extension [A, B](ff: Try[A => B]) override def <*>(fa: Try[A]): Try[B] = - ff.flatMap(f => fa.map(f)) \ No newline at end of file + ff.flatMap(f => fa.map(f)) diff --git a/core/shared/src/main/scala/leopards/syntax.scala b/core/shared/src/main/scala/leopards/syntax.scala index 7b9fb93..6e5ec01 100644 --- a/core/shared/src/main/scala/leopards/syntax.scala +++ b/core/shared/src/main/scala/leopards/syntax.scala @@ -18,4 +18,4 @@ package leopards extension [A](a: A) def pure[F[_]](using F: Applicative[F]): F[A] = F.pure(a) - def raiseError[F[_], B](using F: ApplicativeError[F, A]): F[B] = F.raiseError[B](a) \ No newline at end of file + def raiseError[F[_], B](using F: ApplicativeError[F, A]): F[B] = F.raiseError[B](a) diff --git a/core/shared/src/test/scala/leopards/SyntaxTest.scala b/core/shared/src/test/scala/leopards/SyntaxTest.scala index 423d0e3..4534c53 100644 --- a/core/shared/src/test/scala/leopards/SyntaxTest.scala +++ b/core/shared/src/test/scala/leopards/SyntaxTest.scala @@ -29,18 +29,18 @@ class SyntaxExample extends FunSuite: test("f poly flatMap") { // for the flatMap and value.pure[F] we need the leopards.given import - def fPolyFlatMap[F[_]: Monad](value: Int): F[Int] = + def fPolyFlatMap[F[_]: Monad](value: Int): F[Int] = for { v <- value.pure[F] } yield v - + assertEquals(fPolyFlatMap[Option](42), Some(42)) } test("applicative error syntax") { import scala.util.Try val thr = new RuntimeException("stuff") - //val tried = thr.raiseError[Try, String] // -- does not compile because thr is inferred as RuntimeException, not Throwable + // val tried = thr.raiseError[Try, String] // -- does not compile because thr is inferred as RuntimeException, not Throwable val tried = (thr: Throwable).raiseError[Try, String] assert(tried.isFailure) assertEquals(tried.handleError(_ => "42"), Try("42"))