[Haskell-cafe] Debugging methods for haskell

Magnus Therning magnus at therning.org
Thu Jul 16 10:56:51 EDT 2009


On Wed, Jul 15, 2009 at 11:13 PM, Don Stewart<dons at galois.com> wrote:
> fernanbolando:
>> Hi all
>>
>> I recently used 2 hours of work looking for a bug that was causing
>>
>> Program error: Prelude.!!: index too large
>>
>> This is not very informative. It did not give me a hint which function
>> was causing this. In C adding a few printf would have helped me, but
>> in haskell I was not sure how to do that. Can anybody point me to some
>> debuggin method everyone uses.
>
> You could:
>
>    * use Debug.Trace.trace  (equivalent of printf debugging)
>    * use asserts: the 'assert' function
>    * use the GHCi debugger to construct a stack trace
>    * use profiling to construct a stack trace.
>    * use the GHC head branch for first class stack traces, described
>          in, "Finding the needle: Stack Traces for GHC"
>                http://pubs.doc.ic.ac.uk/finding-the-needle/finding-the-needle.pdf

Another option would be to use Safe.atMay[1] instead of !!.

[1]: http://hackage.haskell.org/packages/archive/safe/0.2/doc/html/Safe.html#v%3Aat

-- 
Magnus Therning                        (OpenPGP: 0xAB4DFBA4)
magnus@therning.org          Jabber: magnus@therning.org
http://therning.org/magnus         identi.ca|twitter: magthe


More information about the Haskell-Cafe mailing list