streamly-core: Streaming, parsers, arrays, serialization and more
This is a package candidate release! Here you can preview how this package release will appear once published to the main package index (which can be accomplished via the 'maintain' link below). Please note that once a package has been published to the main package index it cannot be undone! Please consult the package uploading documentation for more information.
Warnings:
- [option-o2] 'ghc-options: -O2' is rarely needed. Check that it is giving a real benefit and not just imposing longer compile times on your users.
For upgrading to streamly-0.9.0+ please read the Streamly-0.9.0 upgrade guide.
Streamly is a high-performance, beginner-friendly standard library for Haskell. It unifies streaming with list transformers and logic programming; unifies streaming with concurrency and reactive programming; unifies arrays with ring arrays, text, bytestring and vector use cases; unifies arrays with builders and binary serialization; generalizes parsers to any input type and unifies attoparsec, parsec use cases with better performance; provides streaming fileIO — all with a clean, consistent, well-integrated and streaming enabled API.
Streams are designed to have a list like interface — no steep learning curve, no complex types. Streamly is designed to build general purpose applications in a truly functional manner, from simple hello-world to advanced high-performance systems. The design emphasizes simplicity, modularity, and code reuse with minimal building blocks. Performance is on par with C, tuning is easy, and it’s hard to get it wrong.
Streamly is serial by default, with seamless declarative concurrency that scales automatically when needed. It provides prompt and safe resource management, works well with other streaming libraries as well as core libraries like bytestring and text, and is backed by solid documentation.
streamly-core is a Haskell standard library built on top of base
and GHC boot libraries only. Stream processing abstractions include
streams, scans, folds, parsers; and console IO, file IO; text
processing.  Array abstractions include pinned, unpinned, mutable,
immutable, boxed and unboxed arrays, and ring arrays.  Builders,
binary serialization, and deserialization are built-in features of
arrays.
This package provides a high-performance, unified and ergonomic
alternative to many disparate packages, such as streaming, pipes,
conduit, list-t, logict, foldl, attoparsec, array, primitive,
vector, vector-algorithms, binary, cereal, store, bytestring, text,
stringsearch, interpolate, filepath, and path.
Performant. Unified. Modular. Powerful. Simple.
Learn more at the streamly website.
Properties
| Versions | 0.1.0, 0.2.0, 0.2.1, 0.2.2, 0.2.3, 0.3.0, 0.3.0 | 
|---|---|
| Change log | Changelog.md | 
| Dependencies | base (>=4.12 && <4.22), containers (>=0.6.0 && <0.8), exceptions (>=0.8.0 && <0.11), filepath (>=1.4.2 && <1.6), fusion-plugin-types (>=0.1 && <0.2), ghc-bignum (>=1.0 && <2), ghc-prim (>=0.5.3 && <0.14), heaps (>=0.3 && <0.5), integer-gmp (>=1.0 && <1.2), monad-control (>=1.0 && <1.1), template-haskell (>=2.14 && <2.24), transformers (>=0.5.5 && <0.7), Win32 (>=2.6 && <2.14) [details] | 
| License | BSD-3-Clause | 
| Copyright | 2017 Composewell Technologies | 
| Author | Composewell Technologies | 
| Maintainer | streamly@composewell.com | 
| Category | Streamly, Streaming, Dataflow, Pipes, List, Logic, Non-determinism, Parsing, Array, Time | 
| Home page | https://streamly.composewell.com | 
| Bug tracker | https://github.com/composewell/streamly/issues | 
| Source repo | head: git clone https://github.com/composewell/streamly | 
| Uploaded | by adithyaov at 2025-09-03T09:17:12Z | 
Modules
[Index] [Quick Jump]
- Streamly- Console
- Control
- Data
- FileSystem
- Internal- Streamly.Internal.BaseCompat
- Console
- Control
- Data- Streamly.Internal.Data.Array
- Binary
- Streamly.Internal.Data.Builder
- Streamly.Internal.Data.CString
- Either
- Streamly.Internal.Data.Fold
- Streamly.Internal.Data.IOFinalizer
- Streamly.Internal.Data.IORef
- Streamly.Internal.Data.IsMap
- Maybe
- Streamly.Internal.Data.MutArray
- Streamly.Internal.Data.MutByteArray
- Streamly.Internal.Data.Parser
- Streamly.Internal.Data.ParserK
- Streamly.Internal.Data.Path
- Streamly.Internal.Data.Pipe
- Streamly.Internal.Data.Producer
- Refold
- Streamly.Internal.Data.RingArray
- SVar
- Streamly.Internal.Data.Scanl
- Streamly.Internal.Data.Scanr
- Streamly.Internal.Data.Stream
- Streamly.Internal.Data.StreamK- Streamly.Internal.Data.StreamK.Alt
 
- Time
- Tuple
- Streamly.Internal.Data.Unfold
 
- FileSystem
- System
- Unicode
 
- Unicode
 
Flags
Manual Flags
| Name | Description | Default | 
|---|---|---|
| debug | Debug build with asserts enabled | Disabled | 
| internal-dev | DO NOT USE, ONLY FOR INTERNAL USE. | Disabled | 
| has-llvm | Use llvm backend for code generation | Disabled | 
| opt | off=GHC default, on=-O2 | Enabled | 
| limit-build-mem | Limits memory when building | Disabled | 
| internal-use-unliftio | DO NOT USE, ONLY FOR INTERNAL USE. | Disabled | 
| use-unfolds | Use unfolds for generation everywhere | Disabled | 
| use-folds | Use folds for elimination everywhere | Disabled | 
| force-lstat-readdir | Use lstat instead of checking for dtype in ReadDir | Disabled | 
Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info
Downloads
- streamly-core-0.3.0.tar.gz [browse] (Cabal source package)
- Package description (as included in the package)
Maintainer's Corner
Package maintainers
For package maintainers and hackage trustees