mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-10-19 15:43:20 +00:00
LibWeb: Dont load a style sheet's fonts until it has an owning document
We need a style sheet to have an owning document to load it's fonts (to generate a length resolution context). Fixes #6445
This commit is contained in:
parent
9651969708
commit
2af071380e
Notes:
github-actions[bot]
2025-10-16 09:28:36 +00:00
Author: https://github.com/Calme1709
Commit: 2af071380e
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/6482
Reviewed-by: https://github.com/tcl3 ✅
5 changed files with 28 additions and 6 deletions
|
@ -322,6 +322,11 @@ void CSSStyleSheet::add_owning_document_or_shadow_root(DOM::Node& document_or_sh
|
|||
VERIFY(document_or_shadow_root.is_document() || document_or_shadow_root.is_shadow_root());
|
||||
m_owning_documents_or_shadow_roots.set(document_or_shadow_root);
|
||||
|
||||
// All owning documents or shadow roots must be part of the same document so we only need to load this style
|
||||
// sheet's fonts against the document of the first
|
||||
if (this->owning_documents_or_shadow_roots().size() == 1)
|
||||
document_or_shadow_root.document().style_computer().load_fonts_from_sheet(*this);
|
||||
|
||||
for (auto const& import_rule : m_import_rules) {
|
||||
if (import_rule->loaded_style_sheet())
|
||||
import_rule->loaded_style_sheet()->add_owning_document_or_shadow_root(document_or_shadow_root);
|
||||
|
@ -332,6 +337,11 @@ void CSSStyleSheet::remove_owning_document_or_shadow_root(DOM::Node& document_or
|
|||
{
|
||||
m_owning_documents_or_shadow_roots.remove(document_or_shadow_root);
|
||||
|
||||
// All owning documents or shadow roots must be part of the same document so we only need to unload this style
|
||||
// sheet's fonts once we have none remaining.
|
||||
if (this->owning_documents_or_shadow_roots().size() == 0)
|
||||
document_or_shadow_root.document().style_computer().unload_fonts_from_sheet(*this);
|
||||
|
||||
for (auto const& import_rule : m_import_rules) {
|
||||
if (import_rule->loaded_style_sheet())
|
||||
import_rule->loaded_style_sheet()->remove_owning_document_or_shadow_root(document_or_shadow_root);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue