concurrent-split: MVars and Channels with distinguished input and output side
MVars and Channels with distinguished input and output side. When threads communicate via an MVar or a Chan there are often clearly defined roles, which thread is the sender and which one is receiver. We provide wrappers around the standard concurrency communication channels that make the distinction clear and type safe.
For example, if a function has a parameter of type
then it is sure that it will only write to that channel.
Additionally if the compiler warns about an unused
that was created by
then you know that the receiver part of your communication is missing.
This package requires only Haskell 98.
stm-split: transactional communication in
chan-split: follows the same idea as this package and
stm-splitbut requires multi-parameter type classes with functional dependencies.
|Versions [faq]||0.0, 0.0.0.1, 0.0.0.2, 0.0.1, 0.0.1.1|
|Dependencies||base (==4.*) [details]|
|Author||Henning Thielemann <email@example.com>|
|Maintainer||Henning Thielemann <firstname.lastname@example.org>|
|Source repo||this: darcs get http://hub.darcs.net/thielema/concurrent-split/ --tag 0.0.1
head: darcs get http://hub.darcs.net/thielema/concurrent-split/
|Uploaded||by HenningThielemann at Fri Nov 4 09:01:04 UTC 2016|
|Distributions||LTSHaskell:0.0.1.1, NixOS:0.0.1.1, Stackage:0.0.1.1|
|Downloads||1780 total (101 in the last 30 days)|
|Rating||(no votes yet) [estimated by rule of succession]|
Docs uploaded by user
Build status unknown [no reports yet]
For package maintainers and hackage trustees