mirror of
https://github.com/servo/servo.git
synced 2025-06-06 16:45:39 +00:00
Assign table row block sizes in the parent table or rowgroup
This commit is contained in:
parent
2c2f8be1cc
commit
2a0e1cd9c9
4 changed files with 68 additions and 54 deletions
|
@ -496,10 +496,10 @@ impl Flow for TableFlow {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
fn assign_block_size(&mut self, _: &LayoutContext) {
|
fn assign_block_size(&mut self, lc: &LayoutContext) {
|
||||||
debug!("assign_block_size: assigning block_size for table");
|
debug!("assign_block_size: assigning block_size for table");
|
||||||
let vertical_spacing = self.spacing().vertical();
|
let vertical_spacing = self.spacing().vertical();
|
||||||
self.block_flow.assign_block_size_for_table_like_flow(vertical_spacing)
|
self.block_flow.assign_block_size_for_table_like_flow(vertical_spacing, lc)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn compute_stacking_relative_position(&mut self, layout_context: &LayoutContext) {
|
fn compute_stacking_relative_position(&mut self, layout_context: &LayoutContext) {
|
||||||
|
@ -771,15 +771,22 @@ fn perform_border_collapse_for_row(child_table_row: &mut TableRowFlow,
|
||||||
/// rowgroups.
|
/// rowgroups.
|
||||||
pub trait TableLikeFlow {
|
pub trait TableLikeFlow {
|
||||||
/// Lays out the rows of a table.
|
/// Lays out the rows of a table.
|
||||||
fn assign_block_size_for_table_like_flow(&mut self, block_direction_spacing: Au);
|
fn assign_block_size_for_table_like_flow(&mut self, block_direction_spacing: Au,
|
||||||
|
layout_context: &LayoutContext);
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TableLikeFlow for BlockFlow {
|
impl TableLikeFlow for BlockFlow {
|
||||||
fn assign_block_size_for_table_like_flow(&mut self, block_direction_spacing: Au) {
|
fn assign_block_size_for_table_like_flow(&mut self, block_direction_spacing: Au,
|
||||||
|
layout_context: &LayoutContext) {
|
||||||
debug_assert!(self.fragment.style.get_inheritedtable().border_collapse ==
|
debug_assert!(self.fragment.style.get_inheritedtable().border_collapse ==
|
||||||
border_collapse::T::Separate || block_direction_spacing == Au(0));
|
border_collapse::T::Separate || block_direction_spacing == Au(0));
|
||||||
|
|
||||||
if self.base.restyle_damage.contains(ServoRestyleDamage::REFLOW) {
|
if self.base.restyle_damage.contains(ServoRestyleDamage::REFLOW) {
|
||||||
|
for kid in self.base.child_iter_mut() {
|
||||||
|
if kid.is_table_row() {
|
||||||
|
kid.as_mut_table_row().assign_block_size_table_row_base(layout_context)
|
||||||
|
}
|
||||||
|
}
|
||||||
// Our current border-box position.
|
// Our current border-box position.
|
||||||
let block_start_border_padding = self.fragment.border_padding.block_start;
|
let block_start_border_padding = self.fragment.border_padding.block_start;
|
||||||
let mut current_block_offset = block_start_border_padding;
|
let mut current_block_offset = block_start_border_padding;
|
||||||
|
|
|
@ -148,6 +148,17 @@ impl TableCellFlow {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Total block size of child
|
||||||
|
//
|
||||||
|
// Call after block size calculation
|
||||||
|
pub fn total_block_size(&mut self) -> Au {
|
||||||
|
// TODO: Percentage block-size
|
||||||
|
let specified = MaybeAuto::from_style(self.fragment().style()
|
||||||
|
.content_block_size(),
|
||||||
|
Au(0)).specified_or_zero();
|
||||||
|
specified + self.fragment().border_padding.block_start_end()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Flow for TableCellFlow {
|
impl Flow for TableCellFlow {
|
||||||
|
|
|
@ -114,7 +114,7 @@ impl TableRowFlow {
|
||||||
/// inline(always) because this is only ever called by in-order or non-in-order top-level
|
/// inline(always) because this is only ever called by in-order or non-in-order top-level
|
||||||
/// methods
|
/// methods
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
fn assign_block_size_table_row_base(&mut self, layout_context: &LayoutContext) {
|
pub fn assign_block_size_table_row_base(&mut self, layout_context: &LayoutContext) {
|
||||||
if self.block_flow.base.restyle_damage.contains(ServoRestyleDamage::REFLOW) {
|
if self.block_flow.base.restyle_damage.contains(ServoRestyleDamage::REFLOW) {
|
||||||
// Per CSS 2.1 § 17.5.3, find max_y = max(computed `block-size`, minimum block-size of
|
// Per CSS 2.1 § 17.5.3, find max_y = max(computed `block-size`, minimum block-size of
|
||||||
// all cells).
|
// all cells).
|
||||||
|
@ -132,15 +132,8 @@ impl TableRowFlow {
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
let child_fragment = kid.as_mut_table_cell().fragment();
|
|
||||||
// TODO: Percentage block-size
|
|
||||||
let child_specified_block_size =
|
|
||||||
MaybeAuto::from_style(child_fragment.style().content_block_size(),
|
|
||||||
Au(0)).specified_or_zero();
|
|
||||||
max_block_size =
|
max_block_size =
|
||||||
max(max_block_size,
|
max(max_block_size, kid.as_mut_table_cell().total_block_size());
|
||||||
child_specified_block_size +
|
|
||||||
child_fragment.border_padding.block_start_end());
|
|
||||||
}
|
}
|
||||||
let child_node = kid.mut_base();
|
let child_node = kid.mut_base();
|
||||||
child_node.position.start.b = Au(0);
|
child_node.position.start.b = Au(0);
|
||||||
|
@ -158,47 +151,51 @@ impl TableRowFlow {
|
||||||
MaybeAuto::Specified(value) => max(value, block_size),
|
MaybeAuto::Specified(value) => max(value, block_size),
|
||||||
};
|
};
|
||||||
|
|
||||||
// Assign the block-size of own fragment
|
self.assign_block_size_to_self_and_children(block_size);
|
||||||
let mut position = self.block_flow.fragment.border_box;
|
|
||||||
position.size.block = block_size;
|
|
||||||
self.block_flow.fragment.border_box = position;
|
|
||||||
self.block_flow.base.position.size.block = block_size;
|
|
||||||
|
|
||||||
// Assign the block-size of kid fragments, which is the same value as own block-size.
|
|
||||||
for kid in self.block_flow.base.child_iter_mut() {
|
|
||||||
let child_table_cell = kid.as_mut_table_cell();
|
|
||||||
{
|
|
||||||
let kid_fragment = child_table_cell.mut_fragment();
|
|
||||||
let mut position = kid_fragment.border_box;
|
|
||||||
position.size.block = block_size;
|
|
||||||
kid_fragment.border_box = position;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Assign the child's block size.
|
|
||||||
child_table_cell.block_flow.base.position.size.block = block_size;
|
|
||||||
|
|
||||||
// Now we know the cell height, vertical align the cell's children.
|
|
||||||
child_table_cell.valign_children();
|
|
||||||
|
|
||||||
// Write in the size of the relative containing block for children. (This
|
|
||||||
// information is also needed to handle RTL.)
|
|
||||||
child_table_cell.block_flow.base.early_absolute_position_info =
|
|
||||||
EarlyAbsolutePositionInfo {
|
|
||||||
relative_containing_block_size: self.block_flow
|
|
||||||
.fragment
|
|
||||||
.content_box()
|
|
||||||
.size,
|
|
||||||
relative_containing_block_mode: self.block_flow
|
|
||||||
.fragment
|
|
||||||
.style()
|
|
||||||
.writing_mode,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
self.block_flow.base.restyle_damage.remove(ServoRestyleDamage::REFLOW_OUT_OF_FLOW | ServoRestyleDamage::REFLOW);
|
self.block_flow.base.restyle_damage.remove(ServoRestyleDamage::REFLOW_OUT_OF_FLOW | ServoRestyleDamage::REFLOW);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn assign_block_size_to_self_and_children(&mut self, block_size: Au) {
|
||||||
|
// Assign the block-size of kid fragments, which is the same value as own block-size.
|
||||||
|
for kid in self.block_flow.base.child_iter_mut() {
|
||||||
|
let child_table_cell = kid.as_mut_table_cell();
|
||||||
|
{
|
||||||
|
let kid_fragment = child_table_cell.mut_fragment();
|
||||||
|
let mut position = kid_fragment.border_box;
|
||||||
|
position.size.block = block_size;
|
||||||
|
kid_fragment.border_box = position;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Assign the child's block size.
|
||||||
|
child_table_cell.block_flow.base.position.size.block = block_size;
|
||||||
|
|
||||||
|
// Now we know the cell height, vertical align the cell's children.
|
||||||
|
child_table_cell.valign_children();
|
||||||
|
|
||||||
|
// Write in the size of the relative containing block for children. (This
|
||||||
|
// information is also needed to handle RTL.)
|
||||||
|
child_table_cell.block_flow.base.early_absolute_position_info =
|
||||||
|
EarlyAbsolutePositionInfo {
|
||||||
|
relative_containing_block_size: self.block_flow
|
||||||
|
.fragment
|
||||||
|
.content_box()
|
||||||
|
.size,
|
||||||
|
relative_containing_block_mode: self.block_flow
|
||||||
|
.fragment
|
||||||
|
.style()
|
||||||
|
.writing_mode,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// Assign the block-size of own fragment
|
||||||
|
let mut position = self.block_flow.fragment.border_box;
|
||||||
|
position.size.block = block_size;
|
||||||
|
self.block_flow.fragment.border_box = position;
|
||||||
|
self.block_flow.base.position.size.block = block_size;
|
||||||
|
}
|
||||||
|
|
||||||
pub fn populate_collapsed_border_spacing<'a, I>(
|
pub fn populate_collapsed_border_spacing<'a, I>(
|
||||||
&mut self,
|
&mut self,
|
||||||
collapsed_inline_direction_border_widths_for_table: &[Au],
|
collapsed_inline_direction_border_widths_for_table: &[Au],
|
||||||
|
@ -449,9 +446,8 @@ impl Flow for TableRowFlow {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn assign_block_size(&mut self, layout_context: &LayoutContext) {
|
fn assign_block_size(&mut self, _: &LayoutContext) {
|
||||||
debug!("assign_block_size: assigning block_size for table_row");
|
// the surrounding table or rowgroup does this
|
||||||
self.assign_block_size_table_row_base(layout_context);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn compute_stacking_relative_position(&mut self, layout_context: &LayoutContext) {
|
fn compute_stacking_relative_position(&mut self, layout_context: &LayoutContext) {
|
||||||
|
|
|
@ -159,9 +159,9 @@ impl Flow for TableRowGroupFlow {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
fn assign_block_size(&mut self, _: &LayoutContext) {
|
fn assign_block_size(&mut self, lc: &LayoutContext) {
|
||||||
debug!("assign_block_size: assigning block_size for table_rowgroup");
|
debug!("assign_block_size: assigning block_size for table_rowgroup");
|
||||||
self.block_flow.assign_block_size_for_table_like_flow(self.spacing.vertical());
|
self.block_flow.assign_block_size_for_table_like_flow(self.spacing.vertical(), lc);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn compute_stacking_relative_position(&mut self, layout_context: &LayoutContext) {
|
fn compute_stacking_relative_position(&mut self, layout_context: &LayoutContext) {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue