concurrent-resource-map: Concurrent resource map

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.

[maintain] [Publish]


Please see the README on GitHub at

[Skip to Readme]


Change log
Dependencies base [details]
License BSD-3-Clause
Copyright 2020 Mateusz Kowalczyk
Author Mateusz Kowalczyk
Category Data
Home page
Bug tracker
Source repo head: git clone
Uploaded by MateuszKowalczyk at 2020-03-18T03:23:23Z




Maintainer's Corner

For package maintainers and hackage trustees

Readme for concurrent-resource-map-

[back to package description]

concurrent-resource-map Build Status

User-counted resource map with automatic resource collection, aimed to be used in concurrent setting.

Consider having some sort of resource that you need properly initialised and cleaned up but only once and only for as long as there are interested users (threads). Further, instead of only a single resource, you want a collection of such resources, keyed on some value.

This package implements a simple bracket-based scheme that manipulates a resource map by counting number of initalisations and clean-ups: if it detects that the cleanup is from the last user, it removes the resource from the map all together. See the code/hackage for documentation.