<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Thu, Oct 22, 2015 at 11:36 AM, Geoffrey Mainland <span dir="ltr"><<a href="mailto:mainland@apeiron.net" target="_blank">mainland@apeiron.net</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">On 10/22/2015 11:02 AM, Matthias Hörmann wrote:<br>
> I would say that the need to import Control.Applicative in virtually<br>
> every module manually<br>
> definitely caused some pain before AMP.<br>
<br>
</span>In this particular case, there is a trade off between breaking code on<br>
the one hand and having to write some import statements on the other. I<br>
find writing some extra imports less painful than breaking (other<br>
people's and my) code, but the other position is defensible as well. I<br>
sense that I am in the minority, at least on the libraries list.<br>
<span class=""><br>
> I would also argue that a<br>
> non-negligible amount<br>
> of effort goes into teaching the warts, the reasons for the warts and<br>
> how to work around them.<br>
<br>
</span>Which wart(s) in particular? All of them? Does having return (and (>>))<br>
in Monad make teaching more difficult?<br></blockquote><div><br></div><div>Having (>>) means that we have hundreds of monads out there where (>>) has been optimized, but (*>) has not.  </div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">If I were working alone, AMP wouldn't be a huge deal. I could fix the<br>
code for 7.10 compatibility, but then unless everyone switches to 7.10,<br>
changes to the codebase made by someone using 7.8, e.g., defining a new<br>
Monad instance, could break things on 7.10 again. It's easier to stick<br>
with 7.8. Any time spent dealing with compatibility issues is time not<br>
spent writing actual code.<br></blockquote><div><br></div><div>In the open source world many of us just fire off our code to travis-ci and get it to build with a dozen different compiler versions. I maintain a lot of code that supports things back to 7.0 and forward to HEAD this way.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
I outlined one possible path to avoid this kind of issue: spend more<br>
time thinking about ways to maintain compatibility. We had proposals for<br>
doing this with AMP.<br></blockquote><div><br></div><div>And on the other hand we also had a concrete proposal that didn't require language changes that was ridiculously popular. People had been talking about Applicative as a superclass of Monad for a decade before we finally acted upon the AMP. People had been talking about superclass defaulting for a decade. When do you cut off discussion and ship the proposal that has overwhelming support? If there is no process that enables this you can stall the process indefinitely by raising objections of this form. Such a situation is not without costs all its own.</div><div><br></div><div>-Edward</div><div> <br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Cheers,<br>
Geoff<br>
<div class="HOEnZb"><div class="h5"><br>
><br>
> On Thu, Oct 22, 2015 at 3:29 PM, Geoffrey Mainland <<a href="mailto:mainland@apeiron.net">mainland@apeiron.net</a>> wrote:<br>
>> On 10/22/2015 02:40 AM, Edward Kmett wrote:<br>
>>> On Wed, Oct 21, 2015 at 8:42 PM, Gregory Collins<br>
>>> <<a href="mailto:greg@gregorycollins.net">greg@gregorycollins.net</a> <mailto:<a href="mailto:greg@gregorycollins.net">greg@gregorycollins.net</a>>> wrote:<br>
>>><br>
>>><br>
>>>     On Wed, Oct 21, 2015 at 3:18 PM, Geoffrey Mainland<br>
>>>     <<a href="mailto:mainland@apeiron.net">mainland@apeiron.net</a> <mailto:<a href="mailto:mainland@apeiron.net">mainland@apeiron.net</a>>> wrote:<br>
>>><br>
>>>         My original email stated my underlying concern: we are losing<br>
>>>         valuable<br>
>>>         members of the community not because of the technical<br>
>>>         decisions that are<br>
>>>         being made, but because of the process by which they are being<br>
>>>         made.<br>
>>><br>
>>>     [If] you're doing research you're on the treadmill, almost by<br>
>>>     definition, and you're delighted that we're finally making some<br>
>>>     rapid progress on fixing up some of the longstanding warts.<br>
>>><br>
>>>     If you're a practitioner, you are interested in using Haskell for,<br>
>>>     y'know, writing programs. You're probably in one of two camps:<br>
>>>     you're in "green field" mode writing a lot of new code (early<br>
>>>     stage startups, prototype work, etc), or you're<br>
>>>     maintaining/extending programs you've already written that are out<br>
>>>     "in the field" for you doing useful work. Laura Wingerd calls this<br>
>>>     the "annealing temperature" of software, and I think this is a<br>
>>>     nice metaphor to describe it. How tolerant you are of ecosystem<br>
>>>     churn depends on what your temperature is: and I think it should<br>
>>>     be obvious to everyone that Haskell having "success" for<br>
>>>     programming work would mean that lots of useful and correct<br>
>>>     programs get written, so everyone who is in the former camp will<br>
>>>     cool over time to join the latter.<br>
>>><br>
>>><br>
>>>     I've made the point before and I don't really want to belabor it:<br>
>>>     our de facto collective posture towards breaking stuff, especially<br>
>>>     in the past few years, has been extremely permissive, and this<br>
>>>     alienates people who are maintaining working programs.<br>
>>><br>
>>><br>
>>> Even among people who purported to be teaching Haskell or using<br>
>>> Haskell today in industry the margin of preference for the concrete<br>
>>> FTP proposal was ~79%. This was considerably higher than I expected in<br>
>>> two senses. One: there were a lot more people who claimed to be in one<br>
>>> of those two roles than I expected by far, and two: their appetite for<br>
>>> change was higher than I expected. I initially expected to see a<br>
>>> stronger "academic vs. industry" split in the poll, but the groups<br>
>>> were only distinguishable by a few percentage point delta, so while I<br>
>>> expected roughly the end percentage of the poll, based on the year<br>
>>> prior I'd spent running around the planet to user group meetings and<br>
>>> the like, I expected it mostly because I expected more hobbyists and<br>
>>> less support among industrialists.<br>
>>><br>
>>>     I'm actually firmly of the belief that the existing committee<br>
>>>     doesn't really have process issues, and in fact, that often it's<br>
>>>     been pretty careful to minimize the impact of the changes it wants<br>
>>>     to make. As others have pointed out, lots of the churn actually<br>
>>>     comes from platform libraries, which are out of the purview of<br>
>>>     this group.<br>
>>><br>
>>><br>
>>> Historically we've had a bit of a split personality on this front.<br>
>>> Nothing that touches the Prelude had changed in 17 years. On the other<br>
>>> hand the platform libraries had maintained a pretty heavy rolling wave<br>
>>> of breakage the entire time I've been around in the community. On a<br>
>>> more experimental feature front, I've lost count of the number of<br>
>>> different things we've done to Typeable or template-haskell.<br>
>>><br>
>>><br>
>>>     All I'm saying is that if we want to appeal to or cater to working<br>
>>>     software engineers, we have to be a lot less cavalier about<br>
>>>     causing more work for them, and we need to prize stability of the<br>
>>>     core infrastructure more highly. That'd be a broader cultural<br>
>>>     change, and that goes beyond process: it's policy.<br>
>>><br>
>>><br>
>>> The way things are shaping up, we've had 17 years of rock solid<br>
>>> stability, 1 release that incorporated changes that were designed to<br>
>>> minimize impact, to the point that the majority of the objections<br>
>>> against them are of the form where people would prefer that we broke<br>
>>> _more_ code, to get a more sensible state. Going forward, it looks<br>
>>> like the next 2 GHC releases will have basically nothing affecting the<br>
>>> Prelude, and there will be another punctuation in the equilibrium<br>
>>> around 8.4 as the next set of changes kicks in over 8.4 and 8.6 That<br>
>>> gives 2 years worth of advance notice of pending changes, and a pretty<br>
>>> strong guarantee from the committee that you should be able to<br>
>>> maintain code with a 3 release window without running afoul of<br>
>>> warnings or needing CPP.<br>
>>><br>
>>> So, out of curiosity, what additional stability policy is it that you<br>
>>> seek?<br>
>> Thanks to you and Dan [1], I now have a greater understanding and<br>
>> appreciation for where the committee has been coming from. My new<br>
>> understanding is that the changes that were formalized in AMP, FTP, and<br>
>> MRP were the basis for the committee's creation. It also seems that<br>
>> there are more changes in the pipeline that have not yet been made into<br>
>> proposals, e.g., pulling (>>) out of Control.Monad [2]. Part of<br>
>> "stability" is signaling change as far ahead as possible. The committee<br>
>> has put a lot of effort into this, which I appreciate! However, as each<br>
>> of these proposal has come down the pipeline, I never realized that they<br>
>> were part of a larger master plan.<br>
>><br>
>> 1) What is the master plan, and where is it documented, even if this<br>
>> document is not up to the standard of a proposal? What is the final<br>
>> target, and when might we expect it to be reached? What is in the<br>
>> pipeline after MRP?<br>
>><br>
>> Relatedly, guidance on how to write code now so that it will be<br>
>> compatible with future changes helps mitigate the stability issue.<br>
>><br>
>> 2) How can I write code that makes use of the Prelude so that it will<br>
>> work with every new GHC release over the next 3 years? 5 years? For<br>
>> example, how can I write a Monad instance now, knowing the changes that<br>
>> are coming, so that the instance will work with every new GHC release<br>
>> for the next 3 years? 5 years? If the answer is "you can't," then when<br>
>> might I be able to do such a thing? As of 8.4? 8.6? I'm embarrassed to<br>
>> say I don't know the answer!<br>
>><br>
>> Finally, if none of these changes broke Prelude backwards compatibility,<br>
>> far fewer people would be complaining :) Of course, we can't always make<br>
>> progress without breaking things, but a more deliberative process might<br>
>> offer an opportunity to make progress while still preserving backwards<br>
>> compatibility. Take AMP for example. There were at least two [3] [4]<br>
>> proposals for preserving backwards compatibility. Investigating them<br>
>> would have taken time and delayed AMP, yes, but why the rush?<br>
>><br>
>> 3) Can we have a process that allows more deliberation over, and wider<br>
>> publicity for, changes that break backwards compatibility? The goal of<br>
>> such a process would not be to prevent change, but to allow more time to<br>
>> find possible solution to the issue of backwards compatibility.<br>
>><br>
>> My proposal for a low-traffic mailing list where all proposals were<br>
>> announced was meant to provide wider publicity.<br>
>><br>
>> Personally, I think these proposals do indeed fix a lot of warts in the<br>
>> language. As a researcher who uses actively uses Haskell every day,<br>
>> these warts have had approximately zero impact on me for the past<br>
>> (almost) decade, and I would be perfectly content if they were never<br>
>> fixed. The only pain I can recall enduring is having to occasionally<br>
>> write an orphan Applicative instance. I have been importing Prelude<br>
>> hiding mapM for years. I have been importing Control.Applicative for<br>
>> years. Neither has been painful. Dealing with AMP? I'm working on a<br>
>> collaborative research project that is stuck on 7.8 because of AMP. I<br>
>> agree, that seems silly, but whether or not it is silly, it is an impact<br>
>> I feel.<br>
>><br>
>> One way to look at these proposals is to ask the question "Wouldn't the<br>
>> language be nicer if all these changes were made?" Another is to ask the<br>
>> question "Does the fact that these changes have not been made make your<br>
>> life as a Haskell programmer more difficult in any significant way?" I<br>
>> answer "yes" to the former and "no" to the latter. Is our stance that<br>
>> answering "yes" to the former question is enough to motivate braking<br>
>> change? Shouldn't a answer "no" to the latter question cause some<br>
>> hesitation?<br>
>><br>
>> Maybe there are a lot of people who answer "yes" to both questions. I<br>
>> would like to know! But does having return in the Monad class really<br>
>> cause anyone anything other than existential pain?<br>
>><br>
>> Cheers,<br>
>> Geoff<br>
>><br>
>> [1] <a href="https://mail.haskell.org/pipermail/libraries/2015-October/026390.html" rel="noreferrer" target="_blank">https://mail.haskell.org/pipermail/libraries/2015-October/026390.html</a><br>
>> [2] <a href="https://mail.haskell.org/pipermail/libraries/2015-September/026158.html" rel="noreferrer" target="_blank">https://mail.haskell.org/pipermail/libraries/2015-September/026158.html</a><br>
>> [3] <a href="https://ghc.haskell.org/trac/ghc/wiki/InstanceTemplates" rel="noreferrer" target="_blank">https://ghc.haskell.org/trac/ghc/wiki/InstanceTemplates</a><br>
>> [4] <a href="https://ghc.haskell.org/trac/ghc/wiki/IntrinsicSuperclasses" rel="noreferrer" target="_blank">https://ghc.haskell.org/trac/ghc/wiki/IntrinsicSuperclasses</a><br>
<br>
_______________________________________________<br>
</div></div><div class="HOEnZb"><div class="h5">Haskell-prime mailing list<br>
<a href="mailto:Haskell-prime@haskell.org">Haskell-prime@haskell.org</a><br>
<a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-prime" rel="noreferrer" target="_blank">http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-prime</a><br>
</div></div></blockquote></div><br></div></div>