<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="">It is very fashionable to dunk on GHC language extensions but I think it is worth considering where we would be without them — probably Haskell 98 and a nice Wikipedia page explaining how influential Haskell was — a remarkable academic experiment, but practically speaking, like FP and KRC and Hope, a dead programming language.<div class=""><br class=""></div><div class="">I had a period in the late naughties away from Haskell and I thought it was great to be able to work with the familiar Haskell 98 and page in the developments as I needed them, and easily locate documentation, papers and articles on those proposals. The modularity that extensions provide is a real practical strength that is often overlooked.</div><div class=""><br class=""></div><div class="">Further to that, I find it quite difficult to get my head around the sheer vitality of Haskell today. It was tempting to conclude that Haskell2010 would be the last harrah but building Haskell code bases in 2022 is really quite different and a *much* more rewarding and more productive exercise in my opinion, thanks to generics and the ingenious exploration of newtype, especially with DerivingVia. This is really quite separate from all the work on TLP and DH — I am talking about the very practical business of building, organising and maintaining non-trivial Haskell code bases.</div><div class=""><br class=""></div><div class="">I love the way we have become keen to learn from other successes like Rust but I fear we could repeat past mistakes in a dash to force Haskell, and the Haskell community, into a particular shape so that it can compete. I think we should have more confidence in what has got us to where we are — and there is no doubt in my mind that it is the enduring vitality of Haskell that flows from its open philosophy, open to allcomers and open to creative experimentation.</div><div class=""><br class=""></div><div class="">I think the intrinsic diversity we see at all levels of the community is important to that creative process which is why I get a little despondent when I see calls to eliminate that diversity. People see the language extensions in different ways depending on the problems they are trying to solve and those problems are arising in great array of different contexts — and that feeds vitality is what keeps us moving forward (like the proverbial shark). </div><div class=""><br class=""></div><div class="">I understand that we can’t just allow ourselves to suffer a chaotic heat death and we need a continuous effort to analyse and organise, but I look at the diversity of thought and approaches and see the basis of a vibrant future. I just ask that we seek to organise and not to develop a monoculture.</div><div class=""><br class=""></div><div class="">Which is all by way of saying that I think the diversity we see in the extensions and the different ways of understanding them as important to the whole enterprise and take care with any drives to rationalise them into a more coherent structure. </div><div class=""><br class=""></div><div class="">Chris</div><div class=""><br class=""></div><div class=""><div class=""><div class=""><div><br class=""><blockquote type="cite" class=""><div class="">On 13 Dec 2022, at 09:59, Simon Peyton Jones <<a href="mailto:simon.peytonjones@gmail.com" class="">simon.peytonjones@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class=""><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div class="gmail_default" style="font-family:tahoma,sans-serif">
Thanks Richard for answering more comprehensively than I could have done
myself. Simon: do you feel that Richard's email answers your question?
</div></blockquote><div class=""><br class=""></div><div style="font-family:tahoma,sans-serif" class="gmail_default">It contributes to an answer. <br class=""></div><div style="font-family:tahoma,sans-serif" class="gmail_default"><br class=""></div><div style="font-family:tahoma,sans-serif" class="gmail_default"><b class="">The problem(s) we seek to solve</b></div><div style="font-family:tahoma,sans-serif" class="gmail_default"><br class=""></div><div style="font-family:tahoma,sans-serif" class="gmail_default">Richard says</div><div style="font-family:tahoma,sans-serif" class="gmail_default"><br class=""></div><div style="font-family:tahoma,sans-serif" class="gmail_default">We, as a committee, struggle to figure out a policy around extensions. This policy would help inform decisions such as:<div class=""> * whether proposal X needs to come with an extension, can modify a previous one, or needs no extension at all</div><div class=""> * how to evolve the set of extensions that are part of GHC20XX / the default set of extensions</div><div class="">Beyond these real-world challenges that the committee has faced, we might also want to consider</div><div class=""> *
how better to communicate the role extensions play in the Haskell
language (anecdotes suggest the current story is off-putting to
newcomers)</div><div class=""> * whether some extensions ought to be retired</div><div class=""><br class=""></div><div class="">I'm OK with those as goals, although I have not found myself stuck on them. E.g. most proposals do come with an extension because they are, well, an extension. And user opinions frankly differ about the value and tempo of GHC20XX.<br class=""></div><div class=""><br class=""></div><div class=""><b class="">The proposed solution(s)</b></div><div class=""><br class=""></div><div class="">Richard comes up with a couple of categorisations, which are indeed helpful. But he stops short of any concrete proposals.</div><div class=""><br class=""></div><div class="">
<div class="">1. Declare that extensions are <b class="">experimental language features</b>,
being evaluated for inclusion in the language proper. Gating some new
syntax behind an extension theoretically allows us to experiment,
improve, etc., until we are happy, and then we merge the feature into
the language, with no extension needed.</div><div class="">2. Declare that
extensions are <b class="">configuration flags</b>, meant to exist in perpetuity. In
this way, extensions are a more powerful form of warning flag: not only
can they dictate which programs are accepted, but sometimes they can be
used to change the semantics of an accepted program.</div><div class="">3. Organize the set of extensions around an idea of <b class=""><i class="">language levels</i></b><span style="font-style:normal" class="">, where we classify different extensions according to the expected level of expertise of users working in the extended language.</span></div><div class=""><span style="font-style:normal" class=""><br class=""></span></div><div class=""><span style="font-style:normal" class="">These aren't either/or choices. It's clear that <br class=""></span></div><div class=""><ul class=""><li class=""><span style="font-style:normal" class="">some really are configuration flags (Safe, RebindableSyntax; maybe punning)<br class=""></span></li><li class=""><span style="font-style:normal" class="">some are definitely local, thin ice (UndecidableSuperclasses) -- the more we can turn these into local modifiers the better</span></li><li class=""><span style="font-style:normal" class="">some are really part of the language we'd like to see (PolyKinds, MultiParamTypeClasses)</span></li><li class=""><span style="font-style:normal" class="">some are experimental in the "Haskell as a laboratory" sense (Linear)</span></li></ul><div class="">I think that <i class="">classifying </i>them might be helpful; <i class="">choosing one </i>of these paths over the others seems infeasible to me.</div><div class=""><br class=""></div></div></div><div class=""><b class="">What next?</b></div><div class=""><br class=""></div><div class="">I suppose the next step is for some motivated person to write a draft policy paper, so we can say "This is the GHC steering committee's policy on extensions". Maybe it too can be a GHC proposal (rather like the design principles one). It can certainly include the categorisations Richard suggests.<br class=""></div><div class=""><br class=""></div><div class="">Simon<br class=""></div><div class=""><br class=""></div><div class=""><br class=""></div>
</div></div><br class=""><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Tue, 13 Dec 2022 at 09:43, Arnaud Spiwack <<a href="mailto:arnaud.spiwack@tweag.io" class="">arnaud.spiwack@tweag.io</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr" class="">Thanks Richard for answering more comprehensively than I could have done myself. Simon: do you feel that Richard's email answers your question?<br class=""></div><br class=""><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, 9 Dec 2022 at 19:57, 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:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hi,<br class="">
<br class="">
this categorization is very helpful, I’ve been thinking about that as<br class="">
well recently. Especially it’s worth keeping in mind that some language<br class="">
extensions probably wouldn’t be language extensions these days, but<br class="">
some other kind of flag (CPP, Safe, Trustworthy), and as you say<br class="">
shouldn’t get in the way of finding a more coherent story for the<br class="">
others.<br class="">
<br class="">
I think we should keep separate the category<br class="">
<br class="">
F: Enables new language features with not just a local (usually)<br class="">
syntactic effect. (Litmus test: will a user of a module with that<br class="">
extension tell). Mostly all the type-level feature extension (GADTs,<br class="">
LinearTypes, TypeFamilies etc.)<br class="">
<br class="">
Some of these are also guarded by “new syntax” of sorts, but I think<br class="">
they are fundamentally different from your category A. These are, in a<br class="">
way, the most interesting ones!<br class="">
<br class="">
Cheers,<br class="">
Joachim<br class="">
<br class="">
Am Freitag, dem 09.12.2022 um 14:21 +0000 schrieb Richard Eisenberg:<br class="">
> Glancing through the list of extensions, I see a few broad<br class="">
> categories:<br class="">
> <br class="">
> A. Extensions that simply enable new syntax. If users still want fine<br class="">
> control over whether this syntax is allowed, each such extension<br class="">
> could be converted to a warning -- but then all these extensions<br class="">
> (except ones that are still experimental!) would be on by default.<br class="">
> Maybe the warnings would be -Werror by default -- not sure. Examples:<br class="">
> GADTSyntax, Arrows, InstanceSigs, StandaloneDeriving, and many more.<br class="">
> <br class="">
> B. Extensions that allow violation of some general principle that<br class="">
> holds elsewhere. These should be replaced by modifiers or pragmas and<br class="">
> be enabled locally. Examples: OverlappingInstances (this is already<br class="">
> done!), NoMonomorphismRestriction, DeepSubsumption(*),<br class="">
> UndecidableSuperClasses, NoMonoLocalBinds, etc.<br class="">
> <br class="">
> (*): Given the hue and cry about this one, perhaps there should be a<br class="">
> flag to control the behavior.<br class="">
> <br class="">
> C. Extensions that change the compilation pipeline. These need to<br class="">
> remain as configuration flags. Examples: CPP, TemplateHaskell.<br class="">
> <br class="">
> D. Extensions that create variants of the language by changing<br class="">
> semantics of existing constructs. I'm not quite sure what to do with<br class="">
> these, but they probably need to remain configuration flags. Even<br class="">
> better if they could be enabled locally within a file, though. We<br class="">
> should probably try to avoid doing this in the future, though the<br class="">
> pain may be worth it. Examples: RebindableSyntax, Strict,<br class="">
> OverloadedXXX, etc.<br class="">
> <br class="">
> Maybe some extensions fail to be categorized here, but this covers<br class="">
> the vast, vast majority.<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.de/</a><br class="">
<br class="">
_______________________________________________<br class="">
ghc-steering-committee mailing list<br class="">
<a href="mailto:ghc-steering-committee@haskell.org" target="_blank" class="">ghc-steering-committee@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-bin/mailman/listinfo/ghc-steering-committee</a><br class="">
</blockquote></div>
_______________________________________________<br class="">
ghc-steering-committee mailing list<br class="">
<a href="mailto:ghc-steering-committee@haskell.org" target="_blank" class="">ghc-steering-committee@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-bin/mailman/listinfo/ghc-steering-committee</a><br class="">
</blockquote></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=""></div></div></div></body></html>