<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
{font-family:"Cambria Math";
panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0cm;
margin-bottom:.0001pt;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:blue;
text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
{mso-style-priority:99;
color:purple;
text-decoration:underline;}
p.Code, li.Code, div.Code
{mso-style-name:Code;
margin-top:0cm;
margin-right:0cm;
margin-bottom:0cm;
margin-left:36.0pt;
margin-bottom:.0001pt;
font-size:10.0pt;
font-family:"Courier New";}
p.msonormal0, li.msonormal0, div.msonormal0
{mso-style-name:msonormal;
mso-margin-top-alt:auto;
margin-right:0cm;
mso-margin-bottom-alt:auto;
margin-left:0cm;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
span.EmailStyle19
{mso-style-type:personal-reply;
font-family:"Calibri",sans-serif;
color:windowtext;}
.MsoChpDefault
{mso-style-type:export-only;
font-family:"Calibri",sans-serif;
mso-fareast-language:EN-US;}
.MsoPapDefault
{mso-style-type:export-only;
margin-top:6.0pt;
margin-right:0cm;
margin-bottom:6.0pt;
margin-left:0cm;}
@page WordSection1
{size:612.0pt 792.0pt;
margin:72.0pt 72.0pt 72.0pt 72.0pt;}
div.WordSection1
{page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-GB" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:36.0pt">
<a name="_MailEndCompose">1. The syntax conflict with the view pattern proposal is unfortunate---I really like this idea, and I wrote up basically the exact same thing in my dissertation a long time ago, where I called it "guarded patterns". Very handy I think.<o:p></o:p></a></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US">Yes… I too wondered about ||, although then we’d run into trouble with definitions of the function (||). It seems hard to not-accept a proposal because
it conflicts with another un-submitted one. But that’s just a question of specifying which wins in the ambiguous case<o:p></o:p></span></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US"> p1 || p2 = e<o:p></o:p></span></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US">I like the fact that || is a bit noisier; we are using | for guards already.<o:p></o:p></span></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US">We should only allow it infix.<o:p></o:p></span></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US">Would someone like to submit the view-pattern proposal?<o:p></o:p></span></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></span></p>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:36.0pt">
<span style="mso-bookmark:_MailEndCompose">For the second one, I can see two options:<o:p></o:p></span></p>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:36.0pt">
<span style="mso-bookmark:_MailEndCompose"> A) do not allow or patterns if any of the patterns contain constraint<o:p></o:p></span></p>
<p class="MsoNormal" style="margin-left:36.0pt"><span style="mso-bookmark:_MailEndCompose"> B) come up with a mechanism to compute the intersection of constraints<o:p></o:p></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose">I prefer (C): require exactly the same constraints bound in both patterns. Same as we require exactly the same variables bound. We could loosen up later.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></span></p>
<p class="MsoNormal"><span style="mso-bookmark:_MailEndCompose"><span style="mso-fareast-language:EN-US"><o:p> </o:p></span></span></p>
<span style="mso-bookmark:_MailEndCompose"></span>
<div style="border:none;border-left:solid blue 1.5pt;padding:0cm 0cm 0cm 4.0pt">
<div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal"><b><span lang="EN-US">From:</span></b><span lang="EN-US"> ghc-steering-committee [mailto:ghc-steering-committee-bounces@haskell.org]
<b>On Behalf Of </b>Iavor Diatchki<br>
<b>Sent:</b> 07 November 2017 18:03<br>
<b>To:</b> Joachim Breitner <mail@joachim-breitner.de><br>
<b>Cc:</b> ghc-steering-committee@haskell.org<br>
<b>Subject:</b> Re: [ghc-steering-committee] Proposal: Or patterns (#43)<o:p></o:p></span></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
Hello,<o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
I think that in principle the or-pattern patter idea is fine, but I am a bit wary of accepting it as is for two reasons:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
1. The syntax conflict with the view pattern proposal is unfortunate---I really like this idea, and I wrote up basically the exact same thing in my dissertation a long time ago, where I called it "guarded patterns". Very handy I think.<o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
2. The story about pattern contexts seems unclear (i.e., extistentials and GADTs).<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
To work around the first one, how about we use double bar (i.e., ||) to separate the Or pattern? The single bar does feel more natural though...<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
For the second one, I can see two options:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
A) do not allow or patterns if any of the patterns contain constraint<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
B) come up with a mechanism to compute the intersection of constraints. For this I can see a few options:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
B.1) Fancy intersection, where the different branches of the or-patterns may define additional evidence bindings (be it dictionaries or coercions). <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
B.2) Simple intersection, where we only pick constraints from the contexts that match exactly. <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
-Iavor<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
</div>
</div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
<o:p> </o:p></p>
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
On Fri, Nov 3, 2017 at 6:19 AM Joachim Breitner <<a href="mailto:mail@joachim-breitner.de">mail@joachim-breitner.de</a>> wrote:<o:p></o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0cm 0cm 0cm 6.0pt;margin-left:4.8pt;margin-right:0cm">
<p class="MsoNormal" style="mso-margin-top-alt:6.0pt;margin-right:0cm;margin-bottom:6.0pt;margin-left:0cm">
Hi,<br>
<br>
from a procedural point of view, that’s fine: We can certainly ask for<br>
improvements to a proposal, and there is even a “Needs revision” label<br>
for it.<br>
<br>
Joachim<br>
<br>
Am Freitag, den 03.11.2017, 10:40 +1100 schrieb Manuel M T Chakravarty:<br>
> You are right, the proposal must be complete before we can accept it. What I would like to suggest is the following:<br>
><br>
> * If we all agree that *so far* this proposal is acceptable, we bounce it back to the authors saying that if they are able to fill in the gaps (especially, the treatment of GADTs) in a satisfactory manner, we will accept the proposal.<br>
><br>
> * If we decide to reject the proposal, the authors can save themselves the effort of completing the specification.<br>
><br>
> I know that this deviates from our usual procedure, but for a rather large piece of work that does show promise, I think, it is worthwhile to show some respect and appreciation for the effort spent.<br>
><br>
> Cheers,<br>
> Manuel<br>
><br>
> > Simon Peyton Jones <<a href="mailto:simonpj@microsoft.com" target="_blank">simonpj@microsoft.com</a>>:<br>
> ><br>
> > In general I'm ok with this proposal.<br>
> ><br>
> > But I've just added a comment explaining some things that really need fleshing out.<br>
> ><br>
> ><br>
> ><br>
> > * The proposal should specify that in (p1 | p2) the patterns in p1 and p2 must bind the same set of variables, with the same types. Nothing else makes sense; but it is nowhere specified.<br>
> ><br>
> > * I'm concerned that the specification is incomplete. Certainly when it comes to GADTs there is some muttering about the prototype implementation, but no specification.<br>
> ><br>
> > * For GADTs it's clear to me that in (p1 | p2) the patterns p1 and p2 should bind the same set of existentials and the same set of type constraints (including class constraints), just as they must bind the same set of variables with the same types. Just
write out the typing rules for patterns (which should be part of the proposal) and it'll all become clear!<br>
> ><br>
> > * I'm bothered by the stuff about view patterns, lazy patterns etc in the proposal. The point is: or-patterns has NO interaction with these patterns. We should just say that and stop! By having (quite long) sections about these features, but not (say) about
tuple patterns, the implication is that there is something special to say. But there isn't.<br>
> ><br>
> > > My reason for insisting on the first semantics is that it is a simple<br>
> > > extension of the existing pattern semantics in the Report, whereas the<br>
> > > second semantics requires a more profound, non-local change.<br>
> ><br>
> > Definitely non-backtracking. The backtracking thing opens up a whole new can of worms.<br>
> ><br>
> > > quite elaborate and quite some work has gone into it. Hence, I think,<br>
> > > we owe it the authors of the proposal to at least make a preliminary<br>
> > > determination at this point. (In particular, if it is not going to fly<br>
> > > regardless of how GADTs are handled, we should say so now.)<br>
> ><br>
> > I agree with that... but I'd be reluctant to actually accept it into GHC unless it was fully compositional, including GADTs. So it'd be a conditional acceptance, subject to satisfactory resolution of the GADT question. I'm not sure how the implementation
works out... let's see; probably fine.<br>
> ><br>
> ><br>
> > Simon<br>
> ><br>
> > > -----Original Message-----<br>
> > > From: ghc-steering-committee [mailto:<a href="mailto:ghc-steering-committee-" target="_blank">ghc-steering-committee-</a><br>
> > > <a href="mailto:bounces@haskell.org" target="_blank">bounces@haskell.org</a>] On Behalf Of Manuel M T Chakravarty<br>
> > > Sent: 01 November 2017 23:58<br>
> > > To: <a href="mailto:ghc-steering-committee@haskell.org" target="_blank">ghc-steering-committee@haskell.org</a><br>
> > > Subject: [ghc-steering-committee] Proposal: Or patterns (#43)<br>
> > ><br>
> > > Folks,<br>
> > ><br>
> > > I am sorry for taking a long time to get us going on this proposal.<br>
> > ><br>
> > > The ”Or pattern” proposal is about an extension to pattern matching:<br>
> > ><br>
> > > (formatted)<br>
> > > <a href="https://na01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithu" target="_blank">
https://na01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithu</a><br>
> > > <a href="https://na01.safelinks.protection.outlook.com/?url=http%3A%2F%2Fb.com&data=02%7C01%7Csimonpj%40microsoft.com%7Ce4b67c3a21ee4058d49908d52609e766%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C636456746344878614&sdata=vVnLieNrA5efYx9jbB%2BXtb%2FYWdKpO01CQMD2dj6Cwsg%3D&reserved=0" target="_blank">
b.com</a>%2Fosa1%2Fghc-proposals%2Fblob%2For_patterns%2Fproposals%2F0000-<br>
> > > or-<br>
> > > patterns.rst&data=02%7C01%7Csimonpj%<a href="https://na01.safelinks.protection.outlook.com/?url=http%3A%2F%2F40microsoft.com&data=02%7C01%7Csimonpj%40microsoft.com%7Ce4b67c3a21ee4058d49908d52609e766%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C636456746344878614&sdata=0I1KlIPm7n54A5ECKT91vmrrLLtKyLoeS9uD5dfzTG0%3D&reserved=0" target="_blank">40microsoft.com</a>%7Cc41b6be72ad54503<br>
> > > 0e3c08d521846116%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C63645177<br>
> > > <a href="tel:(480)%20595-1860" target="_blank">4805951860</a>&sdata=ivKxIr7%2FprF1GhUBq%2BZRxJjmKqfPq%2BNOXmbw9JPJuQ8%3D&<br>
> > > reserved=0<br>
> > > (PR thread)<br>
> > > <a href="https://na01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithu" target="_blank">
https://na01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithu</a><br>
> > > <a href="https://na01.safelinks.protection.outlook.com/?url=http%3A%2F%2Fb.com&data=02%7C01%7Csimonpj%40microsoft.com%7Ce4b67c3a21ee4058d49908d52609e766%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C636456746344878614&sdata=vVnLieNrA5efYx9jbB%2BXtb%2FYWdKpO01CQMD2dj6Cwsg%3D&reserved=0" target="_blank">
b.com</a>%2Fghc-proposals%2Fghc-<br>
> > > proposals%2Fpull%2F43&data=02%7C01%7Csimonpj%<a href="https://na01.safelinks.protection.outlook.com/?url=http%3A%2F%2F40microsoft.com&data=02%7C01%7Csimonpj%40microsoft.com%7Ce4b67c3a21ee4058d49908d52609e766%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C636456746344878614&sdata=0I1KlIPm7n54A5ECKT91vmrrLLtKyLoeS9uD5dfzTG0%3D&reserved=0" target="_blank">40microsoft.com</a>%7Cc41b6be<br>
> > > 72ad545030e3c08d521846116%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7<br>
> > > C636451774805951860&sdata=x0Xn%2BOS6mHZBWYolcaJfa5JCkbHa1pl552fNI1Swmh<br>
> > > w%3D&reserved=0<br>
> > ><br>
> > > Its basic idea is simple: allow multiple alternative patterns for each<br>
> > > alternative during pattern matching. Unfortunately, the interaction<br>
> > > with guards and some other languages features makes it significantly<br>
> > > less straight forward than one might initially think.<br>
> > ><br>
> > > I propose to accept this proposal provided we can agree to use the<br>
> > > ”first semantics” (aka single-match semantics) — see<br>
> > > <a href="https://na01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithu" target="_blank">
https://na01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithu</a><br>
> > > <a href="https://na01.safelinks.protection.outlook.com/?url=http%3A%2F%2Fb.com&data=02%7C01%7Csimonpj%40microsoft.com%7Ce4b67c3a21ee4058d49908d52609e766%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C636456746344878614&sdata=vVnLieNrA5efYx9jbB%2BXtb%2FYWdKpO01CQMD2dj6Cwsg%3D&reserved=0" target="_blank">
b.com</a>%2Fosa1%2Fghc-proposals%2Fblob%2For_patterns%2Fproposals%2F0000-<br>
> > > or-patterns.rst%23interaction-with-<br>
> > > guards&data=02%7C01%7Csimonpj%<a href="https://na01.safelinks.protection.outlook.com/?url=http%3A%2F%2F40microsoft.com&data=02%7C01%7Csimonpj%40microsoft.com%7Ce4b67c3a21ee4058d49908d52609e766%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C636456746344878614&sdata=0I1KlIPm7n54A5ECKT91vmrrLLtKyLoeS9uD5dfzTG0%3D&reserved=0" target="_blank">40microsoft.com</a>%7Cc41b6be72ad545030e3c08<br>
> > > d521846116%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C63645177480595<br>
> > > 1860&sdata=Z5JJApLfReiCl0dKD2R%2Fvbs3pTZt84iEXDRhdbeVICA%3D&reserved=0<br>
> > ><br>
> > > My reason for insisting on the first semantics is that it is a simple<br>
> > > extension of the existing pattern semantics in the Report, whereas the<br>
> > > second semantics requires a more profound, non-local change. This, in<br>
> > > particular, also makes it easier to understand the implications of the<br>
> > > first semantics. (Also, OCaml has made that same choice.)<br>
> > ><br>
> > > However, even with the first semantics, I still have one concern about<br>
> > > this proposal. The story about the interaction with existential types<br>
> > > is currently only partial and there is no discussion of the<br>
> > > interaction with GADTs. It might be reasonable to ask for a complete<br>
> > > specification of the interaction with these features before making a<br>
> > > final determination on this proposal. Nevertheless, this proposal is<br>
> > > quite elaborate and quite some work has gone into it. Hence, I think,<br>
> > > we owe it the authors of the proposal to at least make a preliminary<br>
> > > determination at this point. (In particular, if it is not going to fly<br>
> > > regardless of how GADTs are handled, we should say so now.)<br>
> > ><br>
> > > Cheers,<br>
> > > Manuel<br>
> > ><br>
> > > PS: It is worth noting that Swift solved the problem of deciding<br>
> > > between the first and second semantics by choosing a syntax that<br>
> > > avoids the ambiguity:<br>
> > > <<a href="https://na01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fdeve" target="_blank">https://na01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fdeve</a><br>
> > > <a href="https://na01.safelinks.protection.outlook.com/?url=http%3A%2F%2Floper.apple.com&data=02%7C01%7Csimonpj%40microsoft.com%7Ce4b67c3a21ee4058d49908d52609e766%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C636456746344878614&sdata=wCHBivwlq4sPM%2BVxMQIIwCzfjGwLKUf7c3xTgXUXtvg%3D&reserved=0" target="_blank">
loper.apple.com</a>%2Flibrary%2Fcontent%2Fdocumentation%2FSwift%2FConceptu<br>
> > > al%2FSwift_Programming_Language%2FStatements.html%23%2F%2Fapple_ref%2F<br>
> > > swift%2Fgrammar%2Fswitch-<br>
> > > statement&data=02%7C01%7Csimonpj%<a href="https://na01.safelinks.protection.outlook.com/?url=http%3A%2F%2F40microsoft.com&data=02%7C01%7Csimonpj%40microsoft.com%7Ce4b67c3a21ee4058d49908d52609e766%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C636456746344878614&sdata=0I1KlIPm7n54A5ECKT91vmrrLLtKyLoeS9uD5dfzTG0%3D&reserved=0" target="_blank">40microsoft.com</a>%7Cc41b6be72ad545030e3<br>
> > > c08d521846116%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C63645177480<br>
> > > 5951860&sdata=ax1RcoY80ERbid5inoe%2BCRYg%2FC4t0hVL5oGBasVTfhM%3D&reser<br>
> > > ved=0>. It is difficult to adapt this syntax to Haskell. If it where<br>
> > > possible, I think, this would be the best solution.<br>
> > > _______________________________________________<br>
> > > ghc-steering-committee mailing list<br>
> > > <a href="mailto:ghc-steering-committee@haskell.org" target="_blank">ghc-steering-committee@haskell.org</a><br>
> > > <a href="https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-" target="_blank">
https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-</a><br>
> > > committee<br>
><br>
> _______________________________________________<br>
> ghc-steering-committee mailing list<br>
> <a href="mailto:ghc-steering-committee@haskell.org" target="_blank">ghc-steering-committee@haskell.org</a><br>
> <a href="https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-committee" target="_blank">
https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-committee</a><br>
--<br>
Joachim Breitner<br>
<a href="mailto:mail@joachim-breitner.de" target="_blank">mail@joachim-breitner.de</a><br>
<a href="https://na01.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww.joachim-breitner.de%2F&data=02%7C01%7Csimonpj%40microsoft.com%7Ce4b67c3a21ee4058d49908d52609e766%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C636456746344878614&sdata=TyqRhlHt83F%2BCpZzF5kNM%2BI4YFj3GbLOGq5pNskVrbw%3D&reserved=0" target="_blank">
http://www.joachim-breitner.de/</a><br>
_______________________________________________<br>
ghc-steering-committee mailing list<br>
<a href="mailto:ghc-steering-committee@haskell.org" target="_blank">ghc-steering-committee@haskell.org</a><br>
<a href="https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-committee" target="_blank">https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-committee</a><o:p></o:p></p>
</blockquote>
</div>
</div>
</div>
</body>
</html>