/* * Copyright (c) 2018-2021, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include namespace Kernel { class KBufferBuilder { public: using OutputType = KBuffer; explicit KBufferBuilder(bool can_expand = false); explicit KBufferBuilder(RefPtr&, bool can_expand = false); KBufferBuilder(KBufferBuilder&&) = default; ~KBufferBuilder() = default; void append(const StringView&); void append(char); void append(const char*, int); void append_escaped_for_json(const StringView&); void append_bytes(ReadonlyBytes); template void appendff(CheckedFormatString&& fmtstr, const Parameters&... parameters) { // FIXME: This is really not the way to go about it, but vformat expects a // StringBuilder. Why does this class exist anyways? StringBuilder builder; vformat(builder, fmtstr.view(), AK::VariadicFormatParams { parameters... }); append_bytes(builder.string_view().bytes()); } bool flush(); OwnPtr build(); private: bool check_expand(size_t); u8* insertion_ptr() { if (!m_buffer) return nullptr; return m_buffer->data() + m_size; } RefPtr m_buffer; size_t m_size { 0 }; bool m_can_expand { false }; }; }