global-variables: Namespaced, global, and top-level mutable variables without unsafePerformIO.
Data.Global provides a global namespace of
TVars. This namespace may be accessed in pure code. Yet reading
and writing to those
TVars happens still in
their respective monads.
Data.Global is designed to meet the following use cases:
Simplify the declaration of top-level mutable variables, by avoiding any pragmas as well as
Avoid having to pass references explicitly throughout the program in order to let distant parts communicate.
Enable a communication by convention scheme, where e.g. different libraries may communicate without code dependencies.
Simplify the "configuration problem" - at least for code in the IO monad.
Note, that this library does not encourage sloppy software design by re-introducing all bad effects of global variables. Nevertheless, sometimes global variables are a suitable solution to a problem. In that case Data.Global simplifies and extends their handling significantly.
Examples are in the documentation of Data.Global.
0.1.1: made compatible with stm-2.3
0.1.0: added declareEmptyMVar and widened the stm dependency
0: First public release
|Versions [faq]||1.0, 220.127.116.11, 18.104.22.168|
|Dependencies||base (==4.*), containers (>=0.3 && <0.5), stm (>=2.1 && <2.4) [details]|
|Copyright||2011, 2012 Jean-Marie Gaillourdet|
|Author||Jean-Marie Gaillourdet and Patrick Michel|
|Maintainer||Jean-Marie Gaillourdet <email@example.com>|
|Source repo||head: hg clone http://bitbucket.org/jmg/global-variables|
|Uploaded||by JeanMarieGaillourdet at 2012-03-03T09:25:25Z|
|Downloads||2413 total (1 in the last 30 days)|
|Rating||(no votes yet) [estimated by Bayesian average]|
Docs uploaded by user
Build status unknown [no reports yet]
For package maintainers and hackage trustees