[libc-commits] [PATCH] D113626: [libc] tweak strtof errno behavior
Michael Jones via Phabricator via libc-commits
libc-commits at lists.llvm.org
Thu Nov 11 10:17:56 PST 2021
This revision was automatically updated to reflect the committed changes.
Closed by commit rG4cdf9884b60d: [libc] tweak strtof errno behavior (authored by michaelrj).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D113626/new/
https://reviews.llvm.org/D113626
Files:
libc/src/__support/str_to_float.h
libc/test/src/__support/str_to_float_test.cpp
libc/test/src/stdlib/strtof_test.cpp
Index: libc/test/src/stdlib/strtof_test.cpp
===================================================================
--- libc/test/src/stdlib/strtof_test.cpp
+++ libc/test/src/stdlib/strtof_test.cpp
@@ -82,7 +82,8 @@
}
TEST_F(LlvmLibcStrToFTest, DecimalSubnormals) {
- runTest("1.4012984643248170709237295832899161312802619418765e-45", 55, 0x1);
+ runTest("1.4012984643248170709237295832899161312802619418765e-45", 55, 0x1,
+ ERANGE);
}
TEST_F(LlvmLibcStrToFTest, DecimalWithLongExponent) {
Index: libc/test/src/__support/str_to_float_test.cpp
===================================================================
--- libc/test/src/__support/str_to_float_test.cpp
+++ libc/test/src/__support/str_to_float_test.cpp
@@ -206,8 +206,8 @@
}
TEST_F(LlvmLibcStrToFloatTest, SimpleDecimalConversion64BasicSubnormals) {
- SimpleDecimalConversionTest<double>("1e-320", 0x7e8, 0);
- SimpleDecimalConversionTest<double>("1e-308", 0x730d67819e8d2, 0);
+ SimpleDecimalConversionTest<double>("1e-320", 0x7e8, 0, ERANGE);
+ SimpleDecimalConversionTest<double>("1e-308", 0x730d67819e8d2, 0, ERANGE);
SimpleDecimalConversionTest<double>("2.9e-308", 0x14da6df5e4bcc8, 1);
}
@@ -217,7 +217,7 @@
// but this is the shortest string that results in the maximum subnormal that
// I found.
SimpleDecimalConversionTest<double>("2.225073858507201e-308", 0xfffffffffffff,
- 0);
+ 0, ERANGE);
// Same here, if you were to extend the max subnormal out for another 800
// digits, incrementing any one of those digits would create a normal number.
@@ -227,7 +227,8 @@
TEST_F(LlvmLibcStrToFloatTest, SimpleDecimalConversion32SpecificFailures) {
SimpleDecimalConversionTest<float>(
- "1.4012984643248170709237295832899161312802619418765e-45", 0x1, 0);
+ "1.4012984643248170709237295832899161312802619418765e-45", 0x1, 0,
+ ERANGE);
}
TEST(LlvmLibcStrToFloatTest, SimpleDecimalConversionExtraTypes) {
Index: libc/src/__support/str_to_float.h
===================================================================
--- libc/src/__support/str_to_float.h
+++ libc/src/__support/str_to_float.h
@@ -308,6 +308,10 @@
++exp2;
}
+ if (exp2 == 0) {
+ errno = ERANGE; // NOLINT
+ }
+
*outputMantissa = finalMantissa;
*outputExp2 = exp2;
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D113626.386575.patch
Type: text/x-patch
Size: 2354 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/libc-commits/attachments/20211111/58f259d0/attachment.bin>
More information about the libc-commits
mailing list