[Haskell-cafe] Bug in HTTP (bad internal error handling)

Sittampalam, Ganesh ganesh.sittampalam at credit-suisse.com
Fri Oct 22 03:35:02 EDT 2010


Bit Connor wrote:
> On Sat, Oct 16, 2010 at 10:29 AM, Claus Reinke
> <claus.reinke at talk21.com> wrote: 
>>> After it catches this error, the function returns (line 376):
>>> 
>>> return (fail (show e))
>>> 
>>> The "fail" is running in the Either monad (The Result type =
>>> Either). This calls the default Monad implementation of fail, which
>>> is just a call to plain old error. This basically causes the entire
>>> program to crash.
>> 
>>> Actually, it appears that simpleHTTP isn't actually supposed to
>>> throw an IOException, and it is instead supposed to return a
>>> ConnError result. So the real fix is to fix the code to make this
>>> happen. But 
>> 
>> Sounds like a victim of
>>   http://hackage.haskell.org/trac/ghc/ticket/4159
>> 
>> For mtl clients, 'fail' for 'Either' used to call 'Left'. That was
>> changed, though the ticket does not indicate the library versions
>> affected.
> 
> This looks like the problem. Any idea how to get the HTTP package
> fixed? I could try making a patch myself, but I would prefer hearing
> from the HTTP maintainer first, who doesn't seem to be around.  

I've tried contacting him a few times about getting the base dependencies in HTTP bumped and an upload made, without success. This is a widely used package that's in the platform and that won't work with GHC 7.0 with the current dependencies, so it really needs to get fixed soon.

libraries@, what's the right way to proceed? Can I make a Debian-style "non-maintainer upload" with minimal changes to fix urgent issues like these?

Cheers,

Ganesh

=============================================================================== 
Please access the attached hyperlink for an important electronic communications disclaimer: 
http://www.credit-suisse.com/legal/en/disclaimer_email_ib.html 
=============================================================================== 



More information about the Haskell-Cafe mailing list