<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div class="">Yes, this is a very important question.</div><div class=""><br class=""></div><div class="">Naturally, (2) makes the theorist in me very happy. But I advocate for (3), regardless:</div><div class=""><br class=""></div><div class="">- This debate isn't only about extensions. As has been pointed out, `base` undergoes a non-trivial amount of churn between releases, and considering the compiler in a vacuum isn't realistic. Two versions of the compiler will accept (slightly) different versions of the language. (Or, in the case of GHC 7.8, drastically different versions of the language.)</div><div class=""><br class=""></div><div class="">- I think we're handicapping ourselves at creating a cutting-edge language if we adopt (1) or (2). (3) allows us to, well, move fast and break things, and that model has been very successful for Haskell thus far.</div><div class=""><br class=""></div><div class="">- Who gets hurt if we choose (3)? Surely, (3) means that, e.g., cabal files should properly specify GHC ranges. And we should aim for Simon M's original comment that evolution only adds features -- but we'll never really meet that standard, I don't think.</div><div class=""><br class=""></div><div class="">- We could adopt versioned extensions, as I've previously brought up. Doing so might move us more toward (1) or (2). However, I would expect a version of GHC to support only one version of a given extension, and so then a file with, say, `{-# LANGUAGE PolyKinds-3 #-}` would be acceptable by only a small compiler version range (possibly containing only one major release), and then what will we have gained?</div><div class=""><br class=""></div><div class="">- I like the idea of having the manual state the stability of extensions. (We should also state unambiguously the potential downside of extensions -- like declaring that UndecidableInstances may cause GHC to loop, but it doesn't allow you to shoot the gorillas.) But I don't think that an extension has to be set in stone after only two revisions. Sometimes experiments really do take years to carry out! So, I like the idea of alpha/beta/stable, but (in contrast to Manuel) I would let the feature designers choose when it's time to move the needle.</div><div class=""><br class=""></div><div class="">Looking forward to seeing others' thoughts on this,</div><div class="">Richard</div><br class=""><div><blockquote type="cite" class=""><div class="">On Oct 17, 2017, at 6:30 AM, Manuel M T Chakravarty <<a href="mailto:chak@justtesting.org" class="">chak@justtesting.org</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><meta http-equiv="Content-Type" content="text/html; charset=utf-8" class=""><div style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class="">I completely agree with Simon: this is an important question.<div class=""><br class=""></div><div class="">I think, it would be good to have at least (1), but better (2). </div><div class=""><br class=""></div><div class="">Why? Because Haskell’ really doesn’t get anywhere and in its absence the guarantees provided by GHC are the only language stability there is. Maybe it is unfair to put this burden on the compiler, instead of on a separate language specification, but that is how it is.</div><div class=""><br class=""></div><div class="">Now, I reckon the main obstacle to (1) and (2) is that LANGUAGE extensions, when they appear first, are in flux, because they are often parts of experiments. Hence, I’d like to suggest that we might be able to lessen the tension between experimentation and stability by formally associating a ”stability” of one of ”alpha”, ”beta”, or ”stable” with each extension.</div><div class=""><br class=""></div><div class="">As we all know, these stability annotations don’t work at all on Hackage as nobody ever moves their packages away from ”experimental”. Hence, I suggest that we do not make this the choice of the person who proposes an extension, but part of our process. There are a few options, which might be worth considering.</div><div class=""><br class=""></div><div class="">For example, when a LANGUAGE extension is first proposed, it starts at ”alpha”. When latter a proposal is submitted to amend the extension, that amendment is approved by us only if it successfully argues that it improves the maturity of the extension such that it warrants ”beta” stability. And then, the same with ”stable” on the second amendment. Finally, ”stable” language extensions cannot be changed unless it is to fix a grave semantic error or similar.</div><div class=""><br class=""></div><div class="">Instead (or in addition) of bumping stability on every new proposal involving the extension, we could also adopt a time (or release) based scheme.</div><div class=""><br class=""></div><div class="">Cheers,</div><div class="">Manuel</div><div class=""><br class=""></div><div class="">PS: BTW, we are pushing for getting to 6 monthly release of GHC. This means that without any guarantees across versions, we would potentially increase variability, which would be bad.<br class=""><div class=""><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="">The main reason I took a position on the issue of extension flags is to force the question: what should LANGUAGE mean? I think it's important to resolve this, to inform future decisions. Here are some options:<div class=""><br class=""></div><div class="">1. LANGUAGE fully specifies the grammar of the source file</div><div class="">2. LANGUAGE fully specifies the grammar and semantics of the source file</div><div class="">3. LANGUAGE tells the compiler what extensions are required, but otherwise provides no guarantees. The source file might not compile with a given version of GHC even if it supports all the extensions listed. In other words, LANGUAGE together with a GHC version range specifies the grammar and semantics of the source file.</div><div class=""><br class=""></div><div class="">I think what we have right now is 3, because we change the meaning of extensions from version to version of GHC. There are advantages to 1 and 2: for example, if we had 1, then we could parse all of Hackage with haskell-src-exts (or at least identify the subset of source files that can be parsed via their LANGUAGE pragmas). If we had 2, then we could parse, rename and typecheck all of Hackage using haskell-src-exts, haskel-names, and haskell-type-exts.</div><div class=""><br class=""></div><div class="">Perhaps we want to say that we can only *add* syntax to an existing extension, not change or remove it. This is a variant of 3 that requires only a lower bound on the GHC version required, not an upper bound, and it provides some of the benefits of 1 and 2: you just need a sufficiently recent version of haskell-src-exts et. al.</div><div class=""><br class=""></div><div class="">Anyway, I mainly wanted to ensure that we're clear about what LANGUAGE means. If we believe the implications of 1 and 2 are too onerous (never changing extensions), so what we want is 3, so be it.</div><div class=""><br class=""></div><div class="">Cheers</div><div class="">Simon</div><div class=""><br class=""></div></div><div class="gmail_extra"><br class=""><div class="gmail_quote">On 10 October 2017 at 03:54, Iavor Diatchki <span dir="ltr" class=""><<a href="mailto:iavor.diatchki@gmail.com" target="_blank" class="">iavor.diatchki@gmail.com</a>></span> wrote:<br class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr" class=""><div class="gmail_quote"><div dir="ltr" class=""><br class=""></div><br class=""><br class=""><div dir="ltr" class="">Hello,<div class=""><br class=""></div><div class="">my preference would be to add this to one of the existing extensions (either "explicit namespaces", or "type level operators"). </div></div><span class="HOEnZb"><font color="#888888" class=""><div dir="ltr" class=""><div class=""><br class=""></div><div class="">Iavor</div><div class=""><br class=""></div><div class=""><br class=""></div><div class=""><br class=""></div><div class=""><br class=""></div></div></font></span><div class=""><div class="h5"><br class=""><div class="gmail_quote"><div dir="ltr" class="">On Sat, Oct 7, 2017 at 11:26 AM Joachim Breitner <<a href="mailto:mail@joachim-breitner.de" target="_blank" class="">mail@joachim-breitner.de</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi Committee,<br class="">
<br class="">
the discussion has ebbed down again. I observe that a clear majority is<br class="">
in favor. I don’t think there is a need for a formal vote, so I will<br class="">
proceed with this decision.<br class="">
<br class="">
Simon M brought up the next issue: Shall we require a separate language<br class="">
extension for this, or can it go under the hood of<br class="">
`ExplicitNamespaces`?<br class="">
<br class="">
So far Simon M expressed a strong preference for the former, while I am<br class="">
inclined to prefer the latter, and would like to hear a few more<br class="">
opinions on this detail (which certainly would set precedence for<br class="">
future decisions).<br class="">
<br class="">
Richard brought up the idea of versioned language extensions; that idea<br class="">
can certainly be investigated, but better independently. We have to<br class="">
deal with this proposal with the tools we have.<br class="">
<br class="">
Greetings,<br class="">
Joachim<br class="">
<br class="">
<br class="">
Am Mittwoch, den 20.09.2017, 12:23 -0400 schrieb Joachim Breitner:<br class="">
> Hi,<br class="">
><br class="">
> the type fixity proposal<br class="">
> (<a href="https://github.com/ghc-proposals/ghc-proposals/pull/65" rel="noreferrer" target="_blank" class="">https://github.com/ghc-<wbr class="">proposals/ghc-proposals/pull/<wbr class="">65</a>)<br class="">
> was met with mixed reactions.<br class="">
><br class="">
> * I recommended rejection and Manuel strongly agrees with me.<br class="">
> * SPJ does not have strong opinions either way.<br class="">
> * Richard is in favor, and Iavor agrees.<br class="">
><br class="">
><br class="">
> Our process says “If consensus is elusive, then we vote, with the<br class="">
> Simons retaining veto power.” It looks like this might be such a case.<br class="">
> Should we go ahead and vote, or is more discussion likely to sway some<br class="">
> of us?<br class="">
><br class="">
> (I guess I can be swayed towards acceptance, especially if this<br class="">
> proposal re-uses existing syntactic idioms from export lists with<br class="">
> ExplicitNamespaces on.)<br class="">
><br class="">
> Greetings,<br class="">
> Joachim<br class="">
><br class="">
><br class="">
><br class="">
> Am Sonntag, den 27.08.2017, 20:16 +0200 schrieb Joachim Breitner:<br class="">
> > Dear Committee,<br class="">
> ><br class="">
> > Ryan Scott’s proposal to allow fixity declaration to explicitly target<br class="">
> > values or types has been brought before us:<br class="">
> > <a href="https://github.com/RyanGlScott/ghc-proposals/blob/type-infix/0000-type-infix.rst" rel="noreferrer" target="_blank" class="">https://github.com/<wbr class="">RyanGlScott/ghc-proposals/<wbr class="">blob/type-infix/0000-type-<wbr class="">infix.rst</a><br class="">
> > <a href="https://github.com/ghc-proposals/ghc-proposals/pull/65" rel="noreferrer" target="_blank" class="">https://github.com/ghc-<wbr class="">proposals/ghc-proposals/pull/<wbr class="">65</a><br class="">
> ><br class="">
> > I (the secretary) nominates myself as the shepherd, so I can right away<br class="">
> > continue giving a recommendation.<br class="">
> ><br class="">
> > I propose to reject this proposal. The main reasons are:<br class="">
> > * it is not clear if there is a real use case for this. Has anyone<br class="">
> > ever complained about the status quo?<br class="">
> > The proposal does not motivate the need for a change well enough.<br class="">
> > (There is a related bug in TH, but that bug can probably simply be<br class="">
> > fixed.)<br class="">
> > * The status quo can be sold as a feature, rather than a short-coming.<br class="">
> > Namely that an operator has a fixed fixity, no matter what namespace<br class="">
> > it lives in.<br class="">
> > This matches morally what other languages do: In Gallina, fixity<br class="">
> > is assigned to names independent of their definition, AFAIK.<br class="">
> > * There is a non-trivial implementation and education overhead, a<br class="">
> > weight that is not pulled by the gains.<br class="">
> ><br class="">
> > If we’d design Haskell from scratch, my verdict might possibly be<br class="">
> > different (but maybe we wouldn’t even allow types and values to share<br class="">
> > names then…)<br class="">
> ><br class="">
> ><br class="">
> > Please contradict me or indicate consensus by staying silent.<br class="">
> ><br class="">
> ><br class="">
> > Greetings,<br class="">
> > Joachim<br class="">
> ><br class="">
> > ______________________________<wbr class="">_________________<br class="">
> > ghc-steering-committee mailing list<br class="">
> > <a href="mailto:ghc-steering-committee@haskell.org" target="_blank" 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="">
><br class="">
> --<br class="">
> Joachim Breitner<br class="">
> <a href="mailto:mail@joachim-breitner.de" target="_blank" class="">mail@joachim-breitner.de</a><br class="">
> <a href="http://www.joachim-breitner.de/" rel="noreferrer" target="_blank" class="">http://www.joachim-breitner.<wbr class="">de/</a><br class="">
><br class="">
> ______________________________<wbr class="">_________________<br class="">
> ghc-steering-committee mailing list<br class="">
> <a href="mailto:ghc-steering-committee@haskell.org" target="_blank" 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="">
--<br class="">
Joachim Breitner<br class="">
<a href="mailto:mail@joachim-breitner.de" target="_blank" class="">mail@joachim-breitner.de</a><br class="">
<a href="http://www.joachim-breitner.de/" rel="noreferrer" target="_blank" class="">http://www.joachim-breitner.<wbr class="">de/</a><br class="">
______________________________<wbr class="">_________________<br class="">
ghc-steering-committee mailing list<br class="">
<a href="mailto:ghc-steering-committee@haskell.org" target="_blank" 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></div></div></div></div>
<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="">
<br class=""></blockquote></div><br class=""></div>
_______________________________________________<br class="">ghc-steering-committee mailing list<br class=""><a href="mailto:ghc-steering-committee@haskell.org" class="">ghc-steering-committee@haskell.org</a><br class=""><a href="https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-committee" class="">https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-committee</a><br class=""></div></blockquote></div><br class=""></div></div>_______________________________________________<br class="">ghc-steering-committee mailing list<br class=""><a href="mailto:ghc-steering-committee@haskell.org" class="">ghc-steering-committee@haskell.org</a><br class="">https://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-steering-committee<br class=""></div></blockquote></div><br class=""></body></html>