Efficiently run periodic, on-demand actions

Version on this page:
LTS Haskell 14.6:0.1.6
Stackage Nightly 2019-09-19:0.1.6
Latest on Hackage:0.1.6

See all snapshots auto-update appears in

MIT licensed by Michael Snoyman
Maintained by

Module documentation for

This version can be pinned in stack with:auto-update-,1219


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.


ChangeLog for auto-update

  • #693: Improve documentation for reaperAction function.
  • #732: Fixed memory leak in reaperAdd function.


  • Provide updateActionModify API in AutoUpdate #547

  • Doc improvements


  • Adding a new AIP - reaperKill


  • Added Control.Debounce
Depends on 1 package(full list with versions):
Used by 7 packages in nightly-2019-06-12(full list with versions):
comments powered byDisqus