The safer-file-handles package
This package adds two safety features on top of the regular System.IO file handles and operations:
Regional file handles. Files must be opened in a region. When the region terminates all opened files are automatically closed. The main advantage of regions is that the handles to the opened files can not be returned from the region which ensures no I/O with closed files is possible.
Explicit IOModes. The regional file handles are parameterized by the IOMode in which they were opened. All operations on handles explicitly specify the needed IOMode. This way it is impossible to read from a write-only handle or write to a read-only handle for example.
The primary technique used in this package is called "Lightweight monadic regions" which was invented by Oleg Kiselyov and Chung-chieh Shan. See:
This technique is implemented in the regions package which is re-exported from safer-file-handles.
See the safer-file-handles-examples package for examples how to use this package:
|Versions||0.1, 0.2, 0.2.0.1, 0.3, 0.3.0.1, 0.4, 0.5, 0.6, 0.6.1, 0.7, 0.8, 0.9, 0.10, 0.10.0.1, 0.11|
|Dependencies||base (>=4 && <4.3), base-unicode-symbols (>=0.1.1 && <0.2), bytestring (==0.9.*), explicit-iomodes (==0.2.*), MonadCatchIO-transformers (==0.0.2.*), regions (>=0.2 && <0.4), transformers (>=0.1.4 && <0.2) [details]|
|Copyright||2010 Bas van Dijk|
|Author||Bas van Dijk|
|Maintainer||Bas van Dijk <email@example.com>|
|Category||System, Monadic Regions|
|Source repository||head: darcs get http://code.haskell.org/~basvandijk/code/safer-file-handles|
|Uploaded||Sat Jan 23 14:25:55 UTC 2010 by BasVanDijk|
|Downloads||2623 total (67 in the last 30 days)|
|Status||Docs uploaded by user
Build status unknown [no reports yet]
For package maintainers and hackage trustees