aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--components/layout/list_item.rs46
-rw-r--r--tests/ref/basic.list1
-rw-r--r--tests/ref/list_style_image_sizing_a.html37
-rw-r--r--tests/ref/list_style_image_sizing_ref.html37
4 files changed, 103 insertions, 18 deletions
diff --git a/components/layout/list_item.rs b/components/layout/list_item.rs
index cb78f44399e..cec7b02f0a5 100644
--- a/components/layout/list_item.rs
+++ b/components/layout/list_item.rs
@@ -15,6 +15,8 @@ use flow::{Flow, FlowClass};
use fragment::{CoordinateSystem, Fragment, FragmentBorderBoxIterator, GeneratedContentInfo};
use generated_content;
use incremental::RESOLVE_GENERATED_CONTENT;
+use inline::InlineMetrics;
+use text;
use wrapper::ThreadSafeLayoutNode;
use geom::{Point2D, Rect};
@@ -84,30 +86,38 @@ impl Flow for ListItemFlow {
fn assign_inline_sizes(&mut self, layout_context: &LayoutContext) {
self.block_flow.assign_inline_sizes(layout_context);
- match self.marker {
- None => {}
- Some(ref mut marker) => {
- // Do this now. There's no need to do this in bubble-widths, since markers do not
- // contribute to the inline size of this flow.
- let intrinsic_inline_sizes = marker.compute_intrinsic_inline_sizes();
-
- marker.border_box.size.inline =
- intrinsic_inline_sizes.content_intrinsic_sizes.preferred_inline_size;
- marker.border_box.start.i = self.block_flow.fragment.border_box.start.i -
- marker.border_box.size.inline;
- }
+ if let Some(ref mut marker) = self.marker {
+ let containing_block_inline_size = self.block_flow.base.block_container_inline_size;
+ marker.assign_replaced_inline_size_if_necessary(containing_block_inline_size);
+
+ // Do this now. There's no need to do this in bubble-widths, since markers do not
+ // contribute to the inline size of this flow.
+ let intrinsic_inline_sizes = marker.compute_intrinsic_inline_sizes();
+
+ marker.border_box.size.inline =
+ intrinsic_inline_sizes.content_intrinsic_sizes.preferred_inline_size;
+ marker.border_box.start.i = self.block_flow.fragment.border_box.start.i -
+ marker.border_box.size.inline;
}
}
fn assign_block_size<'a>(&mut self, layout_context: &'a LayoutContext<'a>) {
self.block_flow.assign_block_size(layout_context);
- match self.marker {
- None => {}
- Some(ref mut marker) => {
- marker.border_box.start.b = Au(0);
- marker.border_box.size.block = marker.calculate_line_height(layout_context);
- }
+ if let Some(ref mut marker) = self.marker {
+ let containing_block_block_size =
+ self.block_flow.base.block_container_explicit_block_size.unwrap_or(Au(0));
+ marker.assign_replaced_block_size_if_necessary(containing_block_block_size);
+
+ let font_metrics =
+ text::font_metrics_for_style(layout_context.font_context(),
+ marker.style.get_font_arc());
+ let line_height = text::line_height_from_style(&*marker.style, &font_metrics);
+ let item_inline_metrics = InlineMetrics::from_font_metrics(&font_metrics, line_height);
+ let marker_inline_metrics = marker.inline_metrics(layout_context);
+ marker.border_box.start.b = item_inline_metrics.block_size_above_baseline -
+ marker_inline_metrics.block_size_above_baseline;
+ marker.border_box.size.block = marker_inline_metrics.block_size_above_baseline;
}
}
diff --git a/tests/ref/basic.list b/tests/ref/basic.list
index 9b19e57760e..f09177b5b2f 100644
--- a/tests/ref/basic.list
+++ b/tests/ref/basic.list
@@ -195,6 +195,7 @@ flaky_cpu == linebreak_simple_a.html linebreak_simple_b.html
# Fails intermittently (#3636)
# == link_style_dynamic_addition.html link_style_dynamic_addition_ref.html
== link_style_order.html link_style_order_ref.html
+== list_style_image_sizing_a.html list_style_image_sizing_ref.html
== list_style_position_a.html list_style_position_ref.html
!= list_style_type_a.html list_style_type_ref.html
== many_brs_a.html many_brs_ref.html
diff --git a/tests/ref/list_style_image_sizing_a.html b/tests/ref/list_style_image_sizing_a.html
new file mode 100644
index 00000000000..04c28158f38
--- /dev/null
+++ b/tests/ref/list_style_image_sizing_a.html
@@ -0,0 +1,37 @@
+<!DOCTYPE html>
+<html>
+<head>
+<!--
+ Tests that the list style image doesn't get stretched vertically. It should be completely
+ covered up by the black absolutely-positioned div.
+-->
+<link rel="stylesheet" type="text/css" href="css/ahem.css">
+<style>
+* {
+ margin: 0;
+ padding: 0;
+}
+li {
+ margin-left: 128px;
+ list-style-image: url();
+ font-size: 256px;
+ font-family: Ahem, monospace;
+}
+#coverup {
+ position: absolute;
+ background: black;
+ top: 176px;
+ left: 0;
+ right: 0;
+ bottom: 0;
+}
+</style>
+</head>
+<body>
+<ul>
+ <li>x</li>
+</ul>
+<div id=coverup></div>
+</body>
+</html>
+
diff --git a/tests/ref/list_style_image_sizing_ref.html b/tests/ref/list_style_image_sizing_ref.html
new file mode 100644
index 00000000000..a4af95bd1cc
--- /dev/null
+++ b/tests/ref/list_style_image_sizing_ref.html
@@ -0,0 +1,37 @@
+<!DOCTYPE html>
+<html>
+<head>
+<!--
+ Tests that the list style image doesn't get stretched vertically. It should be completely
+ covered up by the black absolutely-positioned div.
+-->
+<link rel="stylesheet" type="text/css" href="css/ahem.css">
+<style>
+* {
+ margin: 0;
+ padding: 0;
+}
+li {
+ margin-left: 128px;
+ list-style-image: none;
+ font-size: 256px;
+ font-family: Ahem, monospace;
+}
+#coverup {
+ position: absolute;
+ background: black;
+ top: 176px;
+ left: 0;
+ right: 0;
+ bottom: 0;
+}
+</style>
+</head>
+<body>
+<ul>
+ <li>x</li>
+</ul>
+<div id=coverup></div>
+</body>
+</html>
+