Skip to content

Commit 3c758ad

Browse files
committed
Fix group_digits for negative integers
Signed-off-by: Vladislav Shchapov <[email protected]>
1 parent 365c3fb commit 3c758ad

File tree

2 files changed

+8
-3
lines changed

2 files changed

+8
-3
lines changed

Diff for: include/fmt/format.h

+5-3
Original file line numberDiff line numberDiff line change
@@ -4130,9 +4130,11 @@ template <typename T> struct formatter<group_digits_view<T>> : formatter<T> {
41304130
specs.width_ref, ctx);
41314131
detail::handle_dynamic_spec<detail::precision_checker>(
41324132
specs.precision, specs.precision_ref, ctx);
4133-
return detail::write_int(ctx.out(),
4134-
static_cast<detail::uint64_or_128_t<T>>(t.value),
4135-
0, specs, detail::digit_grouping<char>("\3", ","));
4133+
4134+
auto arg = detail::make_write_int_arg(t.value, specs.sign);
4135+
return detail::write_int(
4136+
ctx.out(), static_cast<detail::uint64_or_128_t<T>>(arg.abs_value),
4137+
arg.prefix, specs, detail::digit_grouping<char>("\3", ","));
41364138
}
41374139
};
41384140

Diff for: test/format-test.cc

+3
Original file line numberDiff line numberDiff line change
@@ -1837,6 +1837,9 @@ TEST(format_test, bytes) {
18371837
TEST(format_test, group_digits_view) {
18381838
EXPECT_EQ(fmt::format("{}", fmt::group_digits(10000000)), "10,000,000");
18391839
EXPECT_EQ(fmt::format("{:8}", fmt::group_digits(1000)), " 1,000");
1840+
EXPECT_EQ(fmt::format("{}", fmt::group_digits(-10000000)), "-10,000,000");
1841+
EXPECT_EQ(fmt::format("{:8}", fmt::group_digits(-1000)), " -1,000");
1842+
EXPECT_EQ(fmt::format("{:8}", fmt::group_digits(-100)), " -100");
18401843
}
18411844

18421845
#ifdef __cpp_generic_lambdas

0 commit comments

Comments
 (0)