Browse Source

Util: Reorder specifier arguments to match parsing order

master
Riyyi 2 years ago
parent
commit
5eb5e2d51e
  1. 10
      src/util/format/builder.cpp
  2. 6
      src/util/format/builder.h
  3. 6
      src/util/format/formatter.cpp
  4. 4
      src/util/format/formatter.h

10
src/util/format/builder.cpp

@ -28,7 +28,7 @@ void Builder::putLiteral(std::string_view literal)
} }
} }
void Builder::putU64(size_t value, size_t width, Align align, char fill, Sign sign, bool isNegative) const void Builder::putU64(size_t value, char fill, Align align, Sign sign, size_t width, bool isNegative) const
{ {
std::string string = (std::stringstream {} << value).str(); std::string string = (std::stringstream {} << value).str();
@ -79,11 +79,11 @@ void Builder::putU64(size_t value, size_t width, Align align, char fill, Sign si
}; };
} }
void Builder::putI64(int64_t value, size_t width, Align align, char fill, Sign sign) const void Builder::putI64(int64_t value, char fill, Align align, Sign sign, size_t width) const
{ {
auto const isNegative = value < 0; bool isNegative = value < 0;
value = isNegative ? -value : value; value = isNegative ? -value : value;
putU64(static_cast<uint64_t>(value), width, align, fill, sign, isNegative); putU64(static_cast<uint64_t>(value), fill, align, sign, width, isNegative);
} }
void Builder::putF64(double number, uint8_t precision) const void Builder::putF64(double number, uint8_t precision) const
@ -99,7 +99,7 @@ void Builder::putF64(double number, uint8_t precision) const
m_builder << string; m_builder << string;
} }
void Builder::putString(std::string_view string, size_t width, Align align, char fill) const void Builder::putString(std::string_view string, char fill, Align align, size_t width) const
{ {
size_t length = string.length(); size_t length = string.length();
if (width < length) { if (width < length) {

6
src/util/format/builder.h

@ -36,11 +36,11 @@ public:
void putLiteral(std::string_view literal); void putLiteral(std::string_view literal);
void putU64(size_t value, size_t width = 0, Align align = Align::Right, char fill = ' ', Sign sign = Sign::Negative, bool isNegative = false) const; void putU64(size_t value, char fill = ' ', Align align = Align::Right, Sign sign = Sign::Negative, size_t width = 0, bool isNegative = false) const;
void putI64(int64_t value, size_t width = 0, Align align = Align::Right, char fill = ' ', Sign sign = Sign::Negative) const; void putI64(int64_t value, char fill = ' ', Align align = Align::Right, Sign sign = Sign::Negative, size_t width = 0) const;
void putF64(double number, uint8_t precision = 6) const; void putF64(double number, uint8_t precision = 6) const;
void putCharacter(char character) const { m_builder.write(&character, 1); } void putCharacter(char character) const { m_builder.write(&character, 1); }
void putString(std::string_view string, size_t width = 0, Align align = Align::Left, char fill = ' ') const; void putString(std::string_view string, char fill = ' ', Align align = Align::Left, size_t width = 0) const;
void putPointer(const void* pointer) const { m_builder << pointer; } void putPointer(const void* pointer) const { m_builder << pointer; }
const std::stringstream& builder() const { return m_builder; } const std::stringstream& builder() const { return m_builder; }

6
src/util/format/formatter.cpp

@ -35,7 +35,7 @@ void Formatter<bool>::format(Builder& builder, bool value) const
template<> template<>
void Formatter<std::string_view>::format(Builder& builder, std::string_view value) const void Formatter<std::string_view>::format(Builder& builder, std::string_view value) const
{ {
builder.putString(value, specifier.width, specifier.align, specifier.fill); builder.putString(value, specifier.fill, specifier.align, specifier.width);
} }
void Formatter<const char*>::parse(Parser& parser) void Formatter<const char*>::parse(Parser& parser)
@ -51,7 +51,9 @@ void Formatter<const char*>::format(Builder& builder, const char* value) const
return; return;
} }
builder.putString(value != nullptr ? std::string_view { value, strlen(value) } : "nullptr"); Formatter<std::string_view>::format(
builder,
value != nullptr ? std::string_view { value, strlen(value) } : "nullptr");
} }
// Pointer // Pointer

4
src/util/format/formatter.h

@ -93,11 +93,11 @@ struct Formatter<T> {
{ {
if (std::is_signed_v<T>) { if (std::is_signed_v<T>) {
builder.putI64( builder.putI64(
value, specifier.width, specifier.align, specifier.fill, specifier.sign); value, specifier.fill, specifier.align, specifier.sign, specifier.width);
} }
if (std::is_unsigned_v<T>) { if (std::is_unsigned_v<T>) {
builder.putU64( builder.putU64(
value, specifier.width, specifier.align, specifier.fill, specifier.sign); value, specifier.fill, specifier.align, specifier.sign, specifier.width);
} }
} }
}; };

Loading…
Cancel
Save