The async package
This package provides a higher-level interface over threads, in which an Async a is a concurrent thread that will eventually deliver a value of type a. The package provides ways to create Async computations, wait for their results, and cancel them.
Using Async is safer than using threads in two ways:
When waiting for a thread to return a result, if the thread dies with an exception then the caller must either re-throw the exception (wait) or handle it (waitCatch); the exception cannot be ignored.
The API makes it possible to build a tree of threads that are automatically killed when their parent dies (see withAsync).
|Versions||1.0, 1.1, 1.2, 1.3, 1.4, 126.96.36.199, 188.8.131.52, 184.108.40.206, 220.127.116.11, 18.104.22.168, 22.214.171.124, 126.96.36.199, 188.8.131.52, 2.0.2, 2.1.0|
|Dependencies||base (>=4.3 && <4.10), stm (>=2.2 && <2.5) [details]|
|Copyright||(c) Simon Marlow 2012|
|Maintainer||Simon Marlow <firstname.lastname@example.org>|
|Source repository||head: git clone https://github.com/simonmar/async.git|
|Uploaded||Tue Jan 5 16:44:15 UTC 2016 by SimonMarlow|
|Distributions||Arch:2.1.0, Debian:2.0.2, Fedora:184.108.40.206, FreeBSD:2.0.2, LTSHaskell:2.1.0, NixOS:2.1.0, Stackage:2.1.0|
|Downloads||90210 total (53 in the last 30 days)|
|Status||Docs available [build log]
Last success reported on 2016-03-16 [all 1 reports]
For package maintainers and hackage trustees