diff --git a/docs/src/main/tut/typeclasses/typeclasses.md b/docs/src/main/tut/typeclasses/typeclasses.md index 1435422656..ab75a14b46 100644 --- a/docs/src/main/tut/typeclasses/typeclasses.md +++ b/docs/src/main/tut/typeclasses/typeclasses.md @@ -221,9 +221,7 @@ val result = Monoid[Int].combine(sumLeft, sumRight) Cats provides laws for type classes via the `kernel-laws` and `laws` modules which makes law checking type class instances easy. -## Further reading -* [Returning the "Current" Type in Scala][fbounds] - +## Typeclass Hierarchy ![Typeclass hierarchy](http://g.gravizo.com/g? digraph G { size ="6,6"; @@ -243,10 +241,14 @@ type class instances easy. CoflatMap [group=g5] Comonad [group=g5] Bimonad [group=g5] + MonadError [group=g6] + ApplicativeError [group=g6] Functor -> Apply -> Applicative -> Monad -> MonadFilter -> MonadCombine Applicative -> Alternative -> MonadCombine MonoidK -> Alternative Functor -> CoflatMap + Applicative -> ApplicativeError -> MonadError + Monad -> MonadError subgraph cluster_s3{ Invariant -> Contravariant graph[style=dotted,label="functor"] @@ -268,5 +270,10 @@ type class instances easy. } ) +## Further reading +* [Returning the "Current" Type in Scala][fbounds] + + + [fbounds]: http://tpolecat.github.io/2015/04/29/f-bounds.html "Returning the "Current" Type in Scala" [simulacrum]: https://github.com/mpilquist/simulacrum "First class syntax support for type classes in Scala"