Bug 241442 - Repaint rect does not take into account text-underline-offset
Summary: Repaint rect does not take into account text-underline-offset
Status: RESOLVED FIXED
Alias: None
Product: WebKit
Classification: Unclassified
Component: Layout and Rendering (show other bugs)
Version: WebKit Nightly Build
Hardware: Unspecified Unspecified
: P2 Normal
Assignee: zalan
URL:
Keywords: InRadar
: 242570 (view as bug list)
Depends on: 241471 241474 241488 241490
Blocks:
  Show dependency treegraph
 
Reported: 2022-06-08 18:03 PDT by Jon Lee
Modified: 2022-07-10 06:54 PDT (History)
8 users (show)

See Also:


Attachments
Test reduction (253 bytes, text/html)
2022-06-08 19:30 PDT, zalan
no flags Details
Test reduction (256 bytes, text/html)
2022-06-08 19:32 PDT, zalan
no flags Details
Patch (9.15 KB, patch)
2022-06-09 21:34 PDT, zalan
no flags Details | Formatted Diff | Diff
Patch (13.15 KB, patch)
2022-06-10 10:46 PDT, zalan
no flags Details | Formatted Diff | Diff
Patch (15.35 KB, patch)
2022-06-10 17:01 PDT, zalan
no flags Details | Formatted Diff | Diff

Note You need to log in before you can comment on or make changes to this bug.
Description Jon Lee 2022-06-08 18:03:00 PDT
https://codepen.io/legion80/pen/MWQPoRZ

Hover over the two links.

The hover should turn the underline color to red. It does when the decoration is within the bounding box of the text, but does not when it's outside.
Comment 1 zalan 2022-06-08 19:11:29 PDT
It looks like the underline is supposed to be part of the ink overflow but for some reason we don't take it into account when computing it. When ink overflow is inflated with box-shadow, repaint works just fine.
Comment 2 zalan 2022-06-08 19:15:24 PDT
https://jsfiddle.net/7f16hr4d/
Comment 3 zalan 2022-06-08 19:30:28 PDT
Created attachment 460109 [details]
Test reduction
Comment 4 zalan 2022-06-08 19:32:35 PDT
Created attachment 460110 [details]
Test reduction

make it less flaky by adding some non-zero timeout
Comment 5 Radar WebKit Bug Importer 2022-06-08 19:50:39 PDT
<rdar://problem/94686075>
Comment 6 zalan 2022-06-09 21:34:33 PDT
Created attachment 460155 [details]
Patch
Comment 7 zalan 2022-06-09 21:40:53 PDT
(In reply to zalan from comment #6)
> Created attachment 460155 [details]
> Patch
need to come up with some test cases including vertical and flipped modes.
Comment 8 zalan 2022-06-10 10:46:13 PDT
Created attachment 460163 [details]
Patch
Comment 9 Myles C. Maxfield 2022-06-10 11:24:55 PDT
Last time I tried to do this, it caused a large performance regression due to repaint rects intersecting new renderers, which caused more to be rendered than used to be rendered. Are you confident this doesn't cause a performance regression?
Comment 10 Myles C. Maxfield 2022-06-10 11:26:37 PDT
See https://bugs.webkit.org/show_bug.cgi?id=190774
Comment 11 zalan 2022-06-10 11:39:04 PDT
(In reply to Myles C. Maxfield from comment #9)
> Last time I tried to do this, it caused a large performance regression due
> to repaint rects intersecting new renderers, which caused more to be
> rendered than used to be rendered. Are you confident this doesn't cause a
> performance regression?
Wasn't that mostly about RenderStyle::changeAffectsVisualOverflow (https://trac.webkit.org/changeset/244277)? None of that has changed here. This is about matching ink overflow produced by legacy line layout (and while this patch certainly has performance implications when certain properties are present, we don't really have a choice but inflate the ink overflow rect as needed).
Comment 12 zalan 2022-06-10 12:13:18 PDT
Comment on attachment 460163 [details]
Patch

repaintrect height went from 12 to 13 (probably because of the +1 to compensate for the integral ceiling in GraphicsContext::computeLineBoundsAndAntialiasingModeForText()
will rebaseline.
Comment 13 zalan 2022-06-10 17:01:44 PDT
Created attachment 460171 [details]
Patch
Comment 14 EWS 2022-06-10 22:34:51 PDT
Committed r295472 (251477@main): <https://commits.webkit.org/251477@main>

All reviewed patches have been landed. Closing bug and clearing flags on attachment 460171 [details].
Comment 15 zalan 2022-06-11 06:56:29 PDT
Thank you for reporting this bug!
Comment 16 Darin Adler 2022-06-11 09:52:19 PDT
In future can just use “internals” instead of “window.internals” in almost all cases.
Comment 17 zalan 2022-06-11 15:51:17 PDT
(In reply to Darin Adler from comment #16)
> In future can just use “internals” instead of “window.internals” in almost
> all cases.
Thanks, will do!
Comment 18 zalan 2022-07-10 06:54:29 PDT
*** Bug 242570 has been marked as a duplicate of this bug. ***