summaryrefslogtreecommitdiff
path: root/Userland
diff options
context:
space:
mode:
authorAndreas Kling <kling@serenityos.org>2021-10-02 17:37:15 +0200
committerAndreas Kling <kling@serenityos.org>2021-10-02 17:39:38 +0200
commit024367d82e59e66390e8a8fc0f7dd866242438f9 (patch)
tree027c34c8ba5410f795cd45d82668f2e9e696a7b0 /Userland
parentae0bdda86e9946e8fc09db0c4dc044b2d975d7fa (diff)
downloadserenity-024367d82e59e66390e8a8fc0f7dd866242438f9.zip
LibJS+AK: Use Vector<u16, 1> for UTF-16 string storage
It's very common to encounter single-character strings in JavaScript on the web. We can make such strings significantly lighter by having a 1-character inline capacity on the Vectors.
Diffstat (limited to 'Userland')
-rw-r--r--Userland/Libraries/LibJS/Runtime/StringConstructor.cpp2
-rw-r--r--Userland/Libraries/LibJS/Runtime/Utf16String.cpp12
-rw-r--r--Userland/Libraries/LibJS/Runtime/Utf16String.h12
-rw-r--r--Userland/Libraries/LibRegex/RegexByteCode.cpp4
-rw-r--r--Userland/Libraries/LibRegex/RegexMatch.h2
5 files changed, 16 insertions, 16 deletions
diff --git a/Userland/Libraries/LibJS/Runtime/StringConstructor.cpp b/Userland/Libraries/LibJS/Runtime/StringConstructor.cpp
index cbac0b8d0d..d13a4f089f 100644
--- a/Userland/Libraries/LibJS/Runtime/StringConstructor.cpp
+++ b/Userland/Libraries/LibJS/Runtime/StringConstructor.cpp
@@ -140,7 +140,7 @@ JS_DEFINE_NATIVE_FUNCTION(StringConstructor::from_char_code)
// 22.1.2.2 String.fromCodePoint ( ...codePoints ), https://tc39.es/ecma262/#sec-string.fromcodepoint
JS_DEFINE_NATIVE_FUNCTION(StringConstructor::from_code_point)
{
- Vector<u16> string;
+ Vector<u16, 1> string;
string.ensure_capacity(vm.argument_count()); // This will be an under-estimate if any code point is > 0xffff.
for (size_t i = 0; i < vm.argument_count(); ++i) {
diff --git a/Userland/Libraries/LibJS/Runtime/Utf16String.cpp b/Userland/Libraries/LibJS/Runtime/Utf16String.cpp
index b2e40c252f..e5ad11e822 100644
--- a/Userland/Libraries/LibJS/Runtime/Utf16String.cpp
+++ b/Userland/Libraries/LibJS/Runtime/Utf16String.cpp
@@ -17,7 +17,7 @@ static NonnullRefPtr<Utf16StringImpl> the_empty_utf16_string()
return empty_string;
}
-Utf16StringImpl::Utf16StringImpl(Vector<u16> string)
+Utf16StringImpl::Utf16StringImpl(Vector<u16, 1> string)
: m_string(move(string))
{
}
@@ -27,7 +27,7 @@ NonnullRefPtr<Utf16StringImpl> Utf16StringImpl::create()
return adopt_ref(*new Utf16StringImpl());
}
-NonnullRefPtr<Utf16StringImpl> Utf16StringImpl::create(Vector<u16> string)
+NonnullRefPtr<Utf16StringImpl> Utf16StringImpl::create(Vector<u16, 1> string)
{
return adopt_ref(*new Utf16StringImpl(move(string)));
}
@@ -39,13 +39,13 @@ NonnullRefPtr<Utf16StringImpl> Utf16StringImpl::create(StringView const& string)
NonnullRefPtr<Utf16StringImpl> Utf16StringImpl::create(Utf16View const& view)
{
- Vector<u16> string;
+ Vector<u16, 1> string;
string.ensure_capacity(view.length_in_code_units());
string.append(view.data(), view.length_in_code_units());
return create(move(string));
}
-Vector<u16> const& Utf16StringImpl::string() const
+Vector<u16, 1> const& Utf16StringImpl::string() const
{
return m_string;
}
@@ -62,7 +62,7 @@ Utf16String::Utf16String()
{
}
-Utf16String::Utf16String(Vector<u16> string)
+Utf16String::Utf16String(Vector<u16, 1> string)
: m_string(Detail::Utf16StringImpl::create(move(string)))
{
}
@@ -77,7 +77,7 @@ Utf16String::Utf16String(Utf16View const& string)
{
}
-Vector<u16> const& Utf16String::string() const
+Vector<u16, 1> const& Utf16String::string() const
{
return m_string->string();
}
diff --git a/Userland/Libraries/LibJS/Runtime/Utf16String.h b/Userland/Libraries/LibJS/Runtime/Utf16String.h
index 640de51218..e38e5b4592 100644
--- a/Userland/Libraries/LibJS/Runtime/Utf16String.h
+++ b/Userland/Libraries/LibJS/Runtime/Utf16String.h
@@ -20,18 +20,18 @@ public:
~Utf16StringImpl() = default;
static NonnullRefPtr<Utf16StringImpl> create();
- static NonnullRefPtr<Utf16StringImpl> create(Vector<u16>);
+ static NonnullRefPtr<Utf16StringImpl> create(Vector<u16, 1>);
static NonnullRefPtr<Utf16StringImpl> create(StringView const&);
static NonnullRefPtr<Utf16StringImpl> create(Utf16View const&);
- Vector<u16> const& string() const;
+ Vector<u16, 1> const& string() const;
Utf16View view() const;
private:
Utf16StringImpl() = default;
- explicit Utf16StringImpl(Vector<u16> string);
+ explicit Utf16StringImpl(Vector<u16, 1> string);
- Vector<u16> m_string;
+ Vector<u16, 1> m_string;
};
}
@@ -39,11 +39,11 @@ private:
class Utf16String {
public:
Utf16String();
- explicit Utf16String(Vector<u16>);
+ explicit Utf16String(Vector<u16, 1>);
explicit Utf16String(StringView const&);
explicit Utf16String(Utf16View const&);
- Vector<u16> const& string() const;
+ Vector<u16, 1> const& string() const;
Utf16View view() const;
Utf16View substring_view(size_t code_unit_offset, size_t code_unit_length) const;
Utf16View substring_view(size_t code_unit_offset) const;
diff --git a/Userland/Libraries/LibRegex/RegexByteCode.cpp b/Userland/Libraries/LibRegex/RegexByteCode.cpp
index 231c076d10..2b6bc146c7 100644
--- a/Userland/Libraries/LibRegex/RegexByteCode.cpp
+++ b/Userland/Libraries/LibRegex/RegexByteCode.cpp
@@ -470,7 +470,7 @@ ALWAYS_INLINE ExecutionResult OpCode_Compare::execute(MatchInput const& input, M
return ExecutionResult::Failed_ExecuteLowPrioForks;
Optional<String> str;
- Vector<u16> utf16;
+ Vector<u16, 1> utf16;
Vector<u32> data;
data.ensure_capacity(length);
for (size_t i = offset; i < offset + length; ++i)
@@ -557,7 +557,7 @@ ALWAYS_INLINE void OpCode_Compare::compare_char(MatchInput const& input, MatchSt
auto input_view = input.view.substring_view(state.string_position, 1);
Optional<String> str;
- Vector<u16> utf16;
+ Vector<u16, 1> utf16;
auto compare_view = input_view.construct_as_same({ &ch1, 1 }, str, utf16);
bool equal;
if (input.regex_options & AllFlags::Insensitive)
diff --git a/Userland/Libraries/LibRegex/RegexMatch.h b/Userland/Libraries/LibRegex/RegexMatch.h
index 60a1241eb3..6d707650ee 100644
--- a/Userland/Libraries/LibRegex/RegexMatch.h
+++ b/Userland/Libraries/LibRegex/RegexMatch.h
@@ -139,7 +139,7 @@ public:
return view;
}
- RegexStringView construct_as_same(Span<u32> data, Optional<String>& optional_string_storage, Vector<u16>& optional_utf16_storage) const
+ RegexStringView construct_as_same(Span<u32> data, Optional<String>& optional_string_storage, Vector<u16, 1>& optional_utf16_storage) const
{
auto view = m_view.visit(
[&]<typename T>(T const&) {