From a141c401f78467bc15f62882fca5d55a007cacbb Mon Sep 17 00:00:00 2001 From: Steven Le Rouzic Date: Mon, 17 Feb 2025 00:21:48 +0100 Subject: Reorganize everything --- asl/string_builder.hpp | 156 ------------------------------------------------- 1 file changed, 156 deletions(-) delete mode 100644 asl/string_builder.hpp (limited to 'asl/string_builder.hpp') diff --git a/asl/string_builder.hpp b/asl/string_builder.hpp deleted file mode 100644 index 15422f6..0000000 --- a/asl/string_builder.hpp +++ /dev/null @@ -1,156 +0,0 @@ -#pragma once - -#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 StringBuilder -{ - buffer m_buffer; - -public: - constexpr StringBuilder() requires default_constructible = default; - explicit constexpr StringBuilder(Allocator allocator) : m_buffer{ASL_MOVE(allocator)} {} - - constexpr ~StringBuilder() = default; - - constexpr StringBuilder(const StringBuilder&) requires copy_constructible = default; - constexpr StringBuilder(StringBuilder&&) = default; - - constexpr StringBuilder& operator=(const StringBuilder&) requires copy_assignable = default; - constexpr StringBuilder& operator=(StringBuilder&&) = default; - - constexpr string_view as_string_view() const - { - auto span = m_buffer.as_span(); - return string_view{span.data(), span.size()}; - } - - void reset() - { - m_buffer.clear(); - } - - // @Todo(C++23) Deducing this - - StringBuilder& push(string_view sv) & - { - isize_t old_size = m_buffer.size(); - m_buffer.resize_zero(old_size + sv.size()); - asl::memcpy(m_buffer.data() + old_size, sv.data(), sv.size()); - return *this; - } - - StringBuilder&& push(string_view sv) && - { - isize_t old_size = m_buffer.size(); - m_buffer.resize_zero(old_size + sv.size()); - asl::memcpy(m_buffer.data() + old_size, sv.data(), sv.size()); - return ASL_MOVE(*this); - } - - StringBuilder& push(char c) & - { - m_buffer.push(c); - return *this; - } - - StringBuilder&& push(char c) && - { - m_buffer.push(c); - return ASL_MOVE(*this); - } - - string finish() && - { - return string{ASL_MOVE(m_buffer)}; - } - - template - string as_string() - requires default_constructible - { - return string{as_string_view()}; - } - - template - string as_string(Allocator allocator) - { - return string{as_string_view(), ASL_MOVE(allocator)}; - } -}; - -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