mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-07-30 12:49:19 +00:00
LibWeb: Avoid full tree traversal for non-subject :has()
invalidation
Instead of checking all elements in a document for containment in `:has()` invalidation set, we could narrow this down to ancestors and ancestor siblings, like we already do for subject `:has()` invalidation. This change brings great improvement on GitHub that has selectors with non-subject `:has()` and sibling combinators (e.g., `.a:has(.b) ~ .c`) which prior to this change meant style invalidation for whole document.
This commit is contained in:
parent
604400f758
commit
327dc8e82a
Notes:
github-actions[bot]
2025-02-13 15:25:48 +00:00
Author: https://github.com/kalenikaliaksandr
Commit: 327dc8e82a
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/3552
6 changed files with 42 additions and 54 deletions
|
@ -508,8 +508,12 @@ static inline bool matches_pseudo_class(CSS::Selector::SimpleSelector::PseudoCla
|
|||
// :has() cannot be nested in a :has()
|
||||
if (selector_kind == SelectorKind::Relative)
|
||||
return false;
|
||||
if (context.collect_per_element_selector_involvement_metadata && &element == context.subject) {
|
||||
const_cast<DOM::Element&>(element).set_affected_by_has_pseudo_class_in_subject_position(true);
|
||||
if (context.collect_per_element_selector_involvement_metadata) {
|
||||
if (&element == context.subject) {
|
||||
const_cast<DOM::Element&>(element).set_affected_by_has_pseudo_class_in_subject_position(true);
|
||||
} else {
|
||||
const_cast<DOM::Element&>(element).set_affected_by_has_pseudo_class_in_non_subject_position(true);
|
||||
}
|
||||
}
|
||||
// These selectors should be relative selectors (https://drafts.csswg.org/selectors-4/#relative-selector)
|
||||
for (auto& selector : pseudo_class.argument_selector_list) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue