Bug 6770

Summary: REGRESSION: Incomplete repaint when block with clipping grows
Product: WebKit Reporter: mitz
Component: Layout and RenderingAssignee: Nobody <webkit-unassigned>
Status: RESOLVED FIXED    
Severity: Normal CC: alice.barraclough, hyatt
Priority: P1 Keywords: HasReduction, InRadar, Regression
Version: 420+   
Hardware: Mac   
OS: OS X 10.4   
Attachments:
Description Flags
Testcase
none
Possible fix
none
Possible fix
none
Possible fix
hyatt: review-
Patch, including change log and manual test hyatt: review+

mitz
Reported 2006-01-24 13:20:40 PST
See the attached testcase. In this case, since the block with the border grows and repaints before its container (which is clipping) grows, so in RenderObject::repaintAfterLayoutIfNeeded it sees that its old bounds are equal to its new bounds and it doesn't repaint. When the container repaints, it paints only the delta, so the old border of the inner block isn't erased.
Attachments
Testcase (401 bytes, text/html)
2006-01-24 13:22 PST, mitz
no flags
Possible fix (2.73 KB, patch)
2006-04-16 14:07 PDT, mitz
no flags
Possible fix (2.73 KB, patch)
2006-04-16 15:36 PDT, mitz
no flags
Possible fix (2.74 KB, patch)
2006-04-16 15:37 PDT, mitz
hyatt: review-
Patch, including change log and manual test (5.52 KB, patch)
2006-04-18 14:15 PDT, mitz
hyatt: review+
mitz
Comment 1 2006-01-24 13:22:00 PST
Created attachment 5926 [details] Testcase
Alice Liu
Comment 2 2006-03-20 06:47:53 PST
mitz
Comment 3 2006-04-16 14:07:41 PDT
Created attachment 7750 [details] Possible fix I think this patch does not add a lot of painting, and what it does add can be divided between 1) what's needed to fix the bug: the layer did not need layout, but ended up resizing because of a child. 2) addressing the fact that the selfNeedsLayout() condition in repaintAfterLayoutIfNeeded() is always false when called from the layer.
mitz
Comment 4 2006-04-16 15:36:15 PDT
Created attachment 7751 [details] Possible fix Please see my previous comment.
mitz
Comment 5 2006-04-16 15:37:54 PDT
Created attachment 7752 [details] Possible fix Sorry, uploaded the wrong file.
Darin Adler
Comment 6 2006-04-16 19:39:54 PDT
Comment on attachment 7752 [details] Possible fix This sure looks good to me, but I think it's something Hyatt will want to review himself.
Dave Hyatt
Comment 7 2006-04-17 14:12:04 PDT
Won't this cause way too much repainting? Turn on paint flashing and try loading a huge file like: http://lxr.mozilla.org/seamonkey/source/layout/base/nsCSSFrameConstructor.cpp Do you see the whole window repainting now with this fix as chunks of data come in? It seems like this fix will cause the root block's layer to repaint whenever new chunks of data come in that make the root block's layer grow.
mitz
Comment 8 2006-04-17 15:00:26 PDT
(In reply to comment #7) > It seems like this fix will cause the root block's layer to repaint whenever > new chunks of data come in that make the root block's layer grow. Oh boy, I overlooked that! I think instead of + m_fullRepaintOnResize = m_object->selfNeedsLayout() || m_object->normalChildNeedsLayout(); it should be + m_fullRepaintOnResize = m_object->selfNeedsLayout() || m_object->hasOverflowClip() && m_object->normalChildNeedsLayout();
Dave Hyatt
Comment 9 2006-04-17 17:39:55 PDT
Comment on attachment 7752 [details] Possible fix Even that change will still cause overflow blocks to repaint over and over as they load content.
mitz
Comment 10 2006-04-18 01:13:06 PDT
(In reply to comment #9) > (From update of attachment 7752 [details] [edit]) > Even that change will still cause overflow blocks to repaint over and over as > they load content. In what case, other than when adding content causes their layer to resize (which is what this bug is about)?
mitz
Comment 11 2006-04-18 14:15:56 PDT
Created attachment 7810 [details] Patch, including change log and manual test Added the hasOverflowClip() check and renamed the flag per Hyatt's suggestion.
Dave Hyatt
Comment 12 2006-04-18 14:17:30 PDT
Comment on attachment 7810 [details] Patch, including change log and manual test r=me
Timothy Hatcher
Comment 13 2006-04-19 19:48:01 PDT
Landed in r13982.
Note You need to log in before you can comment on or make changes to this bug.