<div dir="ltr"><div>I'm also strongly against mutually incompatible extensions. <br></div><div><br></div><div>I'm not sure about allowing the combination of TupleSections and ExtraCommas. It would mean that (x,) has a different meaning depending on what extensions are in force. This is a pretty strange direction to take the language in, and raises questions about whether we should think of GHC as a testing ground for language extensions of which only some will eventually make it into a language standard, or whether we should take a position on which extensions are sensible when there are conflicts. Personally I'm in favour of the committee taking some editorial decisions here - not just assessing which extensions make sense in isolation, but considering whether an extension makes sense in the context of the other extensions we already have.</div><div><br></div><div>But back to the current proposal, I would vote for allowing the parts of the proposal that don't conflict with TupleSections.<br></div><div><br></div><div>Cheers</div><div>Simon<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, 18 Apr 2019 at 16:06, Richard Eisenberg <<a href="mailto:rae@richarde.dev">rae@richarde.dev</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">I strongly dislike the idea of mutually-incompatible extensions.<br>
<br>
We could say that ExtraCommas allows extra commas everywhere, including in tuples and lists. We could also say that TupleSections overrides this behavior in tuples and gives it new meaning. We could further imagine ListSections that would override the behavior in lists. To me, this is preferable than mutual incompatibility.<br>
<br>
Does this make for a nice user experience? I'm not sure. Happily, the reinterpretation from TupleSections or ListSections would change types, so you'd get errors up front. These errors might even be clever enough to notice that both ExtraCommas and TupleSections are in effect and gently remind the user that this combination can be confusing. Actually, this might be a nice "have your cake and eat it too" moment: let's just do all the things!<br>
<br>
Richard<br>
<br>
> On Apr 18, 2019, at 10:52 AM, Simon Peyton Jones via ghc-steering-committee <<a href="mailto:ghc-steering-committee@haskell.org" target="_blank">ghc-steering-committee@haskell.org</a>> wrote:<br>
> <br>
> |  "tuples included" means "incompatible with tuple sections" means "they are<br>
> |  mutually exclusive to a module."<br>
> <br>
> You mean, some kind of new error message that says "these two extension are mutually incompatible".  I can't say I love this.  Let's just leave out tuples from ExtraCommas.<br>
> <br>
> (Actually I could imagine [a,,b,] meaning \xy. [a,x,b,y], one day.  Maybe we omit list literals too?  Or would that break the key use-cases?<br>
> <br>
> Simon<br>
> <br>
> |  -----Original Message-----<br>
> |  From: Christopher Allen <<a href="mailto:cma@bitemyapp.com" target="_blank">cma@bitemyapp.com</a>><br>
> |  Sent: 18 April 2019 10:08<br>
> |  To: Simon Peyton Jones <<a href="mailto:simonpj@microsoft.com" target="_blank">simonpj@microsoft.com</a>><br>
> |  Cc: Eric Seidel <<a href="mailto:eric@seidel.io" target="_blank">eric@seidel.io</a>>; <a href="mailto:ghc-steering-committee@haskell.org" target="_blank">ghc-steering-committee@haskell.org</a><br>
> |  Subject: Re: [ghc-steering-committee] Extra Commas<br>
> |  <br>
> |  My understanding of previous discussions was that:<br>
> |  <br>
> |  <br>
> |  On Thu, Apr 18, 2019 at 2:17 AM Simon Peyton Jones <<a href="mailto:simonpj@microsoft.com" target="_blank">simonpj@microsoft.com</a>><br>
> |  wrote:<br>
> |  ><br>
> |  > But it's actually *incompatible* with TupleSections, so how shoule<br>
> |  >         (True,)<br>
> |  > be interpreted if both are on?<br>
> |  ><br>
> |  > S<br>
> |  ><br>
> |  > |  -----Original Message-----<br>
> |  > |  From: ghc-steering-committee<br>
> |  > | <<a href="mailto:ghc-steering-committee-bounces@haskell.org" target="_blank">ghc-steering-committee-bounces@haskell.org</a>><br>
> |  > |  On Behalf Of Christopher Allen<br>
> |  > |  Sent: 18 April 2019 04:19<br>
> |  > |  To: Eric Seidel <<a href="mailto:eric@seidel.io" target="_blank">eric@seidel.io</a>><br>
> |  > |  Cc: <a href="mailto:ghc-steering-committee@haskell.org" target="_blank">ghc-steering-committee@haskell.org</a><br>
> |  > |  Subject: Re: [ghc-steering-committee] Extra Commas<br>
> |  > |<br>
> |  > |  I spoke with Matt, he's fine either way with or without tuples.<br>
> |  > |<br>
> |  > |  I'd prefer "with tuples" for consistency. I use tuples sometimes,<br>
> |  > | but  don't care about sectioning.<br>
> |  > |<br>
> |  > |  On Wed, Apr 17, 2019 at 8:15 PM Eric Seidel <<a href="mailto:eric@seidel.io" target="_blank">eric@seidel.io</a>> wrote:<br>
> |  > |  ><br>
> |  > |  > I favor accepting the proposal, with or without tuples. I've been<br>
> |  > | writing a bit of Rust recently, and agree with Chris about the<br>
> |  > | ergonomics  of trailing commas.<br>
> |  > |  ><br>
> |  > |  > On Wed, Apr 17, 2019, at 18:31, Joachim Breitner wrote:<br>
> |  > |  > > Hi,<br>
> |  > |  > ><br>
> |  > |  > > Am Mittwoch, den 17.04.2019, 13:38 -0500 schrieb Christopher<br>
> |  Allen:<br>
> |  > |  > > > I gave my recommendation for ExtraCommas, acceptance of the<br>
> |  > | > > > original proposal as written. I talk with the proposer almost<br>
> |  > | > > > every day so I know where he stands. He still thinks it's<br>
> |  > | worth  > > > doing and would like to see it accepted. I think<br>
> |  > | ExtraCommas  > > > merits acceptance. If we can't achieve consensus<br>
> |  > | on it then it  > > > should be rejected so it gets cleared off the<br>
> |  > | slate. I'm not  > > > inclined to argue a syntactic extension like<br>
> |  > | this, but I will say<br>
> |  > |  this:<br>
> |  > |  > > ><br>
> |  > |  > > > The proposal captures a nice design element that we've seen<br>
> |  > | work  > > > very well ergonomically in Rust. We're never going to<br>
> |  > | make the  > > > same decisions with the same tradeoffs as a totally<br>
> |  > | different  > > > language but any time there is a relatively isolated<br>
> |  "good idea"<br>
> |  > |  > > > like this, I'd like to see us try to take advantage of that<br>
> |  > | and  > > > see if it works for us.<br>
> |  > |  > ><br>
> |  > |  > > thanks for picking this up.<br>
> |  > |  > ><br>
> |  > |  > > The most contentious point, besides whether its worth the<br>
> |  > | bother at  > > all, was the interaction with TupleSections. Which<br>
> |  > | gives us three  > > options, I think:<br>
> |  > |  > >  * reject<br>
> |  > |  > >  * accept, covering tuples (and making it conflict with  > ><br>
> |  > | TupleSections)  > >  * accept, not covering tuples.<br>
> |  > |  > ><br>
> |  > |  > > No decision is absolutely wrong, none is obviously right.<br>
> |  > |  > ><br>
> |  > |  > > Maybe we should simply do a vote, to get it decided? Simons (as<br>
> |  > | > > Chairs), what do you think?<br>
> |  > |  > ><br>
> |  > |  > > Cheers,<br>
> |  > |  > > Joachim<br>
> |  > |  > ><br>
> |  > |  > > --<br>
> |  > |  > > Joachim Breitner<br>
> |  > |  > >  <a href="mailto:mail@joachim-breitner.de" target="_blank">mail@joachim-breitner.de</a><br>
> |  > |  > ><br>
> |  > | <a href="https://nam06.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww" rel="noreferrer" target="_blank">https://nam06.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww</a><br>
> |  > | .<a href="http://joachim-breitner.de" rel="noreferrer" target="_blank">joachim-breitner.de</a>%2F&amp;data=02%7C01%7Csimonpj%<a href="http://40microsoft.com" rel="noreferrer" target="_blank">40microsoft.com</a>%7<br>
> |  > | C670f986836834427a29408d6c3dd5cd0%7C72f988bf86f141af91ab2d7cd011db47<br>
> |  > | %7C1%7C0%7C636911752855987147&amp;sdata=gCdvqR5gm0K54rJMnfcnIiOyyv4u<br>
> |  > | 9fb%2BRkQMqGibDlM%3D&amp;reserved=0<br>
> |  > |  > ><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>
> |  > |  > ><br>
> |  > | <a href="https://nam06.safelinks.protection.outlook.com/?url=https%3A%2F%2Fma" rel="noreferrer" target="_blank">https://nam06.safelinks.protection.outlook.com/?url=https%3A%2F%2Fma</a><br>
> |  > | <a href="http://il.haskell.org" rel="noreferrer" target="_blank">il.haskell.org</a>%2Fcgi-bin%2Fmailman%2Flistinfo%2Fghc-steering-commi&a<br>
> |  > | mp;data=02%7C01%7Csimonpj%<a href="http://40microsoft.com" rel="noreferrer" target="_blank">40microsoft.com</a>%7C670f986836834427a29408d6<br>
> |  > | c3dd5cd0%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C63691175285598<br>
> |  > | 7147&amp;sdata=NZqChpNEoHihvoow29uxmmDyPuLeVgn4iNwkcdMDno8%3D&amp;re<br>
> |  > | served=0<br>
> |  > |  > > ttee<br>
> |  > |  > ><br>
> |  > |  > > Attachments:<br>
> |  > |  > > * signature.asc<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>
> |  > |  ><br>
> |  > | <a href="https://nam06.safelinks.protection.outlook.com/?url=https%3A%2F%2Fma" rel="noreferrer" target="_blank">https://nam06.safelinks.protection.outlook.com/?url=https%3A%2F%2Fma</a><br>
> |  > | <a href="http://il.haskell.org" rel="noreferrer" target="_blank">il.haskell.org</a>%2Fcgi-bin%2Fmailman%2Flistinfo%2Fghc-steering-committ<br>
> |  > | &amp;data=02%7C01%7Csimonpj%<a href="http://40microsoft.com" rel="noreferrer" target="_blank">40microsoft.com</a>%7C670f986836834427a29408<br>
> |  > | d6c3dd5cd0%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C636911752855<br>
> |  > | 987147&amp;sdata=1PZCPlMWYOlGrlN7MFkvn7rmpdMUqv%2BShDLpFyO4Y%2FI%3D&<br>
> |  > | amp;reserved=0<br>
> |  > |  > ee<br>
> |  > |<br>
> |  > |<br>
> |  > |<br>
> |  > |  --<br>
> |  > |  Chris Allen<br>
> |  > |  Currently working on<br>
> |  > | <a href="https://nam06.safelinks.protection.outlook.com/?url=http%3A%2F%2Fhas" rel="noreferrer" target="_blank">https://nam06.safelinks.protection.outlook.com/?url=http%3A%2F%2Fhas</a><br>
> |  > | <a href="http://kellbook.com" rel="noreferrer" target="_blank">kellbook.com</a>&amp;data=02%7C01%7Csimonpj%<a href="http://40microsoft.com" rel="noreferrer" target="_blank">40microsoft.com</a>%7C670f986836<br>
> |  > | 834427a29408d6c3dd5cd0%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C<br>
> |  > | 636911752855987147&amp;sdata=u6TzKujVuJnrWL%2BnPr0YlcE7w8xHnENsWZUDK<br>
> |  > | 8IyjBI%3D&amp;reserved=0<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>
> |  > |<br>
> |  > | <a href="https://nam06.safelinks.protection.outlook.com/?url=https%3A%2F%2Fma" rel="noreferrer" target="_blank">https://nam06.safelinks.protection.outlook.com/?url=https%3A%2F%2Fma</a><br>
> |  > | <a href="http://il.haskell.org" rel="noreferrer" target="_blank">il.haskell.org</a>%2Fcgi-bin%2Fmailman%2Flistinfo%2Fghc-steering-committ<br>
> |  > | ee&amp;data=02%7C01%7Csimonpj%<a href="http://40microsoft.com" rel="noreferrer" target="_blank">40microsoft.com</a>%7C670f986836834427a294<br>
> |  > | 08d6c3dd5cd0%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C6369117528<br>
> |  > | 55987147&amp;sdata=ESnHSYRuMMUvenMjIzpapcKWVfzbAqLJ9%2BcSNjoWklk%3D&<br>
> |  > | amp;reserved=0<br>
> |  <br>
> |  <br>
> |  <br>
> |  --<br>
> |  Chris Allen<br>
> |  Currently working on<br>
> |  <a href="https://nam06.safelinks.protection.outlook.com/?url=http%3A%2F%2Fhaskellbo" rel="noreferrer" target="_blank">https://nam06.safelinks.protection.outlook.com/?url=http%3A%2F%2Fhaskellbo</a><br>
> |  <a href="http://ok.com" rel="noreferrer" target="_blank">ok.com</a>&amp;data=02%7C01%7Csimonpj%<a href="http://40microsoft.com" rel="noreferrer" target="_blank">40microsoft.com</a>%7C670f986836834427a29408<br>
> |  d6c3dd5cd0%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C636911752855987147<br>
> |  &amp;sdata=u6TzKujVuJnrWL%2BnPr0YlcE7w8xHnENsWZUDK8IyjBI%3D&amp;reserved=0<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" rel="noreferrer" target="_blank">https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-committee</a><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" rel="noreferrer" target="_blank">https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-committee</a><br>
</blockquote></div>