-
Notifications
You must be signed in to change notification settings - Fork 66
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Proposal: Renaming this library #482
Comments
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 |
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 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. |
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 Inconsistency with Mouse:
Inconsistency with Scala:
I'll try to enrich the list as soon as possible.
|
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 under
cats.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 :)
The text was updated successfully, but these errors were encountered: