mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-07-30 04:39:06 +00:00
LibWeb: Move perform_pending_style_invalidations()
in StyleInvalidator
This change introduces StyleInvalidator as a preparation for upcoming change that will make `perform_pending_style_invalidations()` take care of pending invalidation sets.
This commit is contained in:
parent
03256a2543
commit
8cbe27b2f9
Notes:
github-actions[bot]
2025-07-16 22:44:32 +00:00
Author: https://github.com/kalenikaliaksandr
Commit: 8cbe27b2f9
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/5474
6 changed files with 74 additions and 29 deletions
|
@ -282,6 +282,7 @@ set(SOURCES
|
|||
DOM/StaticNodeList.cpp
|
||||
DOM/StaticRange.cpp
|
||||
DOM/StyleElementUtils.cpp
|
||||
DOM/StyleInvalidator.cpp
|
||||
DOM/Text.cpp
|
||||
DOM/TreeWalker.cpp
|
||||
DOM/Utils.cpp
|
||||
|
|
|
@ -76,6 +76,7 @@
|
|||
#include <LibWeb/DOM/ProcessingInstruction.h>
|
||||
#include <LibWeb/DOM/Range.h>
|
||||
#include <LibWeb/DOM/ShadowRoot.h>
|
||||
#include <LibWeb/DOM/StyleInvalidator.h>
|
||||
#include <LibWeb/DOM/Text.h>
|
||||
#include <LibWeb/DOM/TreeWalker.h>
|
||||
#include <LibWeb/DOM/Utils.h>
|
||||
|
@ -459,6 +460,7 @@ Document::Document(JS::Realm& realm, const URL::URL& url, TemporaryDocumentForFr
|
|||
, m_url(url)
|
||||
, m_temporary_document_for_fragment_parsing(temporary_document_for_fragment_parsing)
|
||||
, m_editing_host_manager(EditingHostManager::create(realm, *this))
|
||||
, m_style_invalidator(realm.heap().allocate<StyleInvalidator>())
|
||||
{
|
||||
m_legacy_platform_object_flags = PlatformObject::LegacyPlatformObjectFlags {
|
||||
.supports_named_properties = true,
|
||||
|
@ -616,6 +618,7 @@ void Document::visit_edges(Cell::Visitor& visitor)
|
|||
visitor.visit(m_session_storage_holder);
|
||||
visitor.visit(m_render_blocking_elements);
|
||||
visitor.visit(m_policy_container);
|
||||
visitor.visit(m_style_invalidator);
|
||||
}
|
||||
|
||||
// https://w3c.github.io/selection-api/#dom-document-getselection
|
||||
|
@ -1492,34 +1495,6 @@ void Document::update_layout(UpdateLayoutReason reason)
|
|||
return invalidation;
|
||||
}
|
||||
|
||||
// This function makes a full pass over the entire DOM and converts "entire subtree needs style update"
|
||||
// into "needs style update" for each inclusive descendant where it's found.
|
||||
static void perform_pending_style_invalidations(Node& node, bool invalidate_entire_subtree)
|
||||
{
|
||||
invalidate_entire_subtree |= node.entire_subtree_needs_style_update();
|
||||
|
||||
if (invalidate_entire_subtree) {
|
||||
node.set_needs_style_update_internal(true);
|
||||
if (node.has_child_nodes())
|
||||
node.set_child_needs_style_update(true);
|
||||
}
|
||||
|
||||
for (auto* child = node.first_child(); child; child = child->next_sibling()) {
|
||||
perform_pending_style_invalidations(*child, invalidate_entire_subtree);
|
||||
}
|
||||
|
||||
if (node.is_element()) {
|
||||
auto& element = static_cast<Element&>(node);
|
||||
if (auto shadow_root = element.shadow_root()) {
|
||||
perform_pending_style_invalidations(*shadow_root, invalidate_entire_subtree);
|
||||
if (invalidate_entire_subtree)
|
||||
node.set_child_needs_style_update(true);
|
||||
}
|
||||
}
|
||||
|
||||
node.set_entire_subtree_needs_style_update(false);
|
||||
}
|
||||
|
||||
void Document::update_style()
|
||||
{
|
||||
if (!browsing_context())
|
||||
|
@ -1536,7 +1511,7 @@ void Document::update_style()
|
|||
if (!needs_full_style_update() && !needs_style_update() && !child_needs_style_update())
|
||||
return;
|
||||
|
||||
perform_pending_style_invalidations(*this, false);
|
||||
m_style_invalidator->perform_pending_style_invalidations(*this, false);
|
||||
|
||||
// NOTE: If this is a document hosting <template> contents, style update is unnecessary.
|
||||
if (m_created_for_appropriate_template_contents)
|
||||
|
|
|
@ -1261,6 +1261,8 @@ private:
|
|||
HashTable<GC::Ref<Element>> m_render_blocking_elements;
|
||||
|
||||
HashTable<WeakPtr<Node>> m_pending_nodes_for_style_invalidation_due_to_presence_of_has;
|
||||
|
||||
GC::Ref<StyleInvalidator> m_style_invalidator;
|
||||
};
|
||||
|
||||
template<>
|
||||
|
|
44
Libraries/LibWeb/DOM/StyleInvalidator.cpp
Normal file
44
Libraries/LibWeb/DOM/StyleInvalidator.cpp
Normal file
|
@ -0,0 +1,44 @@
|
|||
/*
|
||||
* Copyright (c) 2025, Aliaksandr Kalenik <kalenik.aliaksandr@gmail.com>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <LibWeb/DOM/Element.h>
|
||||
#include <LibWeb/DOM/Node.h>
|
||||
#include <LibWeb/DOM/ShadowRoot.h>
|
||||
#include <LibWeb/DOM/StyleInvalidator.h>
|
||||
|
||||
namespace Web::DOM {
|
||||
|
||||
GC_DEFINE_ALLOCATOR(StyleInvalidator);
|
||||
|
||||
// This function makes a full pass over the entire DOM and converts "entire subtree needs style update"
|
||||
// into "needs style update" for each inclusive descendant where it's found.
|
||||
void StyleInvalidator::perform_pending_style_invalidations(Node& node, bool invalidate_entire_subtree)
|
||||
{
|
||||
invalidate_entire_subtree |= node.entire_subtree_needs_style_update();
|
||||
|
||||
if (invalidate_entire_subtree) {
|
||||
node.set_needs_style_update_internal(true);
|
||||
if (node.has_child_nodes())
|
||||
node.set_child_needs_style_update(true);
|
||||
}
|
||||
|
||||
for (auto* child = node.first_child(); child; child = child->next_sibling()) {
|
||||
perform_pending_style_invalidations(*child, invalidate_entire_subtree);
|
||||
}
|
||||
|
||||
if (node.is_element()) {
|
||||
auto& element = static_cast<Element&>(node);
|
||||
if (auto shadow_root = element.shadow_root()) {
|
||||
perform_pending_style_invalidations(*shadow_root, invalidate_entire_subtree);
|
||||
if (invalidate_entire_subtree)
|
||||
node.set_child_needs_style_update(true);
|
||||
}
|
||||
}
|
||||
|
||||
node.set_entire_subtree_needs_style_update(false);
|
||||
}
|
||||
|
||||
}
|
22
Libraries/LibWeb/DOM/StyleInvalidator.h
Normal file
22
Libraries/LibWeb/DOM/StyleInvalidator.h
Normal file
|
@ -0,0 +1,22 @@
|
|||
/*
|
||||
* Copyright (c) 2025, Aliaksandr Kalenik <kalenik.aliaksandr@gmail.com>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <LibGC/CellAllocator.h>
|
||||
#include <LibWeb/Forward.h>
|
||||
|
||||
namespace Web::DOM {
|
||||
|
||||
class StyleInvalidator : public GC::Cell {
|
||||
GC_CELL(StyleInvalidator, GC::Cell);
|
||||
GC_DECLARE_ALLOCATOR(StyleInvalidator);
|
||||
|
||||
public:
|
||||
void perform_pending_style_invalidations(Node& node, bool invalidate_entire_subtree);
|
||||
};
|
||||
|
||||
}
|
|
@ -402,6 +402,7 @@ class RegisteredObserver;
|
|||
class ShadowRoot;
|
||||
class StaticNodeList;
|
||||
class StaticRange;
|
||||
class StyleInvalidator;
|
||||
class Text;
|
||||
class TreeWalker;
|
||||
class XMLDocument;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue