mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-08-02 22:30:31 +00:00
LibWeb: Update style (if needed) before updating layout
Layout depends on style (and not the other way around), so if the document has dirty style when we enter update_layout(), make sure we call update_style() before proceeding with the layout work. This has the pleasant effect of coalescing some redundant layouts.
This commit is contained in:
parent
23f4ff7247
commit
13361bc47d
Notes:
sideshowbarker
2024-07-18 02:56:11 +09:00
Author: https://github.com/awesomekling
Commit: 13361bc47d
1 changed files with 4 additions and 0 deletions
|
@ -430,6 +430,8 @@ void Document::update_layout()
|
|||
if (!browsing_context())
|
||||
return;
|
||||
|
||||
update_style();
|
||||
|
||||
if (!m_layout_root) {
|
||||
Layout::TreeBuilder tree_builder;
|
||||
m_layout_root = static_ptr_cast<Layout::InitialContainingBlock>(tree_builder.build(*this));
|
||||
|
@ -468,6 +470,8 @@ void Document::update_style()
|
|||
{
|
||||
if (!browsing_context())
|
||||
return;
|
||||
if (!needs_style_update() && !child_needs_style_update())
|
||||
return;
|
||||
update_style_recursively(*this);
|
||||
set_needs_layout();
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue