mirror of
https://github.com/servo/servo.git
synced 2025-07-22 23:03:42 +01:00
layout: Fix some whitespace.
This commit is contained in:
parent
2f3b3eb4c4
commit
002d0672ba
1 changed files with 143 additions and 83 deletions
|
@ -97,7 +97,11 @@ struct BSizeConstraintSolution {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl BSizeConstraintSolution {
|
impl BSizeConstraintSolution {
|
||||||
fn new(block_start: Au, block_end: Au, block_size: Au, margin_block_start: Au, margin_block_end: Au)
|
fn new(block_start: Au,
|
||||||
|
block_end: Au,
|
||||||
|
block_size: Au,
|
||||||
|
margin_block_start: Au,
|
||||||
|
margin_block_end: Au)
|
||||||
-> BSizeConstraintSolution {
|
-> BSizeConstraintSolution {
|
||||||
BSizeConstraintSolution {
|
BSizeConstraintSolution {
|
||||||
block_start: block_start,
|
block_start: block_start,
|
||||||
|
@ -131,90 +135,147 @@ impl BSizeConstraintSolution {
|
||||||
// first box of the element.
|
// first box of the element.
|
||||||
let static_position_block_start = static_b_offset;
|
let static_position_block_start = static_b_offset;
|
||||||
|
|
||||||
let (block_start, block_end, block_size, margin_block_start, margin_block_end) = match (block_start, block_end, block_size) {
|
let (block_start, block_end, block_size, margin_block_start, margin_block_end) =
|
||||||
(MaybeAuto::Auto, MaybeAuto::Auto, MaybeAuto::Auto) => {
|
match (block_start, block_end, block_size) {
|
||||||
let margin_block_start = block_start_margin.specified_or_zero();
|
(MaybeAuto::Auto, MaybeAuto::Auto, MaybeAuto::Auto) => {
|
||||||
let margin_block_end = block_end_margin.specified_or_zero();
|
let margin_block_start = block_start_margin.specified_or_zero();
|
||||||
let block_start = static_position_block_start;
|
let margin_block_end = block_end_margin.specified_or_zero();
|
||||||
// Now it is the same situation as block-start Specified and block-end
|
let block_start = static_position_block_start;
|
||||||
// and block-size Auto.
|
// Now it is the same situation as block-start Specified and block-end
|
||||||
|
// and block-size Auto.
|
||||||
|
|
||||||
let block_size = content_block_size;
|
let block_size = content_block_size;
|
||||||
let sum = block_start + block_size + margin_block_start + margin_block_end;
|
let sum = block_start + block_size + margin_block_start + margin_block_end;
|
||||||
(block_start, available_block_size - sum, block_size, margin_block_start, margin_block_end)
|
(block_start,
|
||||||
}
|
available_block_size - sum,
|
||||||
(MaybeAuto::Specified(block_start), MaybeAuto::Specified(block_end), MaybeAuto::Specified(block_size)) => {
|
block_size,
|
||||||
match (block_start_margin, block_end_margin) {
|
margin_block_start,
|
||||||
(MaybeAuto::Auto, MaybeAuto::Auto) => {
|
margin_block_end)
|
||||||
let total_margin_val = available_block_size - block_start - block_end - block_size;
|
}
|
||||||
(block_start, block_end, block_size,
|
(MaybeAuto::Specified(block_start),
|
||||||
total_margin_val.scale_by(0.5),
|
MaybeAuto::Specified(block_end),
|
||||||
total_margin_val.scale_by(0.5))
|
MaybeAuto::Specified(block_size)) => {
|
||||||
}
|
match (block_start_margin, block_end_margin) {
|
||||||
(MaybeAuto::Specified(margin_block_start), MaybeAuto::Auto) => {
|
(MaybeAuto::Auto, MaybeAuto::Auto) => {
|
||||||
let sum = block_start + block_end + block_size + margin_block_start;
|
let total_margin_val =
|
||||||
(block_start, block_end, block_size, margin_block_start, available_block_size - sum)
|
available_block_size - block_start - block_end - block_size;
|
||||||
}
|
(block_start, block_end, block_size,
|
||||||
(MaybeAuto::Auto, MaybeAuto::Specified(margin_block_end)) => {
|
total_margin_val.scale_by(0.5),
|
||||||
let sum = block_start + block_end + block_size + margin_block_end;
|
total_margin_val.scale_by(0.5))
|
||||||
(block_start, block_end, block_size, available_block_size - sum, margin_block_end)
|
}
|
||||||
}
|
(MaybeAuto::Specified(margin_block_start), MaybeAuto::Auto) => {
|
||||||
(MaybeAuto::Specified(margin_block_start), MaybeAuto::Specified(margin_block_end)) => {
|
let sum = block_start + block_end + block_size + margin_block_start;
|
||||||
// Values are over-constrained. Ignore value for 'block-end'.
|
(block_start,
|
||||||
let sum = block_start + block_size + margin_block_start + margin_block_end;
|
block_end,
|
||||||
(block_start, available_block_size - sum, block_size, margin_block_start, margin_block_end)
|
block_size,
|
||||||
|
margin_block_start,
|
||||||
|
available_block_size - sum)
|
||||||
|
}
|
||||||
|
(MaybeAuto::Auto, MaybeAuto::Specified(margin_block_end)) => {
|
||||||
|
let sum = block_start + block_end + block_size + margin_block_end;
|
||||||
|
(block_start,
|
||||||
|
block_end,
|
||||||
|
block_size,
|
||||||
|
available_block_size - sum,
|
||||||
|
margin_block_end)
|
||||||
|
}
|
||||||
|
(MaybeAuto::Specified(margin_block_start),
|
||||||
|
MaybeAuto::Specified(margin_block_end)) => {
|
||||||
|
// Values are over-constrained. Ignore value for 'block-end'.
|
||||||
|
let sum = block_start + block_size + margin_block_start +
|
||||||
|
margin_block_end;
|
||||||
|
(block_start,
|
||||||
|
available_block_size - sum,
|
||||||
|
block_size,
|
||||||
|
margin_block_start,
|
||||||
|
margin_block_end)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// For the rest of the cases, auto values for margin are set to 0
|
// For the rest of the cases, auto values for margin are set to 0
|
||||||
|
|
||||||
// If only one is Auto, solve for it
|
// If only one is Auto, solve for it
|
||||||
(MaybeAuto::Auto, MaybeAuto::Specified(block_end), MaybeAuto::Specified(block_size)) => {
|
(MaybeAuto::Auto,
|
||||||
let margin_block_start = block_start_margin.specified_or_zero();
|
MaybeAuto::Specified(block_end),
|
||||||
let margin_block_end = block_end_margin.specified_or_zero();
|
MaybeAuto::Specified(block_size)) => {
|
||||||
let sum = block_end + block_size + margin_block_start + margin_block_end;
|
let margin_block_start = block_start_margin.specified_or_zero();
|
||||||
(available_block_size - sum, block_end, block_size, margin_block_start, margin_block_end)
|
let margin_block_end = block_end_margin.specified_or_zero();
|
||||||
}
|
let sum = block_end + block_size + margin_block_start + margin_block_end;
|
||||||
(MaybeAuto::Specified(block_start), MaybeAuto::Auto, MaybeAuto::Specified(block_size)) => {
|
(available_block_size - sum,
|
||||||
let margin_block_start = block_start_margin.specified_or_zero();
|
block_end,
|
||||||
let margin_block_end = block_end_margin.specified_or_zero();
|
block_size,
|
||||||
let sum = block_start + block_size + margin_block_start + margin_block_end;
|
margin_block_start,
|
||||||
(block_start, available_block_size - sum, block_size, margin_block_start, margin_block_end)
|
margin_block_end)
|
||||||
}
|
}
|
||||||
(MaybeAuto::Specified(block_start), MaybeAuto::Specified(block_end), MaybeAuto::Auto) => {
|
(MaybeAuto::Specified(block_start),
|
||||||
let margin_block_start = block_start_margin.specified_or_zero();
|
MaybeAuto::Auto,
|
||||||
let margin_block_end = block_end_margin.specified_or_zero();
|
MaybeAuto::Specified(block_size)) => {
|
||||||
let sum = block_start + block_end + margin_block_start + margin_block_end;
|
let margin_block_start = block_start_margin.specified_or_zero();
|
||||||
(block_start, block_end, available_block_size - sum, margin_block_start, margin_block_end)
|
let margin_block_end = block_end_margin.specified_or_zero();
|
||||||
}
|
let sum = block_start + block_size + margin_block_start + margin_block_end;
|
||||||
|
(block_start,
|
||||||
|
available_block_size - sum,
|
||||||
|
block_size,
|
||||||
|
margin_block_start,
|
||||||
|
margin_block_end)
|
||||||
|
}
|
||||||
|
(MaybeAuto::Specified(block_start),
|
||||||
|
MaybeAuto::Specified(block_end),
|
||||||
|
MaybeAuto::Auto) => {
|
||||||
|
let margin_block_start = block_start_margin.specified_or_zero();
|
||||||
|
let margin_block_end = block_end_margin.specified_or_zero();
|
||||||
|
let sum = block_start + block_end + margin_block_start + margin_block_end;
|
||||||
|
(block_start,
|
||||||
|
block_end,
|
||||||
|
available_block_size - sum,
|
||||||
|
margin_block_start,
|
||||||
|
margin_block_end)
|
||||||
|
}
|
||||||
|
|
||||||
// If block-size is auto, then block-size is content block-size. Solve for the
|
// If block-size is auto, then block-size is content block-size. Solve for the
|
||||||
// non-auto value.
|
// non-auto value.
|
||||||
(MaybeAuto::Specified(block_start), MaybeAuto::Auto, MaybeAuto::Auto) => {
|
(MaybeAuto::Specified(block_start), MaybeAuto::Auto, MaybeAuto::Auto) => {
|
||||||
let margin_block_start = block_start_margin.specified_or_zero();
|
let margin_block_start = block_start_margin.specified_or_zero();
|
||||||
let margin_block_end = block_end_margin.specified_or_zero();
|
let margin_block_end = block_end_margin.specified_or_zero();
|
||||||
let block_size = content_block_size;
|
let block_size = content_block_size;
|
||||||
let sum = block_start + block_size + margin_block_start + margin_block_end;
|
let sum = block_start + block_size + margin_block_start + margin_block_end;
|
||||||
(block_start, available_block_size - sum, block_size, margin_block_start, margin_block_end)
|
(block_start,
|
||||||
}
|
available_block_size - sum,
|
||||||
(MaybeAuto::Auto, MaybeAuto::Specified(block_end), MaybeAuto::Auto) => {
|
block_size,
|
||||||
let margin_block_start = block_start_margin.specified_or_zero();
|
margin_block_start,
|
||||||
let margin_block_end = block_end_margin.specified_or_zero();
|
margin_block_end)
|
||||||
let block_size = content_block_size;
|
}
|
||||||
let sum = block_end + block_size + margin_block_start + margin_block_end;
|
(MaybeAuto::Auto, MaybeAuto::Specified(block_end), MaybeAuto::Auto) => {
|
||||||
(available_block_size - sum, block_end, block_size, margin_block_start, margin_block_end)
|
let margin_block_start = block_start_margin.specified_or_zero();
|
||||||
}
|
let margin_block_end = block_end_margin.specified_or_zero();
|
||||||
|
let block_size = content_block_size;
|
||||||
|
let sum = block_end + block_size + margin_block_start + margin_block_end;
|
||||||
|
(available_block_size - sum,
|
||||||
|
block_end,
|
||||||
|
block_size,
|
||||||
|
margin_block_start,
|
||||||
|
margin_block_end)
|
||||||
|
}
|
||||||
|
|
||||||
(MaybeAuto::Auto, MaybeAuto::Auto, MaybeAuto::Specified(block_size)) => {
|
(MaybeAuto::Auto, MaybeAuto::Auto, MaybeAuto::Specified(block_size)) => {
|
||||||
let margin_block_start = block_start_margin.specified_or_zero();
|
let margin_block_start = block_start_margin.specified_or_zero();
|
||||||
let margin_block_end = block_end_margin.specified_or_zero();
|
let margin_block_end = block_end_margin.specified_or_zero();
|
||||||
let block_start = static_position_block_start;
|
let block_start = static_position_block_start;
|
||||||
let sum = block_start + block_size + margin_block_start + margin_block_end;
|
let sum = block_start + block_size + margin_block_start + margin_block_end;
|
||||||
(block_start, available_block_size - sum, block_size, margin_block_start, margin_block_end)
|
(block_start,
|
||||||
}
|
available_block_size - sum,
|
||||||
};
|
block_size,
|
||||||
BSizeConstraintSolution::new(block_start, block_end, block_size, margin_block_start, margin_block_end)
|
margin_block_start,
|
||||||
|
margin_block_end)
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
BSizeConstraintSolution::new(block_start,
|
||||||
|
block_end,
|
||||||
|
block_size,
|
||||||
|
margin_block_start,
|
||||||
|
margin_block_end)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Solve the vertical constraint equation for absolute replaced elements.
|
/// Solve the vertical constraint equation for absolute replaced elements.
|
||||||
|
@ -447,8 +508,8 @@ impl<'a> PreorderFlowTraversal for AbsoluteAssignBSizesTraversal<'a> {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
let AbsoluteAssignBSizesTraversal(ref ctx) = *self;
|
let AbsoluteAssignBSizesTraversal(ref layout_context) = *self;
|
||||||
block_flow.calculate_absolute_block_size_and_margins(*ctx);
|
block_flow.calculate_absolute_block_size_and_margins(*layout_context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1166,9 +1227,8 @@ impl BlockFlow {
|
||||||
loop {
|
loop {
|
||||||
match candidate_block_size_iterator.next() {
|
match candidate_block_size_iterator.next() {
|
||||||
Some(block_size_used_val) => {
|
Some(block_size_used_val) => {
|
||||||
solution =
|
solution = Some(
|
||||||
Some(BSizeConstraintSolution::
|
BSizeConstraintSolution::solve_vertical_constraints_abs_nonreplaced(
|
||||||
solve_vertical_constraints_abs_nonreplaced(
|
|
||||||
block_size_used_val,
|
block_size_used_val,
|
||||||
margin_block_start,
|
margin_block_start,
|
||||||
margin_block_end,
|
margin_block_end,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue