mirror of
https://github.com/fergalmoran/ladybird.git
synced 2026-01-06 16:45:03 +00:00
LibJS: Keep track of PrimitiveStrings and share them
VM now has a string cache which tracks all live PrimitiveStrings and reuses an existing one if possible. This drastically reduces the number of GC-allocated strings in many real-word situations.
This commit is contained in:
@@ -25,6 +25,7 @@ PrimitiveString::PrimitiveString(Utf16String string)
|
||||
|
||||
PrimitiveString::~PrimitiveString()
|
||||
{
|
||||
vm().string_cache().remove(m_utf8_string);
|
||||
}
|
||||
|
||||
String const& PrimitiveString::string() const
|
||||
@@ -90,7 +91,14 @@ PrimitiveString* js_string(Heap& heap, String string)
|
||||
return &heap.vm().single_ascii_character_string(ch);
|
||||
}
|
||||
|
||||
return heap.allocate_without_global_object<PrimitiveString>(move(string));
|
||||
auto& string_cache = heap.vm().string_cache();
|
||||
auto it = string_cache.find(string);
|
||||
if (it == string_cache.end()) {
|
||||
auto* new_string = heap.allocate_without_global_object<PrimitiveString>(string);
|
||||
string_cache.set(move(string), new_string);
|
||||
return new_string;
|
||||
}
|
||||
return it->value;
|
||||
}
|
||||
|
||||
PrimitiveString* js_string(VM& vm, String string)
|
||||
|
||||
Reference in New Issue
Block a user