stm-split

TMVars, TVars and TChans with distinguished input and output side

Version on this page:0.0.2
LTS Haskell 24.16:0.0.2.1
Stackage Nightly 2025-10-25:0.0.2.1
Latest on Hackage:0.0.2.1

See all snapshots stm-split appears in

BSD-3-Clause licensed and maintained by Henning Thielemann
This version can be pinned in stack with:stm-split-0.0.2@sha256:1a6198859868b2ad08a4921d7f3eec8fc1a15d145095a1f74333356dda4da543,1779

Module documentation for 0.0.2

Depends on 2 packages(full list with versions):

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 TChan.In then it is sure that it will only write to that channel. Additionally if the compiler warns about an unused TChan.Out that was created by TChan.new 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.