Bug 89946

Summary: Enforce WebFrameImpl::scopeStringMatches reset flag to start a new search
Product: WebKit Reporter: Carlos <carloschilazo>
Component: WebKit Misc.Assignee: Nobody <webkit-unassigned>
Status: RESOLVED WONTFIX    
Severity: Normal CC: carloschilazo, darin, eric, finnur.webkit
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: All   
OS: All   
URL: http://code.google.com/p/chromium/issues/detail?id=74332
Attachments:
Description Flags
Patch none

Carlos
Reported 2012-06-25 23:16:20 PDT
Related to fixing Chromium issue: http://code.google.com/p/chromium/issues/detail?id=74332 Reset flag in WebFrameImpl::scopeStringMatches (+1680 Source/WebKit/chromium/src/WebFrameImpl.cpp) means we want a brand new search. There is a early return condition which does not consider the reset flag. Situations like in the chromium report we need to start a brand new search, even if shouldScopeMatches(searchText) is false because content changed in a frame. Steps to reproduce: Same as chromium issue
Attachments
Patch (1.13 KB, patch)
2012-06-25 23:25 PDT, Carlos
no flags
Carlos
Comment 1 2012-06-25 23:25:24 PDT
Finnur Thorarinsson
Comment 2 2012-06-26 04:18:58 PDT
I don't think this is the right fix either. Before this change, frames that completed the Find operation and reported 0 matches will not be searched again if you just add more characters to the search. That's no longer the case with this change (basically this disables the optimization altogether). We should be very careful in changing that because in previous tests making that change killed Find performance in large applications like Gmail, if I recall. I guess what needs to happen is that we need to figure out the performance impact of removing this optimization. If it is negligible we can remove all the code below the ASSERT in shouldScopeMatches (and just return true), which might on its own be enough to fix this bug. If that isn't working, then we need to find a way on LOAD_COMMITTED to notify webkit that the frame needs to be searched, even if it returned 0 matches last time. I don't remember if we can trigger something to happen on LOAD_COMMITTED in Webkit (we could then clear the "dont-search-again" flag, I guess), but if not then we'd need to plumb a message down to Webkit from the Browser process to ask it to clear the flag for a particular frame.
Darin Adler
Comment 3 2013-04-09 09:35:19 PDT
Comment on attachment 149463 [details] Patch Clearing flag from a Chromium-specific patch.
Darin Adler
Comment 4 2013-04-09 09:35:37 PDT
Chromium-specific.
Note You need to log in before you can comment on or make changes to this bug.