-
Notifications
You must be signed in to change notification settings - Fork 687
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[css-overflow] Is continue: discard working in the fragment tree useful? #7708
Comments
If it just stopped painting them, then the content would still be overflowing, but scrolling would just reveal a big empty area, yeah? I'm not sure why that would be preferable. ( |
Well, we could spec that line-clamp affects the scrollable overflow, by not accounting for overflow caused by clamped lines, the same way it affects the auto block size, right? I think that'd still be much easier to implement and maybe more intuitive to authors |
At that point, what's making it different from discarding the fragments after the break, then? You already have the ability to shift the fragments to the next rendering context, so I'm not clear what the problem you're trying to solve here is. |
Well, for once, it doesn't change the interactions with the OM (e.g., |
So you're proposing we define that the overflow after the break opportunity doesn't break, but instead becomes invisible ink overflow? (I'm also curious what the essential difference is between those two cases, btw. I would naively think that "push these to nowhere" is similar in difficulty, if not easier?) |
One specific difference is the OOFs would propagate up from the clamped content. |
Ah, in the "become invisible ink overflow" case? Whereas in the "drop the fragments" case the OOFs after the break would just be gone? |
Yup that's correct. |
The other difference/side-effect is the geometry APIs |
The CSS Working Group just discussed The full IRC log of that discussion<TabAtkins> Topic: continue:discard in the fragment tree<astearns> github: https://github.com//issues/7708 <TabAtkins> emilio: making line-clamp work using continue:discard has some side effects <andreubotella> q+ <TabAtkins> emilio: Based on fragmetnation implies the boxes you clamp don't exist, so OM APIs return 0 sizes, etc <florian> q+ <TabAtkins> emilio: And implies that like border-bottom disappears due to box-decoration-break <heycam> q+ <TabAtkins> emilio: I think it would be both easier and more useful to impl line-clamp by clamping both content-height, as it does now, and the scrolalble overflow, and hiding the clamped lines rather thand iscarding fragments <TabAtkins> emilio: There's been some discussion - I think in general it's a lot easier to implement but similarly useful <TabAtkins> emilio: So easier to reach unprefixed line-clamp <iank_> q+ <TabAtkins> emilio: We could decide to ship line-clamp as a longhand for now and decide what to do about shorthands later <astearns> ack andreubotella <TabAtkins> andreubotella: it's not clear how line-clamp would work with editting (?) <astearns> s/(?)/(!)/ <TabAtkins> andreubotella: Not clear where carat woudl go if you move past the clamped line <TabAtkins> andreubotella: Would be less of an issue with emilio's model <astearns> ack florian <TabAtkins> florian: We'd also need to define how padding/etc will work. using fragmentation gets us that, it defines those <TabAtkins> florian: One of the goals is to avoid reinventing all that <TabAtkins> florian: It's true that the discarded part, we have incomplete answers about what to do with abspos in there, what happens to the caret, etc <TabAtkins> florian: So maybe we do use fragmentation, but rather than discard the post-fragmentation is invisible <TabAtkins> florian: but saying that it's easier to do it visually is in conflict with the existing knowledge that it's in conflict with visual stuff <TabAtkins> florian: like bidi content <TabAtkins> florian: in the fragment model, in document order, hen we have enough content to place the ellipsis; that's different from hiding characters at the end of the line <TabAtkins> florian: another complaint about visual aspect is you hvae no control over what gets elided and whether it happens at sensible line-break points <TabAtkins> florian: If using fragmentation, the line breaking properties work <TabAtkins> florian: Another thing which is useful under the current model (and maybe usable under your new model), a lot of people want to clamp at 3 lines, but a lot want to clamp at 100px <TabAtkins> iank_: still possible <TabAtkins> florian: Not impossibl, but undefined. Defined with fragmentation, but not defined without. <TabAtkins> florian: Don't want to display a half-line, for example <TabAtkins> florian: So I think we can find ways to define things in terms of fragmentation that are less mysterious <TabAtkins> florian: And also make some statements about "allowable approximations". <TabAtkins> florian: But I think entirely discard fragmentation would be unfortunate <TabAtkins> iank_: clarification, the visual model is purely about subsequent lines <TabAtkins> iank_: Still do layout placement of ellipsis, etc <TabAtkins> iank_: So not necessarily in conflict with what you want to achieve <astearns> q? <TabAtkins> iank_: I don't wanna have a spec where all the impls do emilio's model, and there's a bunch of soft wording about how it's allowed <emilio> q+ <TabAtkins> florian: yeah point is not to write fiction, it's just that if we do emilio's model because it's more useful, we shouldn't omit the useful properties of the current spec <TabAtkins> florian: If we treat it as something like a multicol where additional cols aren't painted, you can have an answer to all the API questions <TabAtkins> iank_: there's still subtle diffs <TabAtkins> iank_: in emilio's model it's actually desirable that you don't fragment the borders <TabAtkins> emilio: say you calmp in a nested block with border/padding. <TabAtkins> emilio: it has five lines, you clamp at 3, per fragmentation you're supposed to hide the border padding at the bottom <TabAtkins> fantasai: which element has line-clamp here? <TabAtkins> emilio: the bfc <TabAtkins> fantasai: so inside the bfc you have a text with 5 text lines <TabAtkins> fantasai: the bfc says line-clamp:3 <TabAtkins> fantasai: so you clamp after three lines, then what's after is clamped <TabAtkins> emilio: no <TabAtkins> iank_: You're just clamping the content box. You set the content box to the size afte clamping and then layout as normal. <iank_> https://www.software.hixie.ch/utilities/js/live-dom-viewer/?saved=10735 <TabAtkins> [retreading the previous example] <TabAtkins> emilio: the auto height of the inner box is 3 lines tall (plus mbp) <TabAtkins> florian: So you're reinventing fragmentation... <TabAtkins> emilio: no fragment would crop the border <TabAtkins> florian: yeah we have box-decoration-break that lets you control it <TabAtkins> iank_: well they're not repeated, because this *isn't* fragmentation <TabAtkins> [missed] <TabAtkins> florian: If we do it with fragmentation you can choose whether to clip those borders or not <TabAtkins> iank_: You can here, with border:0 <TabAtkins> florian: No you can't, you can't predict whther the clamp activates or not <TabAtkins> florian: fragmentation already solved this, dunno why we're reinventing <TabAtkins> iank_: I think this is a small edge case and most people would expect the behavior from emilio's model <TabAtkins> astearns: agree this is probably small, but there are tons of decisions in this space about what to do after a fragment break, and we'd have to reinvent all of these <TabAtkins> emilio: don't think it's reinventing, we just do what we do if you clamp the auto size and visually hide the overlap <TabAtkins> iank_: very similar to empty-cells on tables, or similar to visibility:hidden but not quite <TabAtkins> astearns: ther'es a long queue <florian> q+ <florian> ? <TabAtkins> heycam: it's probably more like visibility:collapse on those additional lines at the end, they take up no space and aren't rendered <TabAtkins> iank_: a little diff bc collapse applies to a container, and it of ten gets smushed in size and ther'es some other effects, but yeah <astearns> ack heycam <TabAtkins> iank_: the way we'd implement is exactly like empty-cells <TabAtkins> heycam: at a high level in wk, i think we support getting to the full fragmentation model <TabAtkins> heycam: But we'll need an interim solution, maybe emilio's or similar <TabAtkins> heycam: think it would be useful to enumerate the diff between this and the full fragment solution so we can see what it's most similar to <TabAtkins> heycam: and how likely it is we run into compat issue in the future <TabAtkins> heycam: like gBCR() effects, etc <TabAtkins> heycam: If that would change between the two solutions, that might be risky <astearns> ack iank_ <TabAtkins> iank_: broadly i'm supportive of emilio's suggestion <TabAtkins> iank_: webdevs strongly desire an unprefixed line-clamp <TabAtkins> iank_: We, Blink, are probably the closest to ahving a fragmentation solution, but still a ways away <TabAtkins> iank_: emilio's suggestion means all engines can ship something highly interoperable fairly quickly that will satisfy webdev demands <TabAtkins> iank_: dont' want fiction, so if we do emilio's, want it in the spec <TabAtkins> iank_: emilio's gets us there very quickly <TabAtkins> iank_: I don't think emilio's and fragmentation are exclusive <TabAtkins> astearns: If we come up with a list of things that are going to be different, how can we move from one to the other? <TabAtkins> iank_: I don't think that we will <TabAtkins> iank_: I think we'll be shipping whichever we start with <TabAtkins> iank_: So like, I don't believe3 we'll be able to straight unprefix -webkit-line-clamp even with emilio's solution, bc devs are already depending on scrollable overlow returning a particular value to tell if clamping applied <TabAtkins> iank_: I suspect we'll get somethign similar <TabAtkins> iank_: with abspos at the end, for example <TabAtkins> heycam: so what i'm hearing is that if we come to the full solution it will need a switch <TabAtkins> iank_: I think that's ok; they're related problems but not necessarily the same <TabAtkins> iank_: When we want to truncate content and continue it in a different fragmentatin, i wouldn't be sad if that was a different set of fragmentation properties <TabAtkins> iank_: people are today using prefixed line-clamp and unhappy about it, we can all ship an unprefixed line-clamp with emilio's solution <TabAtkins> astearns: but it's still different than emilio's? <TabAtkins> iank_: P sure we can translate most of it over, only big compat change will be the scrollable overflow size change <astearns> ack emilio <astearns> ack florian <TabAtkins> florian: I don't want fiction either, so I'm happy to make accommodations so we can match impls <TabAtkins> florian: but i wanted to circle back to one potential differenence, because i didn't understand an earlier answer <TabAtkins> florian: with emilio's, is it possible to "clamp after however many lines it takes to reach 300px"? <TabAtkins> emilio: could be feasible, define that instead of "hide lines after the third" you'd hide all lines whose block-end edge is after 300px <TabAtkins> florian: so you'd size the container to 300px, fill it in, start filling in content, then remove after... <TabAtkins> emilio: not remove <TabAtkins> florian: you said you'd draw the mbp of children at the bottom, so you'll need to make room to insert those back <TabAtkins> florian: Note it's not the containr border i'm talking about, it's the content element's border <TabAtkins> florian: before ocunting lines you don't know how many lines you'll take <TabAtkins> fremy: you add both top and bottom mbp as you add it, then fill in lines until you hit the limit <TabAtkins> iank_: yup <TabAtkins> iank_: our -webkit-line-clamp will already abort and retry for compliated reasons. this is fine <TabAtkins> florian: what troubles me is not that it's undoable, clearly it is and is even simpler, but it will have something *very similar* to fragmentation which isn't quite fragmentation. <TabAtkins> astearns: which makes you uneasy <TabAtkins> florian: yeah <TabAtkins> florian: The bidi part I'm not sure how you solve <TabAtkins> florian: we don't control what chunk of text on the last line is okay to remove <TabAtkins> florian: this is a known problm of the existing paint-based ellipsis <TabAtkins> emilio: i think blink does layout-time ellipsis <TabAtkins> emilio: presuambly they ahve to reshpare arbitrary content when inserting it to avoid clipping <TabAtkins> florian: and it can push content around? <andreubotella> q+ <astearns> zakim, close queue <Zakim> ok, astearns, the speaker queue is closed <TabAtkins> iank_: I'll ahve to double check, but i think we'll reshape, like if you land on a bad ligature we'll go back and split it <TabAtkins> florian: it's not just painting a ligature, it's about dropping letters or a whole word <TabAtkins> florian: simila for an abspos in the content, the static position changes depending on whether it's pushed to the next line or not <TabAtkins> iank_: I think abspos are break oppos in our impl for this reason <TabAtkins> astearns: next queue <astearns> ack fantasai <TabAtkins> fantasai: there's a number of directions people ahve wanted to extend this in, and starting from fragmentation model gets you to a bunch of different places that we want to end up <TabAtkins> fantasai: while starting from a visual model doesn't <TabAtkins> fantasai: I also pasted a funny test case <TabAtkins> fantasai: it's p weird <fantasai> https://www.software.hixie.ch/utilities/js/live-dom-viewer/?saved=10738 <fantasai> fantasai: This is the model we *want*? <TabAtkins> andreubotella: regarding ellipsis, in current fragmentation there's block-ellipsis where youc an repalce the final lines with something <TabAtkins> andreubotella: how would this work? <TabAtkins> andreubotella: if the string has rtl and ltr characters? <TabAtkins> florian: It's specified, i don't recall the details. I think we insert the string as a string without wrapping oppo and with bidi isolation |
We've had good discussions during TPAC breaks about what a simpler mechanism than the one currently specified might be, and I have been trying to understand in detail what the suggested approach means. As a placeholder, let's call this new approach Prior to trying to spec it out, I'd like to make sure we're all on the same page. Here's a collection of situations which I hope will help us confirm whether we agree about the behavior we're talking about, maybe explore some possible variants, and help us evaluate whether we like the resulting behavior. (We might need a break-out session to go through this.) (In the examples below, a
If anyone has questions in the same vein, that would help explore the behavior (including but not limited to exposing differences between |
I've been toying with a prototype implementation of With that, this is how this prototype handles some of these questions.
The bottom padding and border is kept, but the bottom margin isn't. (This is something that is currently observable in Chromium's implementation of In particular, if you have a div with m/b/p whose only content is a div with m/b/p, and the clamping happens in the inner div, the inner div will also not keep its margin. If the m/b/p for both elements are symmetric, you can observe that as a difference in the actual spacing between the top and bottom:
The line count is part of the formatting context, so if you have
Same as above: the line count adds up across the divs, and any divs after the clamped line will be completely hidden.
My implementation so far hides things that are after the clamp point in the layout tree, regardless of where they show up visually. So (7) is hidden, (8) is shown outside the element.
Same as above, floats anchored in retained lines are shown, even if they visually overflow or show completely outside of the element's bounds. Floats in the discarded lines are hidden. Whether they're replaced or not doesn't make a difference.
As far as
Currently I'm always showing abspos. If the block inset properties are not set, the abspos will show up wherever it would without
Chromium's implementation of |
If the content isn't on a line it will cut off the content outside the formatting context - this is similar to monolithic content. As with 14 they aren't considered for lines.
You get the standard geometry as you'd expect if they weren't hidden. This is similar to how
Same as above. They will be visible if not hidden, and same the same geometry.
Unclear what you mean by truncating here, but I'll assume this is the box with line-clamp on it. It'll be the height of it in the clamped state.
Unclear what tracated box means here, but i'll assume a box that was been hidden. It'll behave the same as if it wasn't truncated.
These questions don't seem specific to the "collapse" behaviour.
Unclear - what the expected behaviour would be - this is similar to existing clamping behaviour (e.g. text-overflow).
Likely yes. |
So in summary the rules appear to be:
|
Currently the specification of `line-clamp` uses a variant called `continue: discard`, but there is an alternative called `continue: collapse` (see w3c/csswg-drafts#7708), which is being implemented in Chrome. A number of tests were added to test this `collapse` alternative, marked as tentative. This patch makes some of those tests non-tentative, in cases when both of the alternatives agree. The agreement of both variants is according to the spec as it exists right now, independent of yesterday's CSSWG resolutions. A follow-up patch will make further tests non-tentative to account for those resolutions.
…en both alternatives agree, a=testonly Automatic update from web-platform-tests Make `line-clamp` tests non-tentative when both alternatives agree Currently the specification of `line-clamp` uses a variant called `continue: discard`, but there is an alternative called `continue: collapse` (see w3c/csswg-drafts#7708), which is being implemented in Chrome. A number of tests were added to test this `collapse` alternative, marked as tentative. This patch makes some of those tests non-tentative, in cases when both of the alternatives agree. The agreement of both variants is according to the spec as it exists right now, independent of yesterday's CSSWG resolutions. A follow-up patch will make further tests non-tentative to account for those resolutions. -- wpt-commits: 81c702f33538a8f245a4adbddd3f9273ab2a373b wpt-pr: 46733
…en both alternatives agree, a=testonly Automatic update from web-platform-tests Make `line-clamp` tests non-tentative when both alternatives agree Currently the specification of `line-clamp` uses a variant called `continue: discard`, but there is an alternative called `continue: collapse` (see w3c/csswg-drafts#7708), which is being implemented in Chrome. A number of tests were added to test this `collapse` alternative, marked as tentative. This patch makes some of those tests non-tentative, in cases when both of the alternatives agree. The agreement of both variants is according to the spec as it exists right now, independent of yesterday's CSSWG resolutions. A follow-up patch will make further tests non-tentative to account for those resolutions. -- wpt-commits: 81c702f33538a8f245a4adbddd3f9273ab2a373b wpt-pr: 46733 UltraBlame original commit: 25c81163645379d0a945b24b7ead9e79b7791f67
…en both alternatives agree, a=testonly Automatic update from web-platform-tests Make `line-clamp` tests non-tentative when both alternatives agree Currently the specification of `line-clamp` uses a variant called `continue: discard`, but there is an alternative called `continue: collapse` (see w3c/csswg-drafts#7708), which is being implemented in Chrome. A number of tests were added to test this `collapse` alternative, marked as tentative. This patch makes some of those tests non-tentative, in cases when both of the alternatives agree. The agreement of both variants is according to the spec as it exists right now, independent of yesterday's CSSWG resolutions. A follow-up patch will make further tests non-tentative to account for those resolutions. -- wpt-commits: 81c702f33538a8f245a4adbddd3f9273ab2a373b wpt-pr: 46733 UltraBlame original commit: 25c81163645379d0a945b24b7ead9e79b7791f67
…en both alternatives agree, a=testonly Automatic update from web-platform-tests Make `line-clamp` tests non-tentative when both alternatives agree Currently the specification of `line-clamp` uses a variant called `continue: discard`, but there is an alternative called `continue: collapse` (see w3c/csswg-drafts#7708), which is being implemented in Chrome. A number of tests were added to test this `collapse` alternative, marked as tentative. This patch makes some of those tests non-tentative, in cases when both of the alternatives agree. The agreement of both variants is according to the spec as it exists right now, independent of yesterday's CSSWG resolutions. A follow-up patch will make further tests non-tentative to account for those resolutions. -- wpt-commits: 81c702f33538a8f245a4adbddd3f9273ab2a373b wpt-pr: 46733
…en both alternatives agree, a=testonly Automatic update from web-platform-tests Make `line-clamp` tests non-tentative when both alternatives agree Currently the specification of `line-clamp` uses a variant called `continue: discard`, but there is an alternative called `continue: collapse` (see w3c/csswg-drafts#7708), which is being implemented in Chrome. A number of tests were added to test this `collapse` alternative, marked as tentative. This patch makes some of those tests non-tentative, in cases when both of the alternatives agree. The agreement of both variants is according to the spec as it exists right now, independent of yesterday's CSSWG resolutions. A follow-up patch will make further tests non-tentative to account for those resolutions. -- wpt-commits: 81c702f33538a8f245a4adbddd3f9273ab2a373b wpt-pr: 46733
I forgot to mention it over here, but I have a PR for |
In our initial implementation of `line-clamp: auto`, we allowed clamping after lineless boxes, in order to better match the behavior of `line-clamp` as it follows from the spec's `continue: discard` model, even though our implementation uses a different model which is not yet in the specification (see w3c/csswg-drafts#7708). However, in hallway conversations in TPAC 2024, we agreed that it would be better for this model to instead only allow clamping immediately after a line. If the first line does not fit, we calmp at the first line even if that overflows the clamp height. If there are no lines, we do not clamp. This patch implements this. Additionally, a previous patch (https://crrev.com/c/5868971) had increased the memory size of `LineClampData` from 8 to 20 bytes, causing a memory regression. This patch shrinks it to 12 bytes, since `LineClampData` no longer needs to keep track of how many block boxes there are between the last line and the clmap point, and now OOFs after the clamped line behave the same when clamping by a number of lines or by a height, so there is no need for a flag to distinguish these behaviors. This patch also adds a size assertion for `LineClampData`. This patch also changes or removes some WPT tests that were written assuming the previous behavior. Bug: 40336192, 368114054 Change-Id: I8c8afebb5dc566de92112cee2fcf24a2e60b42c8
In our initial implementation of `line-clamp: auto`, we allowed clamping after lineless boxes, in order to better match the behavior of `line-clamp` as it follows from the spec's `continue: discard` model, even though our implementation uses a different model which is not yet in the specification (see w3c/csswg-drafts#7708). However, in hallway conversations in TPAC 2024, we agreed that it would be better for this model to instead only allow clamping immediately after a line. If the first line does not fit, we calmp at the first line even if that overflows the clamp height. If there are no lines, we do not clamp. This patch implements this. Additionally, a previous patch (https://crrev.com/c/5868971) had increased the memory size of `LineClampData` from 8 to 20 bytes, causing a memory regression. This patch shrinks it to 12 bytes, since `LineClampData` no longer needs to keep track of how many block boxes there are between the last line and the clmap point, and now OOFs after the clamped line behave the same when clamping by a number of lines or by a height, so there is no need for a flag to distinguish these behaviors. This patch also adds a size assertion for `LineClampData`. This patch also changes or removes some WPT tests that were written assuming the previous behavior. Bug: 40336192, 368114054 Change-Id: I8c8afebb5dc566de92112cee2fcf24a2e60b42c8 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5904459 Reviewed-by: Ian Kilpatrick <[email protected]> Commit-Queue: Andreu Botella <[email protected]> Cr-Commit-Position: refs/heads/main@{#1364495}
In our initial implementation of `line-clamp: auto`, we allowed clamping after lineless boxes, in order to better match the behavior of `line-clamp` as it follows from the spec's `continue: discard` model, even though our implementation uses a different model which is not yet in the specification (see w3c/csswg-drafts#7708). However, in hallway conversations in TPAC 2024, we agreed that it would be better for this model to instead only allow clamping immediately after a line. If the first line does not fit, we calmp at the first line even if that overflows the clamp height. If there are no lines, we do not clamp. This patch implements this. Additionally, a previous patch (https://crrev.com/c/5868971) had increased the memory size of `LineClampData` from 8 to 20 bytes, causing a memory regression. This patch shrinks it to 12 bytes, since `LineClampData` no longer needs to keep track of how many block boxes there are between the last line and the clmap point, and now OOFs after the clamped line behave the same when clamping by a number of lines or by a height, so there is no need for a flag to distinguish these behaviors. This patch also adds a size assertion for `LineClampData`. This patch also changes or removes some WPT tests that were written assuming the previous behavior. Bug: 40336192, 368114054 Change-Id: I8c8afebb5dc566de92112cee2fcf24a2e60b42c8 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5904459 Reviewed-by: Ian Kilpatrick <[email protected]> Commit-Queue: Andreu Botella <[email protected]> Cr-Commit-Position: refs/heads/main@{#1364495}
In our initial implementation of `line-clamp: auto`, we allowed clamping after lineless boxes, in order to better match the behavior of `line-clamp` as it follows from the spec's `continue: discard` model, even though our implementation uses a different model which is not yet in the specification (see w3c/csswg-drafts#7708). However, in hallway conversations in TPAC 2024, we agreed that it would be better for this model to instead only allow clamping immediately after a line. If the first line does not fit, we calmp at the first line even if that overflows the clamp height. If there are no lines, we do not clamp. This patch implements this. Additionally, a previous patch (https://crrev.com/c/5868971) had increased the memory size of `LineClampData` from 8 to 20 bytes, causing a memory regression. This patch shrinks it to 12 bytes, since `LineClampData` no longer needs to keep track of how many block boxes there are between the last line and the clmap point, and now OOFs after the clamped line behave the same when clamping by a number of lines or by a height, so there is no need for a flag to distinguish these behaviors. This patch also adds a size assertion for `LineClampData`. This patch also changes or removes some WPT tests that were written assuming the previous behavior. Bug: 40336192, 368114054 Change-Id: I8c8afebb5dc566de92112cee2fcf24a2e60b42c8 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5904459 Reviewed-by: Ian Kilpatrick <[email protected]> Commit-Queue: Andreu Botella <[email protected]> Cr-Commit-Position: refs/heads/main@{#1364495}
…ter a line box, a=testonly Automatic update from web-platform-tests [line-clamp] Always clamp immediately after a line box In our initial implementation of `line-clamp: auto`, we allowed clamping after lineless boxes, in order to better match the behavior of `line-clamp` as it follows from the spec's `continue: discard` model, even though our implementation uses a different model which is not yet in the specification (see w3c/csswg-drafts#7708). However, in hallway conversations in TPAC 2024, we agreed that it would be better for this model to instead only allow clamping immediately after a line. If the first line does not fit, we calmp at the first line even if that overflows the clamp height. If there are no lines, we do not clamp. This patch implements this. Additionally, a previous patch (https://crrev.com/c/5868971) had increased the memory size of `LineClampData` from 8 to 20 bytes, causing a memory regression. This patch shrinks it to 12 bytes, since `LineClampData` no longer needs to keep track of how many block boxes there are between the last line and the clmap point, and now OOFs after the clamped line behave the same when clamping by a number of lines or by a height, so there is no need for a flag to distinguish these behaviors. This patch also adds a size assertion for `LineClampData`. This patch also changes or removes some WPT tests that were written assuming the previous behavior. Bug: 40336192, 368114054 Change-Id: I8c8afebb5dc566de92112cee2fcf24a2e60b42c8 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5904459 Reviewed-by: Ian Kilpatrick <[email protected]> Commit-Queue: Andreu Botella <[email protected]> Cr-Commit-Position: refs/heads/main@{#1364495} -- wpt-commits: 1563c1e3a851d13982c2e9a0c2eabb8287823b35 wpt-pr: 48482
…ter a line box, a=testonly Automatic update from web-platform-tests [line-clamp] Always clamp immediately after a line box In our initial implementation of `line-clamp: auto`, we allowed clamping after lineless boxes, in order to better match the behavior of `line-clamp` as it follows from the spec's `continue: discard` model, even though our implementation uses a different model which is not yet in the specification (see w3c/csswg-drafts#7708). However, in hallway conversations in TPAC 2024, we agreed that it would be better for this model to instead only allow clamping immediately after a line. If the first line does not fit, we calmp at the first line even if that overflows the clamp height. If there are no lines, we do not clamp. This patch implements this. Additionally, a previous patch (https://crrev.com/c/5868971) had increased the memory size of `LineClampData` from 8 to 20 bytes, causing a memory regression. This patch shrinks it to 12 bytes, since `LineClampData` no longer needs to keep track of how many block boxes there are between the last line and the clmap point, and now OOFs after the clamped line behave the same when clamping by a number of lines or by a height, so there is no need for a flag to distinguish these behaviors. This patch also adds a size assertion for `LineClampData`. This patch also changes or removes some WPT tests that were written assuming the previous behavior. Bug: 40336192, 368114054 Change-Id: I8c8afebb5dc566de92112cee2fcf24a2e60b42c8 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5904459 Reviewed-by: Ian Kilpatrick <[email protected]> Commit-Queue: Andreu Botella <[email protected]> Cr-Commit-Position: refs/heads/main@{#1364495} -- wpt-commits: 1563c1e3a851d13982c2e9a0c2eabb8287823b35 wpt-pr: 48482
…ter a line box, a=testonly Automatic update from web-platform-tests [line-clamp] Always clamp immediately after a line box In our initial implementation of `line-clamp: auto`, we allowed clamping after lineless boxes, in order to better match the behavior of `line-clamp` as it follows from the spec's `continue: discard` model, even though our implementation uses a different model which is not yet in the specification (see w3c/csswg-drafts#7708). However, in hallway conversations in TPAC 2024, we agreed that it would be better for this model to instead only allow clamping immediately after a line. If the first line does not fit, we calmp at the first line even if that overflows the clamp height. If there are no lines, we do not clamp. This patch implements this. Additionally, a previous patch (https://crrev.com/c/5868971) had increased the memory size of `LineClampData` from 8 to 20 bytes, causing a memory regression. This patch shrinks it to 12 bytes, since `LineClampData` no longer needs to keep track of how many block boxes there are between the last line and the clmap point, and now OOFs after the clamped line behave the same when clamping by a number of lines or by a height, so there is no need for a flag to distinguish these behaviors. This patch also adds a size assertion for `LineClampData`. This patch also changes or removes some WPT tests that were written assuming the previous behavior. Bug: 40336192, 368114054 Change-Id: I8c8afebb5dc566de92112cee2fcf24a2e60b42c8 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5904459 Reviewed-by: Ian Kilpatrick <ikilpatrickchromium.org> Commit-Queue: Andreu Botella <abotellaigalia.com> Cr-Commit-Position: refs/heads/main{#1364495} -- wpt-commits: 1563c1e3a851d13982c2e9a0c2eabb8287823b35 wpt-pr: 48482 UltraBlame original commit: 5751601c841de1f7d26475e22ebaa4d8ca71b474
…ter a line box, a=testonly Automatic update from web-platform-tests [line-clamp] Always clamp immediately after a line box In our initial implementation of `line-clamp: auto`, we allowed clamping after lineless boxes, in order to better match the behavior of `line-clamp` as it follows from the spec's `continue: discard` model, even though our implementation uses a different model which is not yet in the specification (see w3c/csswg-drafts#7708). However, in hallway conversations in TPAC 2024, we agreed that it would be better for this model to instead only allow clamping immediately after a line. If the first line does not fit, we calmp at the first line even if that overflows the clamp height. If there are no lines, we do not clamp. This patch implements this. Additionally, a previous patch (https://crrev.com/c/5868971) had increased the memory size of `LineClampData` from 8 to 20 bytes, causing a memory regression. This patch shrinks it to 12 bytes, since `LineClampData` no longer needs to keep track of how many block boxes there are between the last line and the clmap point, and now OOFs after the clamped line behave the same when clamping by a number of lines or by a height, so there is no need for a flag to distinguish these behaviors. This patch also adds a size assertion for `LineClampData`. This patch also changes or removes some WPT tests that were written assuming the previous behavior. Bug: 40336192, 368114054 Change-Id: I8c8afebb5dc566de92112cee2fcf24a2e60b42c8 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5904459 Reviewed-by: Ian Kilpatrick <ikilpatrickchromium.org> Commit-Queue: Andreu Botella <abotellaigalia.com> Cr-Commit-Position: refs/heads/main{#1364495} -- wpt-commits: 1563c1e3a851d13982c2e9a0c2eabb8287823b35 wpt-pr: 48482 UltraBlame original commit: 5751601c841de1f7d26475e22ebaa4d8ca71b474
…ter a line box, a=testonly Automatic update from web-platform-tests [line-clamp] Always clamp immediately after a line box In our initial implementation of `line-clamp: auto`, we allowed clamping after lineless boxes, in order to better match the behavior of `line-clamp` as it follows from the spec's `continue: discard` model, even though our implementation uses a different model which is not yet in the specification (see w3c/csswg-drafts#7708). However, in hallway conversations in TPAC 2024, we agreed that it would be better for this model to instead only allow clamping immediately after a line. If the first line does not fit, we calmp at the first line even if that overflows the clamp height. If there are no lines, we do not clamp. This patch implements this. Additionally, a previous patch (https://crrev.com/c/5868971) had increased the memory size of `LineClampData` from 8 to 20 bytes, causing a memory regression. This patch shrinks it to 12 bytes, since `LineClampData` no longer needs to keep track of how many block boxes there are between the last line and the clmap point, and now OOFs after the clamped line behave the same when clamping by a number of lines or by a height, so there is no need for a flag to distinguish these behaviors. This patch also adds a size assertion for `LineClampData`. This patch also changes or removes some WPT tests that were written assuming the previous behavior. Bug: 40336192, 368114054 Change-Id: I8c8afebb5dc566de92112cee2fcf24a2e60b42c8 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5904459 Reviewed-by: Ian Kilpatrick <ikilpatrickchromium.org> Commit-Queue: Andreu Botella <abotellaigalia.com> Cr-Commit-Position: refs/heads/main{#1364495} -- wpt-commits: 1563c1e3a851d13982c2e9a0c2eabb8287823b35 wpt-pr: 48482 UltraBlame original commit: 5751601c841de1f7d26475e22ebaa4d8ca71b474
The main usefulness of it is clipping overflowing content from e.g.
line-clamp
, but it seems it'd be easier (and more compatible with how-webkit-line-clamp
works now) if this behaved more likevisibility: hidden
(i.e., stop painting them) rather thandisplay: none
on the overflowing items?It'd also be easier to implement, generally, and I'm not sure when it'd be less useful. It might be that I'm missing something obvious?
cc @bfgeek @frivoal @fantasai
The text was updated successfully, but these errors were encountered: