Index: content/renderer/render_frame_impl.cc |
diff --git a/content/renderer/render_frame_impl.cc b/content/renderer/render_frame_impl.cc |
index 30d405fe6e5f4ff5944f0ff7a2dbf80b3ee3ba32..27276bdc75a917dfa3b710e81192ac32ae88e4a9 100644 |
--- a/content/renderer/render_frame_impl.cc |
+++ b/content/renderer/render_frame_impl.cc |
@@ -740,6 +740,7 @@ bool RenderFrameImpl::OnMessageReceived(const IPC::Message& msg) { |
IPC_MESSAGE_HANDLER(FrameMsg_Navigate, OnNavigate) |
IPC_MESSAGE_HANDLER(FrameMsg_BeforeUnload, OnBeforeUnload) |
IPC_MESSAGE_HANDLER(FrameMsg_SwapOut, OnSwapOut) |
+ IPC_MESSAGE_HANDLER(FrameMsg_Stop, OnStop) |
IPC_MESSAGE_HANDLER(FrameMsg_ContextMenuClosed, OnContextMenuClosed) |
IPC_MESSAGE_HANDLER(FrameMsg_CustomContextMenuAction, |
OnCustomContextMenuAction) |
@@ -1028,10 +1029,7 @@ void RenderFrameImpl::OnSwapOut(int proxy_routing_id) { |
// TODO(creis): Should we be stopping all frames here and using |
// StopAltErrorPageFetcher with RenderView::OnStop, or just stopping this |
// frame? |
- if (!frame_->parent()) |
- render_view_->OnStop(); |
- else |
- frame_->stopLoading(); |
+ OnStop(); |
// Let subframes know that the frame is now rendered remotely, for the |
// purposes of compositing and input events. |
@@ -3056,6 +3054,11 @@ void RenderFrameImpl::RemoveObserver(RenderFrameObserver* observer) { |
} |
void RenderFrameImpl::OnStop() { |
+ DCHECK(frame_); |
+ frame_->stopLoading(); |
+ if (!frame_->parent()) |
+ FOR_EACH_OBSERVER(RenderViewObserver, render_view_->observers_, OnStop()); |
+ |
FOR_EACH_OBSERVER(RenderFrameObserver, observers_, OnStop()); |
} |