mirror of
https://github.com/servo/servo.git
synced 2025-08-11 16:35:33 +01:00
Rework the way scroll roots are collected
Collect scroll roots during the collect_stacking_context phase instead of during display list construction. This will be useful in order to collect containing block scroll roots as well as to give scroll roots sequential ids in the future. This change also pulls stacking context children out of the StackingContext struct itself, which should reduce very slightly the memory used by the finished display list. This also simplifies the DisplayListBuilder because it no longer has to maintain a stack of ScrollRootIds and StackingContextIds and can instead just rely on the program stack.
This commit is contained in:
parent
124301cf48
commit
29876d2703
17 changed files with 227 additions and 275 deletions
|
@ -303,9 +303,6 @@ pub struct StackingContext {
|
|||
/// The scroll policy of this layer.
|
||||
pub scroll_policy: ScrollPolicy,
|
||||
|
||||
/// Children of this StackingContext.
|
||||
pub children: Vec<StackingContext>,
|
||||
|
||||
/// The id of the parent scrolling area that contains this StackingContext.
|
||||
pub parent_scroll_id: ScrollRootId,
|
||||
}
|
||||
|
@ -338,7 +335,6 @@ impl StackingContext {
|
|||
perspective: perspective,
|
||||
establishes_3d_context: establishes_3d_context,
|
||||
scroll_policy: scroll_policy,
|
||||
children: Vec::new(),
|
||||
parent_scroll_id: parent_scroll_id,
|
||||
}
|
||||
}
|
||||
|
@ -359,32 +355,7 @@ impl StackingContext {
|
|||
ScrollRootId::root())
|
||||
}
|
||||
|
||||
pub fn add_child(&mut self, mut child: StackingContext) {
|
||||
child.update_overflow_for_all_children();
|
||||
self.children.push(child);
|
||||
}
|
||||
|
||||
pub fn child_at_mut(&mut self, index: usize) -> &mut StackingContext {
|
||||
&mut self.children[index]
|
||||
}
|
||||
|
||||
pub fn children(&self) -> &[StackingContext] {
|
||||
&self.children
|
||||
}
|
||||
|
||||
fn update_overflow_for_all_children(&mut self) {
|
||||
for child in self.children.iter() {
|
||||
if self.context_type == StackingContextType::Real &&
|
||||
child.context_type == StackingContextType::Real {
|
||||
// This child might be transformed, so we need to take into account
|
||||
// its transformed overflow rect too, but at the correct position.
|
||||
let overflow = child.overflow_rect_in_parent_space();
|
||||
self.overflow = self.overflow.union(&overflow);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn overflow_rect_in_parent_space(&self) -> Rect<Au> {
|
||||
pub fn overflow_rect_in_parent_space(&self) -> Rect<Au> {
|
||||
// Transform this stacking context to get it into the same space as
|
||||
// the parent stacking context.
|
||||
//
|
||||
|
@ -402,14 +373,6 @@ impl StackingContext {
|
|||
f32_rect_to_au_rect(overflow)
|
||||
}
|
||||
|
||||
pub fn print_with_tree(&self, print_tree: &mut PrintTree) {
|
||||
print_tree.new_level(format!("{:?}", self));
|
||||
for kid in self.children() {
|
||||
kid.print_with_tree(print_tree);
|
||||
}
|
||||
print_tree.end_level();
|
||||
}
|
||||
|
||||
pub fn to_display_list_items(self) -> (DisplayItem, DisplayItem) {
|
||||
let mut base_item = BaseDisplayItem::empty();
|
||||
base_item.stacking_context_id = self.id;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue