mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-09-30 00:31:14 +00:00
074edffc44
Okay, now ProcFS doesn't crash due to the crappy buffer size estimates not really working out. This thing has dogshit performance and I will fix that separately.
57 lines
1.1 KiB
C++
57 lines
1.1 KiB
C++
#include "StringBuilder.h"
|
|
#include <LibC/stdarg.h>
|
|
#include "printf.cpp"
|
|
|
|
namespace AK {
|
|
|
|
void StringBuilder::append(String&& str)
|
|
{
|
|
m_strings.append(move(str));
|
|
}
|
|
|
|
void StringBuilder::append(const String& str)
|
|
{
|
|
m_strings.append(str);
|
|
}
|
|
|
|
void StringBuilder::append(char ch)
|
|
{
|
|
m_strings.append(StringImpl::create(&ch, 1));
|
|
}
|
|
|
|
void StringBuilder::appendf(const char* fmt, ...)
|
|
{
|
|
va_list ap;
|
|
va_start(ap, fmt);
|
|
printfInternal([this] (char*&, char ch) {
|
|
append(ch);
|
|
}, nullptr, fmt, ap);
|
|
va_end(ap);
|
|
}
|
|
|
|
String StringBuilder::build()
|
|
{
|
|
auto strings = move(m_strings);
|
|
if (strings.is_empty())
|
|
return String::empty();
|
|
|
|
size_t sizeNeeded = 0;
|
|
for (auto& string : strings)
|
|
sizeNeeded += string.length();
|
|
|
|
char* buffer;
|
|
auto impl = StringImpl::create_uninitialized(sizeNeeded, buffer);
|
|
if (!impl)
|
|
return String();
|
|
|
|
for (auto& string : strings) {
|
|
memcpy(buffer, string.characters(), string.length());
|
|
buffer += string.length();
|
|
}
|
|
*buffer = '\0';
|
|
return String(move(impl));
|
|
}
|
|
|
|
}
|
|
|