streamly: Beautiful Streaming, Concurrent and Reactive Composition
Streamly is a monad transformer unifying non-determinism (list-t/logict), concurrency (async), streaming (conduit/pipes), and FRP (Yampa/reflex) functionality in a concise and intuitive API. High level concurrency makes concurrent applications almost indistinguishable from non-concurrent ones. By changing a single combinator you can control whether the code runs serially or concurrently. It naturally integrates concurrency with streaming rather than adding it as an afterthought. Moreover, it interworks with the popular streaming libraries.
See the README for an overview and the haddock documentation for full reference. It is recommended to read the comprehensive tutorial module Streamly.Tutorial first. Also see Streamly.Examples for some working examples.
[Skip to Readme]
Modules
[Index]
- Streamly
- Streamly.Examples
- Streamly.Examples.AcidRainGame
- Streamly.Examples.CirclingSquare
- Streamly.Examples.ListDirRecursive
- Streamly.Examples.MergeSortedStreams
- Streamly.Examples.SearchEngineQuery
- Streamly.Prelude
- Streamly.Time
- Streamly.Tutorial
- Streamly.Examples
Flags
Manual Flags
Name | Description | Default |
---|---|---|
dev | Build development version | Disabled |
extra-benchmarks | Include comparative benchmarks | Disabled |
examples | Build examples | Disabled |
examples-sdl | Include examples that use SDL dependency | Disabled |
Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info
Downloads
- streamly-0.1.1.tar.gz [browse] (Cabal source package)
- Package description (as included in the package)
Maintainer's Corner
For package maintainers and hackage trustees
Candidates
Versions [RSS] | 0.1.0, 0.1.1, 0.1.2, 0.2.0, 0.2.1, 0.3.0, 0.4.0, 0.4.1, 0.5.0, 0.5.1, 0.5.2, 0.6.0, 0.6.1, 0.7.0, 0.7.1, 0.7.2, 0.7.3, 0.7.3.1, 0.7.3.2, 0.8.0, 0.8.1, 0.8.1.1, 0.8.2, 0.8.3, 0.9.0, 0.10.0, 0.10.1 |
---|---|
Change log | Changelog.md |
Dependencies | atomic-primops (>=0.8 && <0.9), base (>=4.8 && <5), containers (>=0.5 && <0.6), exceptions (>=0.8 && <0.11), lifted-base (>=0.2 && <0.3), lockfree-queue (>=0.2.3 && <0.3), monad-control (>=1.0 && <2), mtl (>=2.2 && <3), semigroups (>=0.18 && <0.19), stm (>=2.4.3 && <2.5), transformers (>=0.4 && <0.6), transformers-base (>=0.4 && <0.5) [details] |
Tested with | ghc ==7.10.3, ghc ==8.0.2, ghc ==8.2.2, ghc ==8.4.1 |
License | BSD-3-Clause |
Copyright | 2017 Harendra Kumar |
Author | Harendra Kumar |
Maintainer | harendra.kumar@gmail.com |
Category | Control, Concurrency, Streaming, Reactivity |
Home page | https://github.com/composewell/streamly |
Bug tracker | https://github.com/composewell/streamly/issues |
Source repo | head: git clone https://github.com/composewell/streamly |
Uploaded | by harendra at 2018-03-18T14:56:54Z |
Distributions | LTSHaskell:0.10.1, NixOS:0.10.1, Stackage:0.10.1 |
Reverse Dependencies | 34 direct, 4 indirect [details] |
Executables | parallel-loops, nested-loops, loops |
Downloads | 18334 total (181 in the last 30 days) |
Rating | 2.5 (votes: 6) [estimated by Bayesian average] |
Your Rating | |
Status | Docs available [build log] Last success reported on 2018-03-18 [all 1 reports] |