From 470c4e6ca8d648a70f0071fa7c81b15fbc4556a4 Mon Sep 17 00:00:00 2001 From: Vladislav Shchapov Date: Wed, 17 Jan 2024 02:54:19 +0500 Subject: [PATCH] Fix scope for glibc ext for sec, min, and hour (#3812) Signed-off-by: Vladislav Shchapov --- include/fmt/chrono.h | 2 +- test/chrono-test.cc | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/include/fmt/chrono.h b/include/fmt/chrono.h index 09cce20feaa0..d2552776ab27 100644 --- a/include/fmt/chrono.h +++ b/include/fmt/chrono.h @@ -708,8 +708,8 @@ FMT_CONSTEXPR auto parse_chrono_format(const Char* begin, const Char* end, if (begin == end || *begin == '}') return begin; if (*begin != '%') FMT_THROW(format_error("invalid format")); auto ptr = begin; - pad_type pad = pad_type::unspecified; while (ptr != end) { + pad_type pad = pad_type::unspecified; auto c = *ptr; if (c == '}') break; if (c != '%') { diff --git a/test/chrono-test.cc b/test/chrono-test.cc index b2d03f979578..827fa102b1f6 100644 --- a/test/chrono-test.cc +++ b/test/chrono-test.cc @@ -956,6 +956,7 @@ TEST(chrono_test, glibc_extensions) { EXPECT_EQ(fmt::format("{:%0I,%0H,%0M,%0S}", d), "01,01,02,03"); EXPECT_EQ(fmt::format("{:%_I,%_H,%_M,%_S}", d), " 1, 1, 2, 3"); EXPECT_EQ(fmt::format("{:%-I,%-H,%-M,%-S}", d), "1,1,2,3"); + EXPECT_EQ(fmt::format("{:%-I,%H,%M,%S}", d), "1,01,02,03"); EXPECT_EQ(fmt::format("{:%OI,%OH,%OM,%OS}", d), "01,01,02,03"); EXPECT_EQ(fmt::format("{:%0OI,%0OH,%0OM,%0OS}", d), "01,01,02,03");