On 12-03-11 12:39 PM, Chris Smith wrote:
On Sun, Mar 11, 2012 at 10:30 AM, Mario Blažević<blama...@acanac.net> wrote:
(p1>> unawait x)>>> p2 = (p1>>> p2)<* unawait x -- this one
tripped me up
I don't think this could reasonably hold. For example, you'd expect
that for any p, idP>> p == idP since idP never terminates at all.
But then let p1 == idP, and you get something silly. The issue is
with early termination: if p2 terminates first in the left hand side,
you don't want the unawait to occur.
No, idP does terminate once it consumes its input. Your idP >> p
first reproduces the complete input, and then runs p with empty input.
_______________________________________________
Haskell-Cafe mailing list
Haskell-Cafe@haskell.org
http://www.haskell.org/mailman/listinfo/haskell-cafe