From deecf07bd1feadf76aadba127c7b64f931800c20 Mon Sep 17 00:00:00 2001 From: Steven Le Rouzic Date: Thu, 23 Jan 2025 23:59:32 +0100 Subject: Add StringWriter, and use it instead of StringSink --- asl/string_builder.hpp | 93 +++++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 80 insertions(+), 13 deletions(-) (limited to 'asl/string_builder.hpp') diff --git a/asl/string_builder.hpp b/asl/string_builder.hpp index 378ec48..8e9832f 100644 --- a/asl/string_builder.hpp +++ b/asl/string_builder.hpp @@ -3,26 +3,28 @@ #include "asl/buffer.hpp" #include "asl/string.hpp" #include "asl/string_view.hpp" +#include "asl/format.hpp" +#include "asl/io.hpp" namespace asl { template -class string_builder +class StringBuilder { buffer m_buffer; public: - constexpr string_builder() requires default_constructible = default; - explicit constexpr string_builder(Allocator allocator) : m_buffer{ASL_MOVE(allocator)} {} + constexpr StringBuilder() requires default_constructible = default; + explicit constexpr StringBuilder(Allocator allocator) : m_buffer{ASL_MOVE(allocator)} {} - constexpr ~string_builder() = default; + constexpr ~StringBuilder() = default; - constexpr string_builder(const string_builder&) requires copy_constructible = default; - constexpr string_builder(string_builder&&) = default; + constexpr StringBuilder(const StringBuilder&) requires copy_constructible = default; + constexpr StringBuilder(StringBuilder&&) = default; - constexpr string_builder& operator=(const string_builder&) requires copy_assignable = default; - constexpr string_builder& operator=(string_builder&&) = default; + constexpr StringBuilder& operator=(const StringBuilder&) requires copy_assignable = default; + constexpr StringBuilder& operator=(StringBuilder&&) = default; constexpr string_view as_string_view() const { @@ -37,7 +39,7 @@ public: // @Todo(C++23) Deducing this - string_builder& push(string_view sv) & + StringBuilder& push(string_view sv) & { isize_t old_size = m_buffer.size(); m_buffer.resize_zero(old_size + sv.size()); @@ -45,7 +47,7 @@ public: return *this; } - string_builder&& push(string_view sv) && + StringBuilder&& push(string_view sv) && { isize_t old_size = m_buffer.size(); m_buffer.resize_zero(old_size + sv.size()); @@ -53,13 +55,13 @@ public: return ASL_MOVE(*this); } - string_builder& push(char c) & + StringBuilder& push(char c) & { m_buffer.push(c); return *this; } - string_builder&& push(char c) && + StringBuilder&& push(char c) && { m_buffer.push(c); return ASL_MOVE(*this); @@ -84,6 +86,71 @@ public: } }; -string_builder() -> string_builder<>; +StringBuilder() -> StringBuilder<>; + +template +class StringWriter : public asl::Writer +{ + StringBuilder m_builder; + +public: + constexpr StringWriter() requires default_constructible = default; + explicit constexpr StringWriter(Allocator allocator) : m_builder{ASL_MOVE(allocator)} {} + + constexpr ~StringWriter() override = default; + + constexpr StringWriter(const StringWriter&) requires copy_constructible = default; + constexpr StringWriter(StringWriter&&) = default; + + constexpr StringWriter& operator=(const StringWriter&) requires copy_assignable = default; + constexpr StringWriter& operator=(StringWriter&&) = default; + + void write(span str) override + { + m_builder.push(string_view{reinterpret_cast(str.data()), str.size()}); + } + + constexpr string_view as_string_view() const + { + return m_builder.as_string_view(); + } + + string finish() && + { + return ASL_MOVE(m_builder).finish(); + } + + template + string as_string() + requires default_constructible + { + return m_builder.as_string(); + } + + template + string as_string(Allocator allocator) + { + return m_builder.as_string(ASL_MOVE(allocator)); + } +}; + +StringWriter() -> StringWriter<>; + +template +string format_to_string(string_view fmt, const Args&... args) + requires default_constructible +{ + StringWriter writer{}; + format(&writer, fmt, args...); + return ASL_MOVE(writer).finish(); +} + +template +string format_to_string(Allocator allocator, string_view fmt, const Args&... args) +{ + StringWriter writer{ASL_MOVE(allocator)}; + format(&writer, fmt, args...); + return ASL_MOVE(writer).finish(); +} } // namespace asl -- cgit