stm-split: TMVars, TVars and TChans with distinguished input and output side
Transactional MVars, Vars and Channels with distinguished input and output side. When threads communicate via a TMVar, a TVar or a TChan 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.
See also package
concurrent-split for non-transactional communication.
This package follows the same idea as
chan-split but is strictly Haskell 98.
|Versions [RSS] [faq]||0.0, 0.0.0.1, 0.0.0.2, 0.0.1, 0.0.2, 0.0.2.1|
|Dependencies||base (==4.*), stm (>=2.2 && <2.6) [details]|
|Author||Henning Thielemann <firstname.lastname@example.org>|
|Maintainer||Henning Thielemann <email@example.com>|
|Source repo||this: darcs get http://hub.darcs.net/thielema/stm-split/ --tag 0.0.2.1
head: darcs get http://hub.darcs.net/thielema/stm-split/
|Uploaded||by HenningThielemann at 2018-09-22T18:07:37Z|
|Distributions||LTSHaskell:0.0.2.1, NixOS:0.0.2.1, Stackage:0.0.2.1|
|Downloads||4077 total (19 in the last 30 days)|
|Rating||(no votes yet) [estimated by Bayesian average]|
Docs available [build log]
Last success reported on 2018-09-22 [all 1 reports]