<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class="">I agree with all that you are saying about the syntax, including that I really don’t see a good alternative.<div class=""><br class=""></div><div class="">I didn’t know about the view patterns alternative. That is indeed an annoying potential overlap.</div><div class=""><br class=""></div><div class="">Cheers,</div><div class="">Manuel<br class=""><div><br class=""><blockquote type="cite" class=""><div class="">Simon Marlow <<a href="mailto:marlowsd@gmail.com" class="">marlowsd@gmail.com</a>>:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class="">I'm in favour of Or patterns with the non-backtracking semantics. While '|' is the natural syntax, it does have a couple of drawbacks:<div class=""><br class=""></div><div class="">- it's the same as the guard syntax, and therefore potentially confusing (it might not seem confusing to us, because we're used to parsing Haskell in our heads, but to new users I'm sure this will be confusing)</div><div class="">- It interacts badly with this idea which I really hope we can make into a proper proposal one day: <a href="https://ghc.haskell.org/trac/ghc/wiki/ViewPatternsAlternative" class="">https://ghc.haskell.org/trac/ghc/wiki/ViewPatternsAlternative</a></div><div class=""><br class=""></div><div class="">But '|' is also the syntax used for defining the constructor alternatives in a data type. So unless we intend to recommend GADT syntax exclusively in the future, it makes sense to use '|' for or-patterns. And I can't think of a good alternative.</div><div class=""><br class=""></div><div class="">Cheers,</div><div class="">Simon</div><div class=""> </div></div><div class="gmail_extra"><br class=""><div class="gmail_quote">On 1 November 2017 at 23:57, Manuel M T Chakravarty <span dir="ltr" class=""><<a href="mailto:chak@justtesting.org" target="_blank" class="">chak@justtesting.org</a>></span> wrote:<br class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Folks,<br class="">
<br class="">
I am sorry for taking a long time to get us going on this proposal.<br class="">
<br class="">
The ”Or pattern” proposal is about an extension to pattern matching:<br class="">
<br class="">
(formatted) <a href="https://github.com/osa1/ghc-proposals/blob/or_patterns/proposals/0000-or-patterns.rst" rel="noreferrer" target="_blank" class="">https://github.com/osa1/ghc-<wbr class="">proposals/blob/or_patterns/<wbr class="">proposals/0000-or-patterns.rst</a><br class="">
(PR thread) <a href="https://github.com/ghc-proposals/ghc-proposals/pull/43" rel="noreferrer" target="_blank" class="">https://github.com/ghc-<wbr class="">proposals/ghc-proposals/pull/<wbr class="">43</a><br class="">
<br class="">
Its basic idea is simple: allow multiple alternative patterns for each alternative during pattern matching. Unfortunately, the interaction with guards and some other languages features makes it significantly less straight forward than one might initially think.<br class="">
<br class="">
I propose to accept this proposal provided we can agree to use the ”first semantics” (aka single-match semantics) — see <a href="https://github.com/osa1/ghc-proposals/blob/or_patterns/proposals/0000-or-patterns.rst#interaction-with-guards" rel="noreferrer" target="_blank" class="">https://github.com/osa1/ghc-<wbr class="">proposals/blob/or_patterns/<wbr class="">proposals/0000-or-patterns.<wbr class="">rst#interaction-with-guards</a><br class="">
<br class="">
My reason for insisting on the first semantics is that it is a simple extension of the existing pattern semantics in the Report, whereas the second semantics requires a more profound, non-local change. This, in particular, also makes it easier to understand the implications of the first semantics. (Also, OCaml has made that same choice.)<br class="">
<br class="">
However, even with the first semantics, I still have one concern about this proposal. The story about the interaction with existential types is currently only partial and there is no discussion of the interaction with GADTs. It might be reasonable to ask for a complete specification of the interaction with these features before making a final determination on this proposal. Nevertheless, this proposal is quite elaborate and quite some work has gone into it. Hence, I think, we owe it the authors of the proposal to at least make a preliminary determination at this point. (In particular, if it is not going to fly regardless of how GADTs are handled, we should say so now.)<br class="">
<br class="">
Cheers,<br class="">
Manuel<br class="">
<br class="">
PS: It is worth noting that Swift solved the problem of deciding between the first and second semantics by choosing a syntax that avoids the ambiguity: <<a href="https://developer.apple.com/library/content/documentation/Swift/Conceptual/Swift_Programming_Language/Statements.html#//apple_ref/swift/grammar/switch-statement" rel="noreferrer" target="_blank" class="">https://developer.apple.com/<wbr class="">library/content/documentation/<wbr class="">Swift/Conceptual/Swift_<wbr class="">Programming_Language/<wbr class="">Statements.html#//apple_ref/<wbr class="">swift/grammar/switch-statement</a><wbr class="">>. It is difficult to adapt this syntax to Haskell. If it where possible, I think, this would be the best solution.<br class="">
______________________________<wbr class="">_________________<br class="">
ghc-steering-committee mailing list<br class="">
<a href="mailto:ghc-steering-committee@haskell.org" class="">ghc-steering-committee@<wbr class="">haskell.org</a><br class="">
<a href="https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-committee" rel="noreferrer" target="_blank" class="">https://mail.haskell.org/cgi-<wbr class="">bin/mailman/listinfo/ghc-<wbr class="">steering-committee</a><br class="">
</blockquote></div><br class=""></div>
</div></blockquote></div><br class=""></div></body></html>