<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:Consolas;
        panose-1:2 11 6 9 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        margin-bottom:.0001pt;
        font-size:12.0pt;
        font-family:"Times New Roman",serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
p
        {mso-style-priority:99;
        mso-margin-top-alt:auto;
        margin-right:0cm;
        mso-margin-bottom-alt:auto;
        margin-left:0cm;
        font-size:12.0pt;
        font-family:"Times New Roman",serif;}
pre
        {mso-style-priority:99;
        mso-style-link:"HTML Preformatted Char";
        margin:0cm;
        margin-bottom:.0001pt;
        font-size:10.0pt;
        font-family:"Courier New";}
p.msonormal0, li.msonormal0, div.msonormal0
        {mso-style-name:msonormal;
        mso-margin-top-alt:auto;
        margin-right:0cm;
        mso-margin-bottom-alt:auto;
        margin-left:0cm;
        font-size:12.0pt;
        font-family:"Times New Roman",serif;}
span.HTMLPreformattedChar
        {mso-style-name:"HTML Preformatted Char";
        mso-style-priority:99;
        mso-style-link:"HTML Preformatted";
        font-family:Consolas;
        mso-fareast-language:EN-GB;}
span.EmailStyle22
        {mso-style-type:personal-reply;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:72.0pt 72.0pt 72.0pt 72.0pt;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-GB" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;mso-fareast-language:EN-US">I don’t believe I made this commit, or the ones around it.   Mysterious; I hope I’m not being impersonated!<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;mso-fareast-language:EN-US">Simon<o:p></o:p></span></p>
<p class="MsoNormal"><a name="_MailEndCompose"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;mso-fareast-language:EN-US"><o:p> </o:p></span></a></p>
<p class="MsoNormal"><b><span lang="EN-US" style="font-size:11.0pt;font-family:"Calibri",sans-serif">From:</span></b><span lang="EN-US" style="font-size:11.0pt;font-family:"Calibri",sans-serif"> noreply@phabricator.haskell.org [mailto:noreply@phabricator.haskell.org]
<br>
<b>Sent:</b> 08 July 2016 20:43<br>
<b>To:</b> Simon Peyton Jones <simonpj@microsoft.com><br>
<b>Subject:</b> [Diffusion] [Committed] rCABAL2863a628f857: Add two local type signatures<o:p></o:p></span></p>
<p class="MsoNormal"><o:p> </o:p></p>
<table class="MsoNormalTable" border="0" cellspacing="5" cellpadding="0">
<tbody>
<tr>
<td style="padding:.75pt .75pt .75pt .75pt">
<p class="MsoNormal">simonpj committed rCABAL2863a628f857: Add two local type signatures (authored by simonpj).
<o:p></o:p></p>
</td>
</tr>
</tbody>
</table>
<p class="MsoNormal"><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><o:p> </o:p></span></p>
<div>
<div>
<p>Add two local type signatures<o:p></o:p></p>
<p>I'm adding these type signatures to satisfy the "do not generalise<br>
local let/where" rule that GHC is taking on.<o:p></o:p></p>
<p>The signatures are clearly correct, but I was surprised at the <br>
polymorphism needed. For example<o:p></o:p></p>
<p>parseOptVersion :: ReadP r Version<br>
parseOptVersion = parseQuoted ver <++ ver<o:p></o:p></p>
<div style="margin-top:9.0pt;margin-bottom:9.0pt">
<pre style="line-height:11.25pt"><span style="font-size:8.5pt;font-family:Consolas">where ver :: ReadP r Version<o:p></o:p></span></pre>
<pre style="line-height:11.25pt"><span style="font-size:8.5pt;font-family:Consolas">      ver = parse <++ return noVersion<o:p></o:p></span></pre>
<pre style="line-height:11.25pt"><span style="font-size:8.5pt;font-family:Consolas">      noVersion = Version{ versionBranch=[], versionTags=[] }<o:p></o:p></span></pre>
</div>
<p>Note that 'ver' really is called at two different types! That <br>
in turn is because of the type of (<++)<o:p></o:p></p>
<div style="margin-top:9.0pt;margin-bottom:9.0pt">
<pre style="line-height:11.25pt"><span style="font-size:8.5pt;font-family:Consolas">(<++) :: ReadP a a -> ReadP r a -> ReadP r a<o:p></o:p></span></pre>
<pre style="line-height:11.25pt"><span style="font-size:8.5pt;font-family:Consolas">(+++) :: ReadP r a -> ReadP r a -> ReadP r a<o:p></o:p></span></pre>
</div>
<p>Note the "a a" in the first arg, which is very unusual.<br>
For example, compare the type of (+++).<o:p></o:p></p>
<p>Changing it to match the type of (+++) makes ReadP fail to compile,<br>
though, so I assume it's right as it stands. But surely this deserves<br>
a comment?!<o:p></o:p></p>
</div>
</div>
<p class="MsoNormal"><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><o:p> </o:p></span></p>
<div>
<p class="MsoNormal"><strong><span style="font-size:10.0pt;font-family:"Calibri",sans-serif">AFFECTED FILES</span></strong><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><o:p></o:p></span></p>
<div>
<div>
<p class="MsoNormal"><span style="font-size:10.0pt;font-family:"Calibri",sans-serif">/Distribution/ParseUtils.hs<o:p></o:p></span></p>
</div>
</div>
</div>
<p class="MsoNormal"><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><o:p> </o:p></span></p>
<div>
<p class="MsoNormal"><strong><span style="font-size:10.0pt;font-family:"Calibri",sans-serif">USERS</span></strong><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><o:p></o:p></span></p>
<div>
<div>
<p class="MsoNormal"><span style="font-size:10.0pt;font-family:"Calibri",sans-serif">simonpj (Author)<o:p></o:p></span></p>
</div>
</div>
</div>
<p class="MsoNormal"><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><o:p> </o:p></span></p>
<div>
<p class="MsoNormal"><strong><span style="font-size:10.0pt;font-family:"Calibri",sans-serif">COMMIT</span></strong><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><o:p></o:p></span></p>
<div>
<p class="MsoNormal"><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><a href="https://phabricator.haskell.org/rCABAL2863a628f857">https://phabricator.haskell.org/rCABAL2863a628f857</a><o:p></o:p></span></p>
</div>
</div>
<p class="MsoNormal"><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><o:p> </o:p></span></p>
<div>
<p class="MsoNormal"><strong><span style="font-size:10.0pt;font-family:"Calibri",sans-serif">EMAIL PREFERENCES</span></strong><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><o:p></o:p></span></p>
<div>
<p class="MsoNormal"><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><a href="https://phabricator.haskell.org/settings/panel/emailpreferences/">https://phabricator.haskell.org/settings/panel/emailpreferences/</a><o:p></o:p></span></p>
</div>
</div>
<p class="MsoNormal"><span style="font-size:10.0pt;font-family:"Calibri",sans-serif"><o:p> </o:p></span></p>
<div>
<p class="MsoNormal"><strong><span style="font-size:10.0pt;font-family:"Calibri",sans-serif">To:
</span></strong><span style="font-size:10.0pt;font-family:"Calibri",sans-serif">simonpj<o:p></o:p></span></p>
</div>
</div>
</body>
</html>