Use std::from_chars in MessageFormatParser

This commit is contained in:
Evil Eye 2025-08-20 19:51:02 +02:00
parent 4fd9e5b2bb
commit 6453d3e201

View File

@ -1,12 +1,32 @@
#include "messageformatparser.hpp" #include "messageformatparser.hpp"
#include <charconv>
namespace
{
int parseNumber(std::size_t& i, std::string_view m)
{
if (i < m.size() && m[i] >= '0' && m[i] <= '9')
{
size_t start = i++;
while (i < m.size() && m[i] >= '0' && m[i] <= '9')
++i;
int parsed;
auto [ptr, ec] = std::from_chars(m.data() + start, m.data() + i, parsed);
if (ec == std::errc())
return parsed;
}
return -1;
}
}
namespace Misc namespace Misc
{ {
MessageFormatParser::~MessageFormatParser() {} MessageFormatParser::~MessageFormatParser() = default;
void MessageFormatParser::process(std::string_view m) void MessageFormatParser::process(std::string_view m)
{ {
for (unsigned int i = 0; i < m.size(); ++i) for (std::size_t i = 0; i < m.size(); ++i)
{ {
if (m[i] == '%') if (m[i] == '%')
{ {
@ -23,31 +43,19 @@ namespace Misc
++i; ++i;
} }
int width = 0; int width = parseNumber(i, m);
bool widthSet = false;
while (i < m.size() && m[i] >= '0' && m[i] <= '9')
{
width = width * 10 + (m[i] - '0');
widthSet = true;
++i;
}
if (i < m.size()) if (i < m.size())
{ {
int precision = -1; int precision = -1;
if (m[i] == '.') if (m[i] == '.')
{ {
precision = 0; ++i;
while (++i < m.size() && m[i] >= '0' && m[i] <= '9') precision = parseNumber(i, m);
{
precision = precision * 10 + (m[i] - '0');
}
} }
if (i < m.size()) if (i < m.size())
{ {
width = (widthSet) ? width : -1;
if (m[i] == 'S' || m[i] == 's') if (m[i] == 'S' || m[i] == 's')
visitedPlaceholder(StringPlaceholder, pad, width, precision, FixedNotation); visitedPlaceholder(StringPlaceholder, pad, width, precision, FixedNotation);
else if (m[i] == 'd' || m[i] == 'i') else if (m[i] == 'd' || m[i] == 'i')