mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-22 07:30:19 +00:00
027d26cd5d
You're never gonna be right 100% of the time when guessing how much buffer space you need. This avoids having to make that type of decision in a bunch of cases. :^)
73 lines
1.4 KiB
C++
73 lines
1.4 KiB
C++
#include "StringBuilder.h"
|
|
#include <LibC/stdarg.h>
|
|
#include "printf.cpp"
|
|
#include <AK/StdLibExtras.h>
|
|
|
|
namespace AK {
|
|
|
|
inline void StringBuilder::will_append(size_t size)
|
|
{
|
|
if ((m_length + size) > m_buffer.size())
|
|
m_buffer.grow(max(16u, m_buffer.size() * 2 + size));
|
|
}
|
|
|
|
StringBuilder::StringBuilder(size_t initial_capacity)
|
|
{
|
|
m_buffer.grow(initial_capacity);
|
|
}
|
|
|
|
void StringBuilder::append(const String& str)
|
|
{
|
|
if (str.is_empty())
|
|
return;
|
|
will_append(str.length());
|
|
memcpy(m_buffer.pointer() + m_length, str.characters(), str.length());
|
|
m_length += str.length();
|
|
}
|
|
|
|
void StringBuilder::append(const char* characters, size_t length)
|
|
{
|
|
if (!length)
|
|
return;
|
|
will_append(length);
|
|
memcpy(m_buffer.pointer() + m_length, characters, length);
|
|
m_length += length;
|
|
}
|
|
|
|
void StringBuilder::append(char ch)
|
|
{
|
|
will_append(1);
|
|
m_buffer.pointer()[m_length] = ch;
|
|
m_length += 1;
|
|
}
|
|
|
|
void StringBuilder::appendvf(const char* fmt, va_list ap)
|
|
{
|
|
printfInternal([this] (char*&, char ch) {
|
|
append(ch);
|
|
}, nullptr, fmt, ap);
|
|
}
|
|
|
|
void StringBuilder::appendf(const char* fmt, ...)
|
|
{
|
|
va_list ap;
|
|
va_start(ap, fmt);
|
|
appendvf(fmt, ap);
|
|
va_end(ap);
|
|
}
|
|
|
|
ByteBuffer StringBuilder::to_byte_buffer()
|
|
{
|
|
m_buffer.trim(m_length);
|
|
return move(m_buffer);
|
|
}
|
|
|
|
String StringBuilder::build()
|
|
{
|
|
auto string = String((const char*)m_buffer.pointer(), m_length);
|
|
m_buffer.clear();
|
|
return string;
|
|
}
|
|
|
|
}
|
|
|