aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthew Rasmus <mattr@zzntd.com>2015-01-26 10:57:37 -0800
committerMatthew Rasmus <mattr@zzntd.com>2015-02-02 15:52:12 -0800
commit846fc6453a7ec579e06e373fc48c8b21ce6245e5 (patch)
treeba3aabea42dc765cc457acf95755fde7890e2fb0
parent5b340599f2a100368aa53c427e8b2d14db9271e9 (diff)
downloadservo-846fc6453a7ec579e06e373fc48c8b21ce6245e5.tar.gz
servo-846fc6453a7ec579e06e373fc48c8b21ce6245e5.zip
Shrink-to-fit inline-blocks with width set to auto
-rw-r--r--components/layout/block.rs11
1 files changed, 9 insertions, 2 deletions
diff --git a/components/layout/block.rs b/components/layout/block.rs
index f7f7dde2b48..167e3d99ddc 100644
--- a/components/layout/block.rs
+++ b/components/layout/block.rs
@@ -2153,7 +2153,7 @@ pub trait ISizeAndMarginsComputer {
/// available_inline-size
/// where available_inline-size = CB inline-size - (horizontal border + padding)
fn solve_block_inline_size_constraints(&self,
- _: &mut BlockFlow,
+ block: &mut BlockFlow,
input: &ISizeConstraintInput)
-> ISizeConstraintSolution {
let (computed_inline_size, inline_start_margin, inline_end_margin, available_inline_size) =
@@ -2180,7 +2180,7 @@ pub trait ISizeAndMarginsComputer {
// Invariant: inline-start_margin + inline-size + inline-end_margin ==
// available_inline-size
- let (inline_start_margin, inline_size, inline_end_margin) =
+ let (inline_start_margin, mut inline_size, inline_end_margin) =
match (inline_start_margin, computed_inline_size, inline_end_margin) {
// If all have a computed value other than 'auto', the system is
// over-constrained so we discard the end margin.
@@ -2213,6 +2213,13 @@ pub trait ISizeAndMarginsComputer {
(margin, inline_size, margin)
}
};
+
+ // If inline-size is set to 'auto', and this is an inline block, use the
+ // shrink to fit algorithm (see CSS 2.1 § 10.3.9)
+ if computed_inline_size == MaybeAuto::Auto && block.is_inline_block() {
+ inline_size = block.get_shrink_to_fit_inline_size(inline_size);
+ }
+
ISizeConstraintSolution::new(inline_size, inline_start_margin, inline_end_margin)
}
}