auto-update: Efficiently run periodic, on-demand actions

[ control, library, mit ] [ Propose Tags ]

API docs and the README are available at

[Skip to Readme]


Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees


  • No Candidates
Versions [RSS],,,,,,, 0.1.2,,, 0.1.3,, 0.1.4,, 0.1.5, 0.1.6, 0.2.0
Change log
Dependencies base (>=4.12 && <5) [details]
License MIT
Author Michael Snoyman
Category Control
Home page
Uploaded by KazuYamamoto at 2024-04-27T10:29:00Z
Distributions Arch:0.1.6, Debian:0.1.6, Fedora:0.1.6, FreeBSD:, LTSHaskell:0.1.6, NixOS:0.1.6, Stackage:0.2.0, openSUSE:0.1.6
Reverse Dependencies 28 direct, 3923 indirect [details]
Downloads 103264 total (388 in the last 30 days)
Rating (no votes yet) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Docs available [build log]
Last success reported on 2024-04-27 [all 1 reports]

Readme for auto-update-0.2.0

[back to package description]


A common problem is the desire to have an action run at a scheduled interval, but only if it is needed. For example, instead of having every web request result in a new getCurrentTime call, we'd like to have a single worker thread run every second, updating an IORef. However, if the request frequency is less than once per second, this is a pessimization, and worse, kills idle GC.

This library allows you to define actions which will either be performed by a dedicated thread or, in times of low volume, will be executed by the calling thread.

For original use case, see yesod-scaffold issue #15.