Skip to content

Commit

Permalink
Scalafmt
Browse files Browse the repository at this point in the history
  • Loading branch information
mpilquist committed Oct 11, 2023
1 parent 6e17e4e commit 61e6077
Show file tree
Hide file tree
Showing 19 changed files with 39 additions and 37 deletions.
10 changes: 10 additions & 0 deletions .scalafmt.conf
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
version = "3.7.14"

style = default

runner.dialect = scala3

docstrings.wrap = "no"

maxColumn = 100

3 changes: 1 addition & 2 deletions core/shared/src/main/scala/leopards/ApplicativeError.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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]
extension [A](fa: F[A]) def handleError(f: Throwable => A): F[A]
4 changes: 2 additions & 2 deletions core/shared/src/main/scala/leopards/Apply.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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)
Expand All @@ -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]]]

Expand Down
6 changes: 2 additions & 4 deletions core/shared/src/main/scala/leopards/FlatMap.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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)
2 changes: 1 addition & 1 deletion core/shared/src/main/scala/leopards/Foldable.scala
Original file line number Diff line number Diff line change
Expand Up @@ -27,4 +27,4 @@ object Foldable:
export leopards.stdListInstances
export leopards.stdOptionInstances
export leopards.stdTryInstances
export leopards.stdFunction1Instances
export leopards.stdFunction1Instances
2 changes: 1 addition & 1 deletion core/shared/src/main/scala/leopards/Functor.scala
Original file line number Diff line number Diff line change
Expand Up @@ -28,4 +28,4 @@ object Functor:
export leopards.stdListInstances
export leopards.stdOptionInstances
export leopards.stdTryInstances
export leopards.stdFunction1Instances
export leopards.stdFunction1Instances
5 changes: 2 additions & 3 deletions core/shared/src/main/scala/leopards/Kleisli.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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))
3 changes: 1 addition & 2 deletions core/shared/src/main/scala/leopards/Monad.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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
2 changes: 1 addition & 1 deletion core/shared/src/main/scala/leopards/Monoid.scala
Original file line number Diff line number Diff line change
Expand Up @@ -17,4 +17,4 @@
package leopards

trait Monoid[A] extends Semigroup[A]:
def empty: A
def empty: A
5 changes: 2 additions & 3 deletions core/shared/src/main/scala/leopards/OptionT.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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])
Expand All @@ -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]]:
Expand Down
4 changes: 2 additions & 2 deletions core/shared/src/main/scala/leopards/Semigroup.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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
def |+|(y: Int) = x + y
3 changes: 1 addition & 2 deletions core/shared/src/main/scala/leopards/Semigroupal.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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)]
3 changes: 1 addition & 2 deletions core/shared/src/main/scala/leopards/Traverse.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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)
Original file line number Diff line number Diff line change
Expand Up @@ -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)
x => f(fa(x))(x)
2 changes: 1 addition & 1 deletion core/shared/src/main/scala/leopards/instances/list.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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)(_ :: _))
Expand Down
4 changes: 2 additions & 2 deletions core/shared/src/main/scala/leopards/instances/option.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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))
def foldRight[B](b: B)(f: (A, B) => B): B = fa.fold(b)(a => f(a, b))
8 changes: 4 additions & 4 deletions core/shared/src/main/scala/leopards/instances/try.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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))
ff.flatMap(f => fa.map(f))
2 changes: 1 addition & 1 deletion core/shared/src/main/scala/leopards/syntax.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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)
def raiseError[F[_], B](using F: ApplicativeError[F, A]): F[B] = F.raiseError[B](a)
6 changes: 3 additions & 3 deletions core/shared/src/test/scala/leopards/SyntaxTest.scala
Original file line number Diff line number Diff line change
Expand Up @@ -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"))
Expand Down

0 comments on commit 61e6077

Please sign in to comment.