<div dir="ltr">I also think it's better to have all the discussion in one place. However, I think it would be beneficial to preserve the following two features of the current process:<div><br><div> 1. Proposals are still submitted to the committee for review (and we get an e-mail about it). This is useful for me, as while I sometimes read through proposals if I have some free time, I certainly don't track all of them all the time. But I do go and read them once Joachim sends the e-mail that we should be discussing them.</div><div><br></div><div> 2. I think it would be good to try to keep the committee discussion on Github more or less restricted to the committee and the proposal author. I think this would help keep steer discussions towards termination (which is sometimes difficult even when we are restricted to just the committee :-)</div><div><br></div><div>Finally, I'd say that if we are going to discuss things on Github, then we should probably make the mailing list private, since it won't really contain any information of interest to the community. And, it would make it possible to have a private discussion, if we need to (of course, we could do that anyway by e-mailing everyone explicitly, but that's a bit of a pain).</div><div><br></div><div>On the topic of delay: to me it feels that a lot of the time when we have a long delay, is when there isn't a clear consensus in the committee about what to do---I am not sure what we can do about it. My personal preference is that in such cases we should reject "new features" and accept "incomplete fixes", but of course we just have to deal with it on a case by case basis.</div><div><br></div><div>-Iavor</div><div><br></div><div><br></div><div><br></div><div><br></div><div><br></div><div><br></div><div><br></div></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Apr 17, 2019 at 8:16 AM Eric Seidel <<a href="mailto:eric@seidel.io">eric@seidel.io</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">The cost/benefit and audience points are important issues that we have to consider when evaluating a proposal, but I'm not sure that they are that relevant to this particular situation.<br>
<br>
It seems like the big issue apart from the delay (which I think we can all agree is a problem) was a failure of communication. We were under the impression that rejecting the programs would also solve Matthew's problem, but it seems we were mistaken. I think that alone points to the need for a more flexible process than an up-or-down decision.<br>
<br>
I like Joachim's first suggestion for point 3, that we deliberate on the list, present an initial response, and invite a rebuttal from the author before making a final decision. I think that keeping our initial deliberations on the list makes sense because it provides a more focussed forum for us to discuss the proposal. But I don't feel too strongly about deliberating on the list vs github.<br>
<br>
Thank you for sharing your frustrations with us, Matthew. We all appreciate the work you do.<br>
<br>
Eric<br>
<br>
On Wed, Apr 17, 2019, at 07:02, Simon Peyton Jones via ghc-steering-committee wrote:<br>
> Thanks Joachim - and thank you Matthew for taking the trouble to write.<br>
> <br>
> Some brief responses<br>
> <br>
> * I don't see any reason to conduct a conversation on the steering<br>
> committee email list, rather than on the Github converation. In<br>
> fact doing it by email is *less* good because the discussion is in<br>
> two places. The only reason to do so would be to have a private<br>
> conversation -- but the email list is by design public. So yes<br>
> to Github; and let's explicitly invite the author to participate<br>
> in the conversation if they wish.<br>
> <br>
> * Delay. This is a challenge because everyone is a volunteer and<br>
> everyone is busy. Should I spend the next 30 mins reviewing a<br>
> GHC proposal or a patch that fixes a bug? That delay is hard on <br>
> the author, but I see no way to fully solve that tension.<br>
> <br>
> * Cost and benefit. The biggest tension I feel is that every incremental<br>
> change to the language makes it more complicated, makes the compiler<br>
> more complicated, and imposes a new maintenance burden on the<br>
> implementors, forever. There are many features I value (e.g. partial<br>
> type signatures, or pattern synonyms) whose authors have long since<br>
> moved on, and I am the de-facto maintainer.<br>
> <br>
> It's not wrong to move on. It's a huge service for someone to propose,<br>
> design, and implement something. But is genuinely difficult to balance<br>
> the immediate benefits (esp to the author) against the long-term costs.<br>
> <br>
> * Audience. Sometimes the population that genuinely wants a feature is<br>
> pretty small. That does not make it a bad proposal -- sometimes people<br>
> don't know they want something till it's there. But it does make it<br>
> harder to generate the time and energy to dig into the technical details.<br>
> <br>
> It may be that we could articulate some of these tensions on our wiki pages.<br>
> Doing so won't solve them but might help people to feel less badly treated.<br>
> And THAT is a very important goal.<br>
> <br>
> Matthew: you are a major contributor to GHC -- thank you!<br>
> <br>
> Simon<br>
> <br>
> <br>
> | -----Original Message-----<br>
> | From: ghc-steering-committee <<a href="mailto:ghc-steering-committee-bounces@haskell.org" target="_blank">ghc-steering-committee-bounces@haskell.org</a>><br>
> | On Behalf Of Joachim Breitner<br>
> | Sent: 17 April 2019 11:30<br>
> | To: <a href="mailto:ghc-steering-committee@haskell.org" target="_blank">ghc-steering-committee@haskell.org</a><br>
> | Cc: Matthew Pickering <<a href="mailto:matthewtpickering@gmail.com" target="_blank">matthewtpickering@gmail.com</a>><br>
> | Subject: [ghc-steering-committee] Unhappy proposers<br>
> | <br>
> | Dear Committee,<br>
> | <br>
> | I have received an email from one of our most productive proposal writers,<br>
> | Matthew, who we have left quite unhappy with the process, and I hope we<br>
> | can take the time to see what went wrong, and what we can do differently<br>
> | to not be wasteful with the motivation of the Matthews out there.<br>
> | <br>
> | Matthew asked me to paraphrase his complaints, just to get this started on<br>
> | a productive tone. So I’ll play annoyance tone firewall.<br>
> | <br>
> | The PR in question is #207 (Fix the treatment of type variables in<br>
> | quotations), and he has three main reasons why he is unsatsified:<br>
> | <br>
> | <br>
> | 1. Delay<br>
> | ========<br>
> | <br>
> | There was a long delay between consensus on the mailing list (March 7) and<br>
> | the official announcement on GitHub.<br>
> | <br>
> | <br>
> | This is clearly true, and is purely on me, and I am sorry for that.<br>
> | <br>
> | I try to do a monthly sweep of the committee activities, including closing<br>
> | or accepting proposals where I did not do it directly, but well, the last<br>
> | month turned out to be 90 days or so … I will try to be better here, but<br>
> | also appreciate nudges.<br>
> | <br>
> | Also, shepherds, if you detect consensus, feel encouraged to respond to<br>
> | the list with “Looks like we can accept/reject this, Joachim, can you do<br>
> | it?” Then I am likely to do the bureaucratic acts directly.<br>
> | <br>
> | <br>
> | 2. Lack of understanding<br>
> | ========================<br>
> | <br>
> | Matthew has the impression that the itch he was trying to scratch, the<br>
> | overall needs of Typed Template Haskell (a still rarely used feature, but<br>
> | dear to his hard) and his solutions are not well understood.<br>
> | <br>
> | <br>
> | I am not in a position (and this is maybe not the right thread) to judge<br>
> | who is wrong and who is right. And maybe that is partly the<br>
> | point: Not the whole committee is in a position to understand the<br>
> | implications of a change to, say, Typed Template Haskell. Do we need to<br>
> | adjust our process to that somehow? How do we deal with that?<br>
> | <br>
> | Also, I think we can recognize that we should not underestimate the<br>
> | motivation and the actual needs of the people who sit down and write<br>
> | proposals, and assume good faith. Matthew says that the bug he tries to<br>
> | fix here does affect his actual work, and in particular that our solution<br>
> | (forbid type variables in splices) does not actually solve his problem.<br>
> | <br>
> | <br>
> | 3. Lack of communication<br>
> | ========================<br>
> | <br>
> | Finally, Matthew points out that some of the reasons that led to the<br>
> | rejection were not properly discussed with him as the author first.<br>
> | <br>
> | <br>
> | I agree that this is a problematic pattern, and one that I have observed a<br>
> | few times too: A proposal gets proposed, the shepherd recommends rejection<br>
> | (or the discussion veers in that direction), we discuss the pros and cons,<br>
> | and then just reject it. I understand how a proposer might feel helpless<br>
> | in that situation.<br>
> | <br>
> | Worse, they see that proposals by committee members have an easier time,<br>
> | because then the committee member happens to be on the list and can defend<br>
> | and explain their proposal better. (This point was not raised by Matthew,<br>
> | but added by me).<br>
> | <br>
> | <br>
> | Luckily, I think this problem can be solved in a procedural way.<br>
> | <br>
> | Procedural proposal A:<br>
> | <br>
> | When a shepherd intents to proposal rejecting a proposal, he first<br>
> | writes his rationale on the Github discussion thread and waits for<br>
> | the author’s rebuttal. This can (and is encouraged) to lead to a<br>
> | discussion between shepherd and authors (and any further interesting<br>
> | party or committee member) with one of these outcomes:<br>
> | * the shepherd is swayed and proposes acceptance,<br>
> | * the proposal is improved and the shepherd can propose to accept<br>
> | it,<br>
> | * the authors withdraw the proposal,<br>
> | * no agreement can be reached, and the discussion comes to an end.<br>
> | Now the shepherd may propose rejecting to the committee.<br>
> | <br>
> | <br>
> | I think this process would give the authors a bigger say and role, more<br>
> | insight and warning into a possible rejection, and thus hopefully better<br>
> | satisfaction in the end.<br>
> | <br>
> | <br>
> | A simpler variant of that with a similar result would be something we have<br>
> | discussed earlier:<br>
> | <br>
> | Procedural proposal B:<br>
> | <br>
> | The committee discusses proposals on Github; the mailing list is<br>
> | only used for announcement (new proposal and shepherd assignment,<br>
> | shepherd’s recommendation, decision, status messages,<br>
> | metadiscussions like this one.)<br>
> | <br>
> | <br>
> | What are you opinions here?<br>
> | <br>
> | Matthew, would any of these procedures have given you a better experience<br>
> | and/or outcome?<br>
> | <br>
> | <br>
> | I hope we can turn Matthew’s bad experience into something with a<br>
> | productive outcome!<br>
> | <br>
> | (Note that I have not included all technical details of Matthew’s email<br>
> | here, to keep this focused on the procedural problems he points out.<br>
> | Matthew, maybe you can raise the good technical points on Github<br>
> | separately?)<br>
> | <br>
> | <br>
> | Cheers,<br>
> | Joachim<br>
> | <br>
> | <br>
> | <br>
> | --<br>
> | Joachim Breitner<br>
> | <a href="mailto:mail@joachim-breitner.de" target="_blank">mail@joachim-breitner.de</a><br>
> | <a href="http://www.joachim-breitner.de/" rel="noreferrer" target="_blank">http://www.joachim-breitner.de/</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>
><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>