<html>
    <head>
      <base href="http://llvm.org/bugs/" />
    </head>
    <body><table border="1" cellspacing="0" cellpadding="8">
        <tr>
          <th>Bug ID</th>
          <td><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW --- - Decide what to do with stof"
   href="http://llvm.org/bugs/show_bug.cgi?id=19954">19954</a>
          </td>
        </tr>

        <tr>
          <th>Summary</th>
          <td>Decide what to do with stof
          </td>
        </tr>

        <tr>
          <th>Product</th>
          <td>libc++
          </td>
        </tr>

        <tr>
          <th>Version</th>
          <td>unspecified
          </td>
        </tr>

        <tr>
          <th>Hardware</th>
          <td>PC
          </td>
        </tr>

        <tr>
          <th>OS</th>
          <td>All
          </td>
        </tr>

        <tr>
          <th>Status</th>
          <td>NEW
          </td>
        </tr>

        <tr>
          <th>Severity</th>
          <td>normal
          </td>
        </tr>

        <tr>
          <th>Priority</th>
          <td>P
          </td>
        </tr>

        <tr>
          <th>Component</th>
          <td>All Bugs
          </td>
        </tr>

        <tr>
          <th>Assignee</th>
          <td>unassignedclangbugs@nondot.org
          </td>
        </tr>

        <tr>
          <th>Reporter</th>
          <td>nicolasweber@gmx.de
          </td>
        </tr>

        <tr>
          <th>CC</th>
          <td>llvmbugs@cs.uiuc.edu, mclow.lists@gmail.com
          </td>
        </tr>

        <tr>
          <th>Classification</th>
          <td>Unclassified
          </td>
        </tr></table>
      <p>
        <div>
        <pre>Created <span class=""><a href="attachment.cgi?id=12611" name="attach_12611" title="possible patch">attachment 12611</a> <a href="attachment.cgi?id=12611&action=edit" title="possible patch">[details]</a></span>
possible patch

<a href="http://lists.cs.uiuc.edu/pipermail/cfe-commits/Week-of-Mon-20140602/106976.html">http://lists.cs.uiuc.edu/pipermail/cfe-commits/Week-of-Mon-20140602/106976.html</a>

"""21.5p4 and 21.5p11 say that std::stof() and std::stod() are both supposed
to call strtod() (for char*) or wcstod() (for wchar_t*). libc++ currently
calls strtof() / wcstof() from std::stof(), so the attached patch fixes
this.

This has a surprising effect: 21.5p6 and 21.5p13 say that stof() should
throw out_of_range if strtod / wcstod set errno to ERANGE. Now, for
stof("1.e60") will call strtod("1.e60", ...). 1.e60 fits in a double, so
strtod() won't set ERANGE. But stof() returns a float, and this double
converted to a float does result in INFINITY. So it sounds like the
standard demands that stof("1.e60") returns INFINITY but does not throw,
while std::stod("1.e360") is supposed to return INFINITY and
throw out_of_range (assuming the C library sets ERANGE in this case, which
seems like a reasonable assumption.)"""

"""It is:

<a href="http://lwg.github.io/issues/lwg-active.html#2009">http://lwg.github.io/issues/lwg-active.html#2009</a>
"""

""" I hope that proposed resolution gets a slightly more detailed text. Similar
wording in the C standard apparently implies something along the lines of
"`1.e60` is a valid IEEE 754 spelling of INFINITY, and INFINITY is a
representable value" (
<a href="http://www.open-std.org/jtc1/sc22/wg14/www/docs/dr_025.html">http://www.open-std.org/jtc1/sc22/wg14/www/docs/dr_025.html</a> ) (which as far as
I understand is the interpretation that e.g. musl is using, so their strtof
doesn't set ERANGE on this input.)"""


"""Since this is an active LWG bug, I’d like to hold off on your patch until
after the next committee meeting (which is the week after next)."""


The attached patch changes stof to call strtod() and updates the test.  If the
committee decides that this should be changed, the stof() implementation needs
to be changed to do whatever the committee decides, and the test needs to be
updated. (Note that some C libraries, such as musl, don't set ERANGE for
INFINNITY in strtof().)</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are on the CC list for the bug.</li>
      </ul>
    </body>
</html>