The cluss package
A cluss enables you to achieve function overloading, or ad-hoc polymorphism, without creating a new type class.
In order to give ad-hoc polymorphism to a type variable
you simply use
with a list of "type patterns" like
In [Type T, ...] a,
which indicates that the type matches some of the patterns;
which is analogous to a type class indicating that a type matches some of its "instances".
In [Type T, ...] a is what we call a "cluss".
Clusses can easily be used in a nested way and even be recursive; therefore, they are expressive enough to imitate Haskell-98-style type classes.
Clusses, however, go beyond a mere alternative to type classes. They have closed and prioritized instances and open methods, while type classes have open and unprioritized instances and closed methods. Those properties give clusses the advantages different from type classes:
You can judge whether a type
abelongs to a cluss
, on some level, writing
Has as a, since cluss instances are closed.
You can make cluss instances more flexibly, without causing overlapping instances or incoherent instances, since cluss instances are prioritized.
You can create new methods for clusses anywhere in any module, since cluss methods are open.
|Versions||0.1, 0.2, 0.3|
|Dependencies||base (==4.*), template-haskell (>=2.5) [details]|
|Copyright||(c) Yusuke Matsushita 2014|
|Maintainer||Yusuke Matsushita <firstname.lastname@example.org>|
|Category||type system, constraints|
|Source repository||head: git clone email@example.com:Kinokkory/cluss.git|
|Uploaded||Tue Oct 14 08:06:01 UTC 2014 by Kinokkory|
|Downloads||686 total (20 in the last 30 days)|
|Status||Docs uploaded by user
Build status unknown [no reports yet]
Hackage Matrix CI
For package maintainers and hackage trustees