WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
66322
Prepare frames for history navigation
https://bugs.webkit.org/show_bug.cgi?id=66322
Summary
Prepare frames for history navigation
Gavin Peters
Reported
2011-08-16 11:49:29 PDT
Advance frame state before history navigation in new frame
Attachments
Patch
(2.76 KB, patch)
2011-08-16 11:51 PDT
,
Gavin Peters
no flags
Details
Formatted Diff
Diff
Patch
(5.06 KB, patch)
2011-08-17 16:14 PDT
,
Gavin Peters
no flags
Details
Formatted Diff
Diff
Show Obsolete
(1)
View All
Add attachment
proposed patch, testcase, etc.
Gavin Peters
Comment 1
2011-08-16 11:51:22 PDT
Created
attachment 104075
[details]
Patch
Gavin Peters
Comment 2
2011-08-16 11:52:04 PDT
Comment on
attachment 104075
[details]
Patch By advancing the state machine for a new Frame like this, we avoid getting explicit reloads on history navigation when a back/forward navigation happens to cross a renderer boundary
Gavin Peters
Comment 3
2011-08-16 11:52:31 PDT
fishd, WDYT?
Darin Fisher (:fishd, Google)
Comment 4
2011-08-16 15:25:59 PDT
Comment on
attachment 104075
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=104075&action=review
> Source/WebKit/chromium/src/WebFrameImpl.cpp:905 > + FrameLoaderStateMachine* stateMachine = m_frame->loader()->stateMachine();
The state machine feels like an internal detail of the FrameLoader. I suspect it may be better to add a method on FrameLoader that is expected to perform this fixup. I wonder if we shouldn't move some of the setCurrentItem calls behind such a method too. The challenge is to come up with a good name that properly describes the work.
Darin Fisher (:fishd, Google)
Comment 5
2011-08-16 15:30:16 PDT
(In reply to
comment #2
)
> (From update of
attachment 104075
[details]
) > By advancing the state machine for a new Frame like this, we avoid getting explicit reloads on history navigation when a back/forward navigation happens to cross a renderer boundary
Yes, I think this is the correct fixup to perform when we find that there is no current HistoryItem. One idea is to express all of this in terms of some kind of alternative to Frame::init(), or perhaps as a method that can be called after Frame::init(). Maybe doing this fixup inside loadHistoryItem is the wrong thing. Maybe Chromium should call some extra function after creating the WebView. Maybe instead of initializeMainFrame we should have an initializeMainFrameWithHistoryItem? Or, maybe initializeMainFrame should take a WebHistoryItem parameter?
Gavin Peters
Comment 6
2011-08-17 16:14:54 PDT
Created
attachment 104266
[details]
Patch
Gavin Peters
Comment 7
2011-08-17 16:18:36 PDT
Comment on
attachment 104266
[details]
Patch Thanks for the review Darin. I've elected to add a method to the FrameLoader, and call it from loadFromHistory in the WebFrameImpl. I thought that this was simple enough, and accomplished the goal of having an understandable method that conses up a frame suitable for history navigation. WDYT?
WebKit Review Bot
Comment 8
2011-08-18 04:10:58 PDT
Comment on
attachment 104266
[details]
Patch Clearing flags on attachment: 104266 Committed
r93296
: <
http://trac.webkit.org/changeset/93296
>
WebKit Review Bot
Comment 9
2011-08-18 04:11:03 PDT
All reviewed patches have been landed. Closing bug.
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug