mirror of
https://github.com/fmtlib/fmt.git
synced 2025-11-02 15:11:43 +01:00
Replace snprintf-based hex float formatter with internal implementation
Signed-off-by: Vladislav Shchapov <vladislav@shchapov.ru>
This commit is contained in:
committed by
Victor Zverovich
parent
74d55a4938
commit
31364732dc
@@ -1344,16 +1344,64 @@ TEST(format_test, format_double) {
|
||||
EXPECT_EQ(fmt::format("{:f}", 392.65), "392.650000");
|
||||
EXPECT_EQ(fmt::format("{:F}", 392.65), "392.650000");
|
||||
EXPECT_EQ(fmt::format("{:L}", 42.0), "42");
|
||||
EXPECT_EQ(fmt::format("{:24a}", 4.2f), " 0x1.0cccccp+2");
|
||||
EXPECT_EQ(fmt::format("{:24a}", 4.2), " 0x1.0cccccccccccdp+2");
|
||||
EXPECT_EQ(fmt::format("{:<24a}", 4.2), "0x1.0cccccccccccdp+2 ");
|
||||
EXPECT_EQ(fmt::format("{0:e}", 392.65), "3.926500e+02");
|
||||
EXPECT_EQ(fmt::format("{0:E}", 392.65), "3.926500E+02");
|
||||
EXPECT_EQ(fmt::format("{0:+010.4g}", 392.65), "+0000392.6");
|
||||
char buffer[buffer_size];
|
||||
safe_sprintf(buffer, "%a", -42.0);
|
||||
EXPECT_EQ(fmt::format("{:a}", -42.0), buffer);
|
||||
safe_sprintf(buffer, "%A", -42.0);
|
||||
EXPECT_EQ(fmt::format("{:A}", -42.0), buffer);
|
||||
|
||||
#if FMT_CPLUSPLUS >= 201703L
|
||||
double xd = 0x1.ffffffffffp+2;
|
||||
safe_sprintf(buffer, "%.*a", 10, xd);
|
||||
EXPECT_EQ(fmt::format("{:.10a}", xd), buffer);
|
||||
safe_sprintf(buffer, "%.*a", 9, xd);
|
||||
EXPECT_EQ(fmt::format("{:.9a}", xd), buffer);
|
||||
|
||||
if (std::numeric_limits<long double>::digits == 64) {
|
||||
auto ld = 0xf.ffffffffffp-3l;
|
||||
safe_sprintf(buffer, "%La", ld);
|
||||
EXPECT_EQ(fmt::format("{:a}", ld), buffer);
|
||||
safe_sprintf(buffer, "%.*La", 10, ld);
|
||||
EXPECT_EQ(fmt::format("{:.10a}", ld), buffer);
|
||||
safe_sprintf(buffer, "%.*La", 9, ld);
|
||||
EXPECT_EQ(fmt::format("{:.9a}", ld), buffer);
|
||||
}
|
||||
#endif
|
||||
|
||||
if (fmt::detail::const_check(std::numeric_limits<double>::is_iec559)) {
|
||||
double d = (std::numeric_limits<double>::min)();
|
||||
EXPECT_EQ(fmt::format("{:a}", d), "0x1p-1022");
|
||||
EXPECT_EQ(fmt::format("{:#a}", d), "0x1.p-1022");
|
||||
|
||||
d = (std::numeric_limits<double>::max)();
|
||||
safe_sprintf(buffer, "%a", d);
|
||||
EXPECT_EQ(fmt::format("{:a}", d), buffer);
|
||||
|
||||
d = std::numeric_limits<double>::denorm_min();
|
||||
EXPECT_EQ(fmt::format("{:a}", d), "0x0.0000000000001p-1022");
|
||||
}
|
||||
|
||||
if (std::numeric_limits<long double>::digits == 64) {
|
||||
auto ld = (std::numeric_limits<long double>::min)();
|
||||
safe_sprintf(buffer, "%La", ld);
|
||||
EXPECT_EQ(fmt::format("{:a}", ld), buffer);
|
||||
|
||||
ld = (std::numeric_limits<long double>::max)();
|
||||
safe_sprintf(buffer, "%La", ld);
|
||||
EXPECT_EQ(fmt::format("{:a}", ld), buffer);
|
||||
|
||||
ld = std::numeric_limits<long double>::denorm_min();
|
||||
EXPECT_EQ(fmt::format("{:a}", ld), "0x0.000000000000001p-16382");
|
||||
}
|
||||
|
||||
safe_sprintf(buffer, "%.*a", 10, 4.2);
|
||||
EXPECT_EQ(fmt::format("{:.10a}", 4.2), buffer);
|
||||
|
||||
EXPECT_EQ(fmt::format("{:a}", -42.0), "-0x1.5p+5");
|
||||
EXPECT_EQ(fmt::format("{:A}", -42.0), "-0X1.5P+5");
|
||||
|
||||
EXPECT_EQ(fmt::format("{:f}", 9223372036854775807.0),
|
||||
"9223372036854775808.000000");
|
||||
}
|
||||
|
||||
@@ -225,10 +225,8 @@ TEST(printf_test, hash_flag) {
|
||||
EXPECT_PRINTF("-42.0000", "%#g", -42.0);
|
||||
EXPECT_PRINTF("-42.0000", "%#G", -42.0);
|
||||
|
||||
safe_sprintf(buffer, "%#a", 16.0);
|
||||
EXPECT_PRINTF(buffer, "%#a", 16.0);
|
||||
safe_sprintf(buffer, "%#A", 16.0);
|
||||
EXPECT_PRINTF(buffer, "%#A", 16.0);
|
||||
EXPECT_PRINTF("0x1.p+4", "%#a", 16.0);
|
||||
EXPECT_PRINTF("0X1.P+4", "%#A", 16.0);
|
||||
|
||||
// '#' flag is ignored for non-numeric types.
|
||||
EXPECT_PRINTF("x", "%#c", 'x');
|
||||
|
||||
Reference in New Issue
Block a user