github web-platform-tests/wpt merge_pr_47643

latest releases: merge_pr_49470, epochs/three_hourly/2024-12-03_06H, epochs/six_hourly/2024-12-03_06H...
4 months ago

[line-clamp] Take ruby annotations into account for line-clamp: auto

When line-clamp: auto is being used, it should clamp at the last
point where the size of the box would not go beyond its specified
max-height. However, this did not always hold when there were
line-under ruby annotations on the lines around the clamp point.

This happens because the annotation overflow that such annotations
create increases the height of the line, but this overflow size (which
is tracked in PreviousInflowPosition) will be subtracted from any
immediately following padding. Since line-clamp: auto tracks padding
by subtracting the block end padding in a box from its parent's clamp
offset, this results in accounting for the pull padding and the full
annotation overflow. This patch fixes that by passing the current
box's block end padding into BlockLineClampData::UpdateAfterLayout
to account for that.

Another bug with ruby and line-clamp: auto is that the last line
before the clamp point might not have an ellipsis, or lines before the
clamp point might end up hidden if they had ruby annotations. This is
because whether a line has an ellipsis or is hidden needs to be
computed before the layout of that line finishes. And for
line-clamp: auto, whether a line is at the clamp point or after it
depends on its height, which is dependent on the line's annotations.
Furthermore, here the annotation overflow also needs to be accounted
for, relative to the block container's block end padding.

To fix this, this patch merges the ShouldLineClamp and
ShouldHideLine methods from InlineLayoutAlgorithm into a single
GetLineClampState method. In this method, when we are clamping by a
height, we precompute the line's effective total block size. And since
we also need to account for the effects of padding afterwards, we add
a LineClampEndPadding field in the constraint space to pass it as an
input.

Bug: 40336192
Change-Id: I90fb500dc79a7ed669fa1a74e5bfdc43a26a7447
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5785842
Reviewed-by: Kent Tamura tkent@chromium.org
Commit-Queue: Andreu Botella abotella@igalia.com
Reviewed-by: Ian Kilpatrick ikilpatrick@chromium.org
Cr-Commit-Position: refs/heads/main@{#1342867}

Don't miss a new wpt release

NewReleases is sending notifications on new releases.