Open geirolz opened 9 months ago
Mouse is a 10 year old, stable library. Renaming would likely be disruptive and IMO not welcomed by many/most users. The potential benefits seem intangible and may not come to be, but the costs of a rename are definite.
A while ago there was a similar request to merge the mouse into the main cats' repository including potential renaming. From my feelings, nothing has changed since then. I'd stand for having it separate as it has been for ten years as pointed out by Ben. I struggle to say that any rebranding would make mouse
famous.
In another direction: there's probably a subset of Mouse's syntax that's proven to be particularly commonly useful. And other methods that don't see as much use.
If we could somehow quantify what the most useful parts of Mouse's API were, I'd be supportive of migrating those into the syntax modules of Cats, so that more people can benefit from them without an extra library. It would be dependent upon the Cats maintainers agreeing of course.
@geirolz would that achieve some of what you're seeking?
Perhaps, we could consider consolidating some syntax like OptionOps
and TryOps
in one place – either "cats" or "mouse".
Personally, I often feel a bit annoyed when I need import those syntaxes from both places.
One of those syntaxes I use the most is the cata
function. For types Option
and Try
it is implemented in "mouse" but "cats" has its own cata
/cataF
for OptionT
for example.
On the other hand, due to the struggle we can face fighting binary/source compatibilities that idea may not be worth it...
Yep, compatibility tax (as well as having a lot of deprecated API) makes it itty-bitty beneficial from my point of view. This might be worth the hassle only in Cats 3.0. But it's barely possible we will see it in the next N years.
I see your points, I don't think renaming it self can make mouse famous but I think that making it easier to use improve the adoption. In any case I feel your doubts about this, totally understandable.
@benhutchison that is a good idea, I believe that everything related to F[Either[L, R]]
, F[Option[A]]
, F[Boolean]
, Either
, Try
, Option
should be taken in account to be moved. Those helps transformation avoiding EitherT
and OptionT
that sometimes are used just for convenient syntax. I don't see those syntaxes as polished but as a basic operators to manipulate the shape.
I admit that it's a bit annoying that cats doesn't have method to simply combine and lift data.
Inconsistency with Mouse:
Nested
-> mouse has convenient syntax to avoid lifting to and from Nested
, all the *In
methods EitherT
and OptionT
-> mouse has the syntax to lift Any
, F[Any]
into monad transformerAny.asRight
/ Any.asLeft
-> mouse has Any.asRightF
/ Any.asLeftF
*Any.some
-> mouse has Any.someF
*F[Boolean].ifM
-> mouse has andM
/ orM
Try.toEither
is defined in both Scala and Mouse List.toNel
-> mouse has List.tailOption
and List.tailOrEmpty
Set.toNes
-> mouse has Set.tailOption
and Set.tailOrEmpty
Inconsistency with Scala:
Try.toOption
-> mouse has Option.toTry
I'll try to enrich the list as soon as possible.
*
inconsistent between Either and Option, but this is another topic
I often talk to colleagues who use cats-core, cats-effect, etc... but know nothing about mouse. This is sad because I love mouse and all its features ( which prevents the usage of
EitherT
andOptionT
for instance) , but I see the reasons why this can't be merged within cats-core.However, I wonder if there is a way to improve the visibility of this project. With the arrival of Scala 3 we can take the opportunity to rename/fork this library to a better and clearer name which includes
cats-
as prefix to let it be more part of an ecosystem. I see cats-core as the base, mouse as an advanced syntax of cats and cats-effect as the effects system. At the moment,mouse
seems an independent library and not a cats ecosystem add-on to me.I don't want to blame the current name, I just wonder if a rebranding would improve the visibility of this library which, in my humble opinion, should be part of every cats-based project. Too many times I have seen boilerplate and operators that are already part of mouse rewritten within
Utils
classes.Going deeper, the problem I see with the
mouse
name is that it doesn't really describe the purpose of the library, which aim to just enrich cats with a nice and useful syntax without adding new type classes or features.Some ideas:
cats-pragmatics
(polished, but I'm not sure if it is correct)cats-mouse
( more conservative )cats-suit
/cats-dress
( fancy and funny but I don't know how explanatory it is )cats-enrichments
/cats-rich-syntax
( more serious but clear )Something like this, for instance:
Once done with the name, I'd also rethink the packages because it would be nice to try to keep the same pattern as
cats-core
in order to simplify the life of the users. Since mouse adds syntax to cats core, maybe it is correct to put it undercats.syntax
package, where mouse is a specialization of the basic cats syntax. This creates a kind of boundary.Moreover, this is also useful to better organize imports with Scalafmt
Example
We could also consider to no having a global import but split them by type as suggested in #362 which I like TBH
To rename or not, what name and how to do it is up to you, but I just wanted to sow a seed for a discussion. Maybe I am the only one who sees this problem.
Let me know what you think :)