[Haskell-cafe] [Haskell] Functor => Applicative => Monad

Conor McBride conor at strictlypositive.org
Wed Dec 15 19:08:32 CET 2010


On 15 Dec 2010, at 17:48, Brent Yorgey wrote:

> On Wed, Dec 15, 2010 at 06:25:30PM +0100, Maciej Piechotka wrote:
>> On Wed, 2010-12-15 at 13:51 +0200, John Smith wrote:
>>> On 15/12/2010 11:39, Lennart Augustsson wrote:
>>>> Any refutable pattern match in do would force MonadFail (or  
>>>> MonadPlus if you prefer).  So

[..]

>>>>
>>>> As far as type inference and desugaring goes, it seems very  
>>>> little would have to be changed in an implementation.
>>>
>>> Is there a need for a MonadFail, as distinct from mzero? fail  
>>> always seems to be defined as error in ordinary monads,
>>> and as mzero in MonadPlus (or left at the default error).
>>
>> Not all types can implement mplus to begin with even if they can have
>> 'zero' type. For example technically Maybe breaks the laws while  
>> still
>> having useful fail:

[..]

>
> But that depends on what laws you choose for MonadPlus.  See
> http://www.haskell.org/haskellwiki/MonadPlus .

What has any of this to do with monads?

Cheers

Conor




More information about the Haskell-Cafe mailing list