<div dir="ltr"><div><div><div><div><div><div>I'm slightly against this proposal.  I think the reasons you gave *are* sufficient to reject it, moreover there's the additional overhead of another extension - complexity in the compiler, and cognitive overhead for programmers. Extensions aren't cheap, or at least they're not cheap enough to justify making extensions for subsets of existing extensions to cover narrow use cases like this.<br></div></div></div><br></div>Yes ScopedTypeVariables might break some code if you enable it, but I think we should all just enable it everywhere and move on. That leaves the cases where you might be working in some legacy codebase where you want to make a small change and are tempted to enable PatternSignatures because ScopedTypeVariables breaks the code somewhere else - just do without it, or enable ScopedTypeVariables and fix the breakage. I am not sympathetic to your plight :)<br><br></div>Cheers<br></div>Simon<br></div><div class="gmail_extra"><br><div class="gmail_quote">On 1 May 2018 at 01:13, Christopher Allen <span dir="ltr"><<a href="mailto:cma@bitemyapp.com" target="_blank">cma@bitemyapp.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">This proposal splits out the faculty for assigning type signatures to<br>
variables destructured out of a pattern from ScopedTypeVariables.<br>
<br>
<a href="https://github.com/ghc-proposals/ghc-proposals/pull/119/" rel="noreferrer" target="_blank">https://github.com/ghc-<wbr>proposals/ghc-proposals/pull/<wbr>119/</a><br>
<br>
My recommendation is to accept the proposal, with some reservations.<br>
<br>
ScopedTypeVariables is one of the more popular candidates for "this<br>
should always be on regardless." The cases in which STV would be<br>
useful greatly outnumber the downsides Gundry cited in my experience.<br>
My impression of this upheld by my industrial experience and that of<br>
the other industrial programmers I've talked to in the past about<br>
ScopedTypeVariables. Almost any time it is brought up almost<br>
invariably the conversation touches on, "why isn't this on by<br>
default?"<br>
<br>
I understand STV could break programs with overlapping names that are<br>
intended to be independent type variables, I don't presume to litigate<br>
or resolve that issue here.<br>
<br>
Extension fatigue is wearing on the Haskell users I regularly interact<br>
with, especially as it's unclear if Haskell Prime will convene and<br>
consolidate commonly used extensions into the core language.<br>
<br>
In my view these aren't sufficient reason to reject the proposed<br>
extension on the merits so my recommendation is to accept it as-is. I<br>
think the case for this proposal is particularly strong as it would<br>
clean up the extension's presently somewhat confusing relationship<br>
with STV.<br>
<br>
If no objections are raised, it should be assumed that this has the<br>
assent of the committee.<br>
<span class="HOEnZb"><font color="#888888"><br>
-- <br>
Chris Allen<br>
______________________________<wbr>_________________<br>
ghc-steering-committee mailing list<br>
<a href="mailto:ghc-steering-committee@haskell.org">ghc-steering-committee@<wbr>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-<wbr>bin/mailman/listinfo/ghc-<wbr>steering-committee</a><br>
</font></span></blockquote></div><br></div>