1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-25 04:17:35 +00:00

LibWeb: Use table_box() to get root box in TFC

Introduce `table_box()` function that returns table formatting
context root box casted to `TableBox` similar to how it's done
in other formatting contexts like `root()` in BFC and
`flex_container` in FFC. And replace `context_box()` calls
in TFC with calls to `table_box()`.
This commit is contained in:
Aliaksandr Kalenik 2023-01-08 01:54:25 +03:00 committed by Andreas Kling
parent f26eed9633
commit 77a2b151ea
2 changed files with 11 additions and 11 deletions

View file

@ -206,12 +206,11 @@ void TableFormattingContext::compute_table_measures()
void TableFormattingContext::compute_table_width()
{
auto const& table_box = context_box();
auto& table_box_state = m_state.get_mutable(table_box);
auto& table_box_state = m_state.get_mutable(table_box());
auto& computed_values = table_box.computed_values();
auto& computed_values = table_box().computed_values();
CSSPixels width_of_table_containing_block = m_state.get(*table_box.containing_block()).content_width();
CSSPixels width_of_table_containing_block = m_state.get(*table_box().containing_block()).content_width();
// The row/column-grid width minimum (GRIDMIN) width is the sum of the min-content width
// of all the columns plus cell spacing or borders.
@ -230,7 +229,7 @@ void TableFormattingContext::compute_table_width()
// The used min-width of a table is the greater of the resolved min-width, CAPMIN, and GRIDMIN.
auto used_min_width = grid_min;
if (!computed_values.min_width().is_auto()) {
used_min_width = max(used_min_width, computed_values.min_width().resolved(table_box, CSS::Length::make_px(width_of_table_containing_block)).to_px(table_box));
used_min_width = max(used_min_width, computed_values.min_width().resolved(table_box(), CSS::Length::make_px(width_of_table_containing_block)).to_px(table_box()));
}
CSSPixels used_width;
@ -243,7 +242,7 @@ void TableFormattingContext::compute_table_width()
// If the table-roots width property has a computed value (resolving to
// resolved-table-width) other than auto, the used width is the greater
// of resolved-table-width, and the used min-width of the table.
CSSPixels resolved_table_width = computed_values.width().resolved(table_box, CSS::Length::make_px(width_of_table_containing_block)).to_px(table_box);
CSSPixels resolved_table_width = computed_values.width().resolved(table_box(), CSS::Length::make_px(width_of_table_containing_block)).to_px(table_box());
used_width = max(resolved_table_width, used_min_width);
table_box_state.set_content_width(used_width);
}
@ -253,7 +252,7 @@ void TableFormattingContext::distribute_width_to_columns()
{
// Implements https://www.w3.org/TR/css-tables-3/#width-distribution-algorithm
CSSPixels available_width = m_state.get(context_box()).content_width();
CSSPixels available_width = m_state.get(table_box()).content_width();
auto columns_total_used_width = [&]() {
CSSPixels total_used_width = 0;
@ -346,8 +345,7 @@ void TableFormattingContext::distribute_width_to_columns()
void TableFormattingContext::determine_intrisic_size_of_table_container(AvailableSpace const& available_space)
{
auto const& table_box = context_box();
auto& table_box_state = m_state.get_mutable(table_box);
auto& table_box_state = m_state.get_mutable(table_box());
if (available_space.width.is_min_content()) {
// The min-content width of a table is the width required to fit all of its columns min-content widths and its undistributable spaces.
@ -426,7 +424,7 @@ void TableFormattingContext::position_row_boxes()
}
CSSPixels row_group_top_offset = 0.0f;
context_box().for_each_child_of_type<TableRowGroupBox>([&](auto& row_group_box) {
table_box().for_each_child_of_type<TableRowGroupBox>([&](auto& row_group_box) {
CSSPixels row_group_height = 0.0f;
CSSPixels row_group_width = 0.0f;
@ -511,7 +509,7 @@ void TableFormattingContext::run(Box const& box, LayoutMode, AvailableSpace cons
position_row_boxes();
position_cell_boxes();
m_state.get_mutable(context_box()).set_content_height(total_content_height);
m_state.get_mutable(table_box()).set_content_height(total_content_height);
// FIXME: This is a total hack, we should respect the 'height' property.
m_automatic_content_height = total_content_height;