Bug 56856

Summary: RenderListBox needs to be added to Page::scrollableAreaSet()
Product: WebKit Reporter: Beth Dakin <bdakin>
Component: Layout and RenderingAssignee: Beth Dakin <bdakin>
Status: RESOLVED FIXED    
Severity: Normal CC: bdakin, leandrogracia
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: PC   
OS: OS X 10.5   
Attachments:
Description Flags
Pacth
simon.fraser: review+
Patch sent to wrong bug. Please delete. none

Beth Dakin
Reported 2011-03-22 12:33:14 PDT
http://trac.webkit.org/changeset/81209 added a HashSet of ScrollableAreas to Page. The patch I attached to https://bugs.webkit.org/show_bug.cgi?id=56067 correctly added code to RenderListBox to add and remove them from the set, but somehow this code did not get committed. Here is a patch to add RenderListBoxes to the set.
Attachments
Pacth (2.10 KB, patch)
2011-03-22 12:42 PDT, Beth Dakin
simon.fraser: review+
Patch sent to wrong bug. Please delete. (8.46 KB, text/plain)
2011-04-08 06:51 PDT, Leandro Graciá Gil
no flags
Beth Dakin
Comment 1 2011-03-22 12:42:50 PDT
Simon Fraser (smfr)
Comment 2 2011-03-22 13:06:14 PDT
Comment on attachment 86493 [details] Pacth View in context: https://bugs.webkit.org/attachment.cgi?id=86493&action=review > Source/WebCore/rendering/RenderListBox.cpp:88 > + if (Page* page = frame()->page()) { > + m_page = page; > + m_page->addScrollableArea(this); > + } It's unfortunate to have to store the Page here. Is there a way to do the removeScrollableArea() earlier, while the renderer can still get to the page?
Beth Dakin
Comment 3 2011-03-22 13:18:02 PDT
An alternative design that might work would be to have a call in Document::detach() that empties the Page's HashSet completely, and then to leave code in the RenderBlah destructors that removes the object from the set only if the frame still has a page, thereby implying that the document has not been detached. However, I would really rather file a different bug to do this differently if that's what we want to do RenderLayer and RenderDataGrid already got local Page pointers in https://bugs.webkit.org/show_bug.cgi?id=56067 , and it was just a mistake that this code was not committed then. I would rather not spend time re-designing this right now to fix this bad oversight, but I am definitely open to re-designing it at a later point in time.
Beth Dakin
Comment 4 2011-03-22 14:33:49 PDT
Thanks! Fixed with revision 81704.
Leandro Graciá Gil
Comment 5 2011-04-08 06:51:46 PDT
Created attachment 88813 [details] Patch sent to wrong bug. Please delete. Adding the new tests to the skip lists of all non-chromium platforms as the Media Stream API is not enabled in them.
Leandro Graciá Gil
Comment 6 2011-04-08 06:53:19 PDT
(In reply to comment #5) > Created an attachment (id=88813) [details] > Patch > > Adding the new tests to the skip lists of all non-chromium platforms as the Media Stream API is not enabled in them. Sorry, wrong bug number when submitting it (56586). Please delete if possible.
Note You need to log in before you can comment on or make changes to this bug.