commit | 5e7a2e406d37d6b81c2880c5b9b9c16ccf994dc2 | [log] [tgz] |
---|---|---|
author | Morten Stenshorne <mstensho@chromium.org> | Fri May 06 07:47:26 2022 |
committer | Chromium LUCI CQ <chromium-scoped@luci-project-accounts.iam.gserviceaccount.com> | Fri May 06 07:47:26 2022 |
tree | b97e90650e5979289ae606c264728552a0bbc326 | |
parent | 5a27dc4a1f8d74b0e1f69741ede50ee08c7a1e16 [diff] |
Always create an anonymous contents wrapper inside a fieldset. This way we'll have less to worry about in the layout algorithm. Padding handling was incorrect, and it caused an infinite loop, because the algorithm expected the anonymous child to take care of trailing padding, and therefore didn't pass it to FinishFragmentation(). We therefore failed to treat the trailing padding as monolithic. We need to treat padding as monolithic, or we might never get past it if it's taller than the fragmentainer (and push it ahead of us into the next fragmentainer infinitely). The fragmentation code would believe that we managed to fit some of it in one fragmentainer, but we'd in fact try again from the start of the padding-block-end in the next fragmentainer (because it should be monolithic, that's why!) - forever. Just making sure that there's always an anonymous contents wrapper simplifies things and fixes bugs, including a minor correctness bug; see the new test empty-scrollable.html Some unit tests had to be updated. These expectations were mostly last touched by CL:2960239 , which eliminated the need for anonymous content wrappers if the fieldset only had a legend child. Now we'll always create them. Bug: 1322426 Change-Id: I215ecd6387e388d0a6801476b6269cb8fb84cba3 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3629580 Commit-Queue: Morten Stenshorne <mstensho@chromium.org> Reviewed-by: Alison Maher <almaher@microsoft.com> Reviewed-by: Kent Tamura <tkent@chromium.org> Cr-Commit-Position: refs/heads/main@{#1000277}
Chromium is an open-source browser project that aims to build a safer, faster, and more stable way for all users to experience the web.
The project's web site is https://www.chromium.org.
To check out the source code locally, don't use git clone
! Instead, follow the instructions on how to get the code.
Documentation in the source is rooted in docs/README.md.
Learn how to Get Around the Chromium Source Code Directory Structure .
For historical reasons, there are some small top level directories. Now the guidance is that new top level directories are for product (e.g. Chrome, Android WebView, Ash). Even if these products have multiple executables, the code should be in subdirectories of the product.
If you found a bug, please file it at https://crbug.com/new.