The IOSpec package

[Tags:bsd3, library]

This package consists of several modules, that give a pure specification of functions in the IO monad:

Besides these modules containing the specifications, there are a few other important modules:

There are several well-documented examples included with the source distribution.


[Skip to Readme]

Properties

Versions 0.1, 0.1.1, 0.2, 0.2.1, 0.2.2, 0.2.3, 0.2.4, 0.2.5, 0.2.6, 0.3
Dependencies base (>=2 && <5), mtl, QuickCheck (==2.*), Stream [details]
License BSD3
Author Wouter Swierstra, Yusaku Hashimoto
Maintainer Wouter Swierstra <wouter.swierstra@gmail.com>
Stability Unknown
Category Testing
Uploaded Tue Feb 21 09:34:55 UTC 2012 by WouterSwierstra
Distributions Debian:0.3, Fedora:0.3, NixOS:0.3
Downloads 4271 total (32 in the last 30 days)
Votes
0 []
Status Docs uploaded by user
Build status unknown [no reports yet]

Modules

[Index]

Downloads

Maintainer's Corner

For package maintainers and hackage trustees

Readme for IOSpec

Readme for IOSpec-0.2.5

IOSpec version 0.2
  Author: Wouter Swierstra <wss@cs.nott.ac.uk>

IOSpec provides a library containing pure, executable specifications
of a few functions from the IO monad. 

Build instructions:

    $ runhaskell Setup.lhs configure
    $ runhaskell Setup.lhs build
    $ runhaskell Setup.lhs install

See http://www.haskell.org/ghc/docs/latest/html/Cabal/builders.html
for more instructions.

Documentation:

Please have a look at the latest documentation available from:
  http://www.cs.nott.ac.uk/~wss/repos/IOSpec

To build the Haddock API execute the following command:
    $ runhaskell Setup.lhs haddock

This will require Haddock 2.0

Check out the examples directory for the following examples:

    * Echo.hs - illustrates how to test the echo function.
    * Queues.hs - an implementation of queues using IORefs.
    * Channels.hs - an implementation of channels using MVars.
    * Sudoku.hs - a parallel Sudoku solver that uses STM and MVars
         based on Graham Hutton's version of Richard Bird's "Solving Sudoku".

Every example contains quite some comments, explaining how to use
the library.