mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-07-31 13:19:05 +00:00
LibWeb: Make Element::html_uppercased_qualified_name() lazy
Many elements never end up needing this string, so instead of eagerly generating it in the Element constructor, let's defer it until someone actually requests it. Knocks off a ~1% profile item on Speedometer3's jQuery test.
This commit is contained in:
parent
94cc4adefd
commit
7884e58b5c
Notes:
github-actions[bot]
2025-04-20 16:44:23 +00:00
Author: https://github.com/awesomekling
Commit: 7884e58b5c
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/4408
2 changed files with 13 additions and 8 deletions
|
@ -90,7 +90,6 @@ Element::Element(Document& document, DOM::QualifiedName qualified_name)
|
||||||
: ParentNode(document, NodeType::ELEMENT_NODE)
|
: ParentNode(document, NodeType::ELEMENT_NODE)
|
||||||
, m_qualified_name(move(qualified_name))
|
, m_qualified_name(move(qualified_name))
|
||||||
{
|
{
|
||||||
make_html_uppercased_qualified_name();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Element::~Element() = default;
|
Element::~Element() = default;
|
||||||
|
@ -952,13 +951,12 @@ void Element::set_inline_style(GC::Ptr<CSS::CSSStyleProperties> style)
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://dom.spec.whatwg.org/#element-html-uppercased-qualified-name
|
// https://dom.spec.whatwg.org/#element-html-uppercased-qualified-name
|
||||||
void Element::make_html_uppercased_qualified_name()
|
FlyString Element::make_html_uppercased_qualified_name() const
|
||||||
{
|
{
|
||||||
// This is allowed by the spec: "User agents could optimize qualified name and HTML-uppercased qualified name by storing them in internal slots."
|
// This is allowed by the spec: "User agents could optimize qualified name and HTML-uppercased qualified name by storing them in internal slots."
|
||||||
if (namespace_uri() == Namespace::HTML && document().document_type() == Document::Type::HTML)
|
if (namespace_uri() == Namespace::HTML && document().document_type() == Document::Type::HTML)
|
||||||
m_html_uppercased_qualified_name = qualified_name().to_ascii_uppercase();
|
return qualified_name().to_ascii_uppercase();
|
||||||
else
|
return qualified_name();
|
||||||
m_html_uppercased_qualified_name = qualified_name();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://html.spec.whatwg.org/multipage/webappapis.html#queue-an-element-task
|
// https://html.spec.whatwg.org/multipage/webappapis.html#queue-an-element-task
|
||||||
|
@ -3853,4 +3851,11 @@ GC::Ptr<NamedNodeMap const> Element::attributes() const
|
||||||
return const_cast<Element&>(*this).attributes();
|
return const_cast<Element&>(*this).attributes();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FlyString const& Element::html_uppercased_qualified_name() const
|
||||||
|
{
|
||||||
|
if (!m_html_uppercased_qualified_name.has_value())
|
||||||
|
m_html_uppercased_qualified_name = make_html_uppercased_qualified_name();
|
||||||
|
return m_html_uppercased_qualified_name.value();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -110,7 +110,7 @@ public:
|
||||||
virtual ~Element() override;
|
virtual ~Element() override;
|
||||||
|
|
||||||
FlyString const& qualified_name() const { return m_qualified_name.as_string(); }
|
FlyString const& qualified_name() const { return m_qualified_name.as_string(); }
|
||||||
FlyString const& html_uppercased_qualified_name() const { return m_html_uppercased_qualified_name; }
|
FlyString const& html_uppercased_qualified_name() const;
|
||||||
|
|
||||||
virtual FlyString node_name() const final { return html_uppercased_qualified_name(); }
|
virtual FlyString node_name() const final { return html_uppercased_qualified_name(); }
|
||||||
FlyString const& local_name() const { return m_qualified_name.local_name(); }
|
FlyString const& local_name() const { return m_qualified_name.local_name(); }
|
||||||
|
@ -497,7 +497,7 @@ protected:
|
||||||
CustomElementState custom_element_state() const { return m_custom_element_state; }
|
CustomElementState custom_element_state() const { return m_custom_element_state; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void make_html_uppercased_qualified_name();
|
FlyString make_html_uppercased_qualified_name() const;
|
||||||
|
|
||||||
void invalidate_style_after_attribute_change(FlyString const& attribute_name, Optional<String> const& old_value, Optional<String> const& new_value);
|
void invalidate_style_after_attribute_change(FlyString const& attribute_name, Optional<String> const& old_value, Optional<String> const& new_value);
|
||||||
|
|
||||||
|
@ -511,7 +511,7 @@ private:
|
||||||
bool is_auto_directionality_form_associated_element() const;
|
bool is_auto_directionality_form_associated_element() const;
|
||||||
|
|
||||||
QualifiedName m_qualified_name;
|
QualifiedName m_qualified_name;
|
||||||
FlyString m_html_uppercased_qualified_name;
|
mutable Optional<FlyString> m_html_uppercased_qualified_name;
|
||||||
|
|
||||||
GC::Ptr<NamedNodeMap> m_attributes;
|
GC::Ptr<NamedNodeMap> m_attributes;
|
||||||
GC::Ptr<CSS::CSSStyleProperties> m_inline_style;
|
GC::Ptr<CSS::CSSStyleProperties> m_inline_style;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue