Run IO actions lazily while respecting their order

Version on this page:
LTS Haskell 13.22:
Stackage Nightly 2019-05-21:
Latest on Hackage:

See all snapshots lazyio appears in

BSD-3-Clause licensed and maintained by Henning Thielemann

Module documentation for

Run IO actions lazily while respecting their order. Running a value of the LazyIO monad in the IO monad is like starting a thread which is however driven by its output. That is, the LazyIO action is only executed as far as necessary in order to provide the required data.

The package may help you to avoid stack overflows in mapM. Say you have

mapM f xs

where xs is a long list. When run, you may encounter a stack overflow. To prevent it, write instead:

import qualified System.IO.Lazy as LazyIO $ mapM (LazyIO.interleave . f) xs

The stack overflow is gone.



* System.IO.Lazy.T: remove MonadIO instance

liftIO did not satisfy MonadIO laws.
You must use the new function LazyIO.interleave instead.
A positive side-effect is that you do not need
to depend explicitly on 'transformers' anymore.
Depends on 3 packages:
Used by 2 packages:
comments powered byDisqus