Merge pull request #4797 from nyashbox/feat/add_g_specifier_to_format

Make Poco::format() support %g or %G as a format specifier like printf() does
This commit is contained in:
Günter Obiltschnig 2024-12-02 07:16:09 +01:00 committed by GitHub
commit ed54e86914
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 82 additions and 0 deletions

View File

@ -62,6 +62,8 @@ std::string Foundation_API format(const std::string& fmt, const Any& value);
/// * e signed floating-point value in the form [-]d.dddde[<sign>]dd[d] /// * e signed floating-point value in the form [-]d.dddde[<sign>]dd[d]
/// * E signed floating-point value in the form [-]d.ddddE[<sign>]dd[d] /// * E signed floating-point value in the form [-]d.ddddE[<sign>]dd[d]
/// * f signed floating-point value in the form [-]dddd.dddd /// * f signed floating-point value in the form [-]dddd.dddd
/// * g use the shortest representation: %e or %f
/// * G use the shortest representation: %E or %F
/// * s std::string /// * s std::string
/// * v std::string_view /// * v std::string_view
/// * z std::size_t /// * z std::size_t

View File

@ -128,6 +128,8 @@ namespace
case 'e': str << std::scientific; break; case 'e': str << std::scientific; break;
case 'E': str << std::scientific << std::uppercase; break; case 'E': str << std::scientific << std::uppercase; break;
case 'f': str << std::fixed; break; case 'f': str << std::fixed; break;
case 'g': str << std::defaultfloat; break;
case 'G': str << std::defaultfloat << std::uppercase; break;
} }
} }
@ -212,6 +214,8 @@ namespace
case 'e': case 'e':
case 'E': case 'E':
case 'f': case 'f':
case 'g':
case 'G':
switch (mod) switch (mod)
{ {
case 'l': str << AnyCast<long double>(*itVal++); break; case 'l': str << AnyCast<long double>(*itVal++); break;

View File

@ -325,6 +325,80 @@ void FormatTest::testAnyInt()
assertTrue (s == "42"); assertTrue (s == "42");
} }
void FormatTest::testShortestRepr()
{
std::string str;
//
// uppercase tests
//
{
str = format("%G", 123.456);
assertEquals("123.456", str);
str = format("%G", 12345.6789);
assertEquals("12345.7", str);
str = format("%G", 0.000123);
assertEquals("0.000123", str);
str = format("%G", 1234567890.123);
assertEquals("1.23457E+09", str);
str = format("%G", 0.0);
assertEquals("0", str);
str = format("%G", -9876.54321);
assertEquals("-9876.54", str);
str = format("%.2G", 123.456);
assertEquals("1.2E+02", str);
str = format("%G", 1.0);
assertEquals("1", str);
str = format("%G", 0.00000000123);
assertEquals("1.23E-09", str);
str = format("%G", 0.00000000000123);
assertEquals("1.23E-12", str);
}
//
// lowercase tests
//
{
str = format("%g", 123.456);
assertEquals("123.456", str);
str = format("%g", 12345.6789);
assertEquals("12345.7", str);
str = format("%g", 0.000123);
assertEquals("0.000123", str);
str = format("%g", 1234567890.123);
assertEquals("1.23457e+09", str);
str = format("%g", 0.0);
assertEquals("0", str);
str = format("%g", -9876.54321);
assertEquals("-9876.54", str);
str = format("%.2g", 123.456);
assertEquals("1.2e+02", str);
str = format("%g", 1.0);
assertEquals("1", str);
str = format("%g", 0.00000000123);
assertEquals("1.23e-09", str);
str = format("%g", 0.00000000000123);
assertEquals("1.23e-12", str);
}
}
void FormatTest::testFloatFix() void FormatTest::testFloatFix()
{ {
@ -527,6 +601,7 @@ CppUnit::Test* FormatTest::suite()
CppUnit_addTest(pSuite, FormatTest, testMultiple); CppUnit_addTest(pSuite, FormatTest, testMultiple);
CppUnit_addTest(pSuite, FormatTest, testIndex); CppUnit_addTest(pSuite, FormatTest, testIndex);
CppUnit_addTest(pSuite, FormatTest, testAny); CppUnit_addTest(pSuite, FormatTest, testAny);
CppUnit_addTest(pSuite, FormatTest, testShortestRepr);
return pSuite; return pSuite;
} }

View File

@ -29,6 +29,7 @@ public:
void testFloatSci(); void testFloatSci();
void testString(); void testString();
void testStringView(); void testStringView();
void testShortestRepr();
void testMultiple(); void testMultiple();
void testIndex(); void testIndex();
void testAny(); void testAny();