<div dir="ltr">readEither is kind of a lie. The Read parsing system has no real error handling, so readEither just confuses people into thinking they're getting a useful message when they're not.</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Oct 15, 2021 at 12:28 AM Fumiaki Kinoshita <<a href="mailto:fumiexcel@gmail.com">fumiexcel@gmail.com</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"><div dir="ltr"><div dir="ltr"><div>I'm not proposing to <i>remove</i> it; my suggestion is to attach a warning perpetually (or like 20 years).</div><div>Without warnings, I think just adding readMaybe would have little incentive to the ecosystem;</div><div>we can't expect people to eyeball the uses of read (highly generic name) in their codebase.</div><div>We've broken a lot of code using fail simply because there was no warning enabled by default.<br></div></div><div><br></div><div>To be clear I'm all for bringing readMaybe and readEither (I prefer the either variant because of the Nothing blindness) into Prelude.</div><div>Once that happens, IMO DEPRECATE pragma should be added to encourage switching to safer variants.<br></div><div><br></div><div class="gmail_quote"><div dir="ltr" class="gmail_attr">2021年10月15日(金) 12:53 Carter Schonwald <<a href="mailto:carter.schonwald@gmail.com" target="_blank">carter.schonwald@gmail.com</a>>:<br></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="auto">I agree with emily david and ed </div><div dir="auto"><br></div><div dir="auto">Bringing readMaybe into prelude plus adding call stack info to read are the Sane path forward to improving Haskell. </div><div dir="auto"><br></div><div dir="auto"> Deprecating read, insofar as how ghc deprecation works, is a lotta pain for no real hao. </div><div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Oct 14, 2021 at 11:47 PM Edward Kmett <<a href="mailto:ekmett@gmail.com" target="_blank">ekmett@gmail.com</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"><div dir="ltr">A variant of this that I would support would be to bring <font style="font-family:monospace;color:rgb(0,0,0)" face="monospace">readMaybe</font> into <font style="font-family:monospace;color:rgb(0,0,0)" face="monospace">Prelude</font> from <font style="font-family:monospace;color:rgb(0,0,0)" face="monospace">Text.Read</font> for a good long time, and <i>then</i> to deprecate <font style="font-family:monospace;color:rgb(0,0,0)" face="monospace">read</font>. As it stands, <font style="font-family:monospace;color:rgb(0,0,0)" face="monospace">read</font> and the almost equally ugly <font style="font-family:monospace;color:rgb(0,0,0)" face="monospace">readIO</font> are the only <font style="font-family:monospace;color:rgb(0,0,0)" face="monospace">Prelude</font> facing ways for a user to really consume a <font style="font-family:monospace;color:rgb(0,0,0)" face="monospace">Read</font> instance, so losing <font style="font-family:monospace;color:rgb(0,0,0)" face="monospace">read</font> there is a heck of a blow to usability without a replacement being in place with an established pattern of usage.</div><div dir="ltr"><div><br></div><div>-Edward</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Oct 14, 2021 at 11:16 PM Emily Pillmore <<a href="mailto:emilypi@cohomolo.gy" target="_blank">emilypi@cohomolo.gy</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"><div><div><div><div><div>NOPE.</div></div><div><div style="display:none;border:0px none;width:0px;height:0px;overflow:hidden"><img alt="" style="display: none; border: 0px none; width: 0px; height: 0px; overflow: hidden;" width="1" height="0"></div><br><div></div></div><br><div><div class="gmail_quote">On Thu, Oct 14, 2021 at 8:31 PM, Fumiaki Kinoshita <span dir="ltr"><<a href="mailto:fumiexcel@gmail.com" target="_blank">fumiexcel@gmail.com</a>></span> wrote:<br><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_extra"><div class="gmail_quote" id="gmail-m_3691348748705581579gmail-m_-3827657078428095285m_8720860438723925186gmail-m_-341499609662145501null"><div dir="ltr"><div>It is a partial function that does not provide a call stack, and it's very slow too.<br></div><div><br></div><div>I propose deprecating <a rel="noopener noreferrer" href="http://prelude.read/" target="_blank">Prelude.read</a>. Adding deprecation should not break anything substantial because Hackage rejects -Werror (application code using -Werror is likely to experience a lot more breakage anyway, and I'd say it's their fault if it fails to build due to a use of read along with -Werror).</div><div><br></div><div>Of course those who still want to use <a rel="noopener noreferrer" href="http://prelude.read/" target="_blank">Prelude.read</a> can totally ignore warnings. I believe this proposal is not that controversial.<br></div></div>
<p>_______________________________________________
<br>
Libraries mailing list
<br>
<a rel="noopener noreferrer" href="mailto:Libraries@haskell.org" target="_blank">Libraries@haskell.org</a>
<br>
<a rel="noopener noreferrer" href="http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries" target="_blank">http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries</a></p></div></div></blockquote></div></div><br></div></div></div>_______________________________________________<br>
Libraries mailing list<br>
<a href="mailto:Libraries@haskell.org" target="_blank">Libraries@haskell.org</a><br>
<a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries" rel="noreferrer" target="_blank">http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries</a><br>
</blockquote></div>
_______________________________________________<br>
Libraries mailing list<br>
<a href="mailto:Libraries@haskell.org" target="_blank">Libraries@haskell.org</a><br>
<a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries" rel="noreferrer" target="_blank">http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries</a><br>
</blockquote></div></div>
_______________________________________________<br>
Libraries mailing list<br>
<a href="mailto:Libraries@haskell.org" target="_blank">Libraries@haskell.org</a><br>
<a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries" rel="noreferrer" target="_blank">http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries</a><br>
</blockquote></div></div>
_______________________________________________<br>
Libraries mailing list<br>
<a href="mailto:Libraries@haskell.org" target="_blank">Libraries@haskell.org</a><br>
<a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries" rel="noreferrer" target="_blank">http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries</a><br>
</blockquote></div>