<div dir="ltr">1. +1<div>2. ambivalent, I've never actually seen anyone use readEither, but it doesn't really hurt for it to be there since it isn't stealing anything valuable from the namespace.</div><div>3. +1</div><div><br></div><div>In my mind, the single most important part of this is part (3), improving the docs. All partial functions defined in base should come with warnings about this in the docs, along with hyperlinks to total functions for accomplishing the same thing.</div><div><br></div><div>-Andrew Martin</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Dec 27, 2016 at 10:58 PM, Simon Jakobi via Libraries <span dir="ltr"><<a href="mailto:libraries@haskell.org" target="_blank">libraries@haskell.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">read [1] is an easy way to introduce runtime exceptions into programs,<br>
but its documentation doesn't sufficiently warn of this danger. read's<br>
safe alternatives, Text.Read.readMaybe [2] and Text.Read.readEither<br>
[3], are relatively unknown and too hard to find.<br>
<br>
To guide users (particularly newcomers) away from read and towards<br>
readMaybe and readEither, I propose to<br>
<br>
1. Add readMaybe to the Prelude<br>
2. Add readEither to the Prelude<br>
3. Change the documentation for read to point out the partiality and<br>
to recommend the above alternatives:<br>
<br>
The haddocks for read currently read:<br>
<br>
> The read function reads input from a string, which must be<br>
completely consumed by the input process.<br>
<br>
I propose to add a paragraph roughly like this:<br>
<br>
> Note: read will throw an error if the parse fails. If there's<br>
any uncertainty w.r.t. the shape of the input, readMaybe or readEither<br>
should be used instead.<br>
<br>
<br>
Name clashes:<br>
<br>
A cursory code search on Github for readMaybe [4] reveals many<br>
existing definitions, mostly with the same type (Read a => String -><br>
Maybe a) and definition. The same search for readEither [5] shows<br>
mostly GHC forks.<br>
<br>
Design issues:<br>
<br>
I am somewhat doubtful about the benefit of readEither over readMaybe:<br>
While readEither does give additional info on the kind of parse<br>
failures, that information is encoded in a String error message, from<br>
which it must be parsed if it is needed in the program.<br>
<br>
<br>
As the different parts of the proposal can be implemented<br>
independently of each other, please vote separately on each part of<br>
the proposal.<br>
<br>
Discussion period: 4 weeks.<br>
<br>
Cheers,<br>
Simon<br>
<br>
[1] <a href="http://hackage.haskell.org/package/base-4.9.0.0/docs/Prelude.html#v:read" rel="noreferrer" target="_blank">http://hackage.haskell.org/<wbr>package/base-4.9.0.0/docs/<wbr>Prelude.html#v:read</a><br>
[2] <a href="http://hackage.haskell.org/package/base-4.9.0.0/docs/Text-Read.html#v:readMaybe" rel="noreferrer" target="_blank">http://hackage.haskell.org/<wbr>package/base-4.9.0.0/docs/<wbr>Text-Read.html#v:readMaybe</a><br>
[3] <a href="http://hackage.haskell.org/package/base-4.9.0.0/docs/Text-Read.html#v:readEither" rel="noreferrer" target="_blank">http://hackage.haskell.org/<wbr>package/base-4.9.0.0/docs/<wbr>Text-Read.html#v:readEither</a><br>
[4] <a href="https://github.com/search?l=Haskell&q=readMaybe&type=Code" rel="noreferrer" target="_blank">https://github.com/search?l=<wbr>Haskell&q=readMaybe&type=Code</a><br>
[5] <a href="https://github.com/search?l=Haskell&q=readEither&type=Code" rel="noreferrer" target="_blank">https://github.com/search?l=<wbr>Haskell&q=readEither&type=Code</a><br>
______________________________<wbr>_________________<br>
Libraries mailing list<br>
<a href="mailto:Libraries@haskell.org">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-<wbr>bin/mailman/listinfo/libraries</a><br>
</blockquote></div><br><br clear="all"><div><br></div>-- <br><div class="gmail_signature" data-smartmail="gmail_signature">-Andrew Thaddeus Martin</div>
</div>