[Haskell-cafe] exceptions vs. Either

Alastair Reid alastair at reid-consulting-uk.ltd.uk
Mon Aug 2 16:58:50 EDT 2004


On Monday 02 August 2004 21:09, Evan LaForge wrote:
> Exceptions are convenient [...] 
> [but] an exception will only be thrown when you evaluate t.
>
> So it seems to me that if you are, say, checking input, the options are
> to handle exceptions from the checking code but expect them to come from
> the processing code, or [not use eceptions]
> [...]
> So then, in what contexts are exceptions appropriate in haskell?

I think you're right that exceptions aren't useful for input checking.  You 
really need something that will check all the input at once.  i.e., 
evaluating any part of the checked input causes all input checks to be 
performed.  The easiest way to do this is with a monad or some such - which 
provides you with a more flexible, more controllable error-reporting 
mechanism anyway.

I usually use exceptions when dealing with the outside world where I want to 
protect the outside world from any misbehaviour of the Haskell code.  For 
example, if opening and closing windows or files, controlling a robot, etc., 
I might use the exception catching/propagating to make sure that things are 
shutdown properly when the Haskell program crashes.

In general, if there's a way to make your program bombproof using a 
conventional mechanism (monads, Either, Maybe, etc.), then you should use it 
since it will be easier to reason about and can be more flexible.  But, if 
your program really has to be bombproof and you can't convince yourself that 
it is (e.g., it depends on a library you didn't write), exception handling 
can help a lot.

--
Alastair Reid


More information about the Haskell-Cafe mailing list