Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(59)

Side by Side Diff: content/browser/renderer_host/render_view_host.cc

Issue 6319001: Support window.opener after a process swap. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Better message filtering approach. Created 9 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "content/browser/renderer_host/render_view_host.h" 5 #include "content/browser/renderer_host/render_view_host.h"
6 6
7 #include <string> 7 #include <string>
8 #include <utility> 8 #include <utility>
9 #include <vector> 9 #include <vector>
10 10
(...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after
85 85
86 RenderViewHost::RenderViewHost(SiteInstance* instance, 86 RenderViewHost::RenderViewHost(SiteInstance* instance,
87 RenderViewHostDelegate* delegate, 87 RenderViewHostDelegate* delegate,
88 int routing_id, 88 int routing_id,
89 SessionStorageNamespace* session_storage) 89 SessionStorageNamespace* session_storage)
90 : RenderWidgetHost(instance->GetProcess(), routing_id), 90 : RenderWidgetHost(instance->GetProcess(), routing_id),
91 instance_(instance), 91 instance_(instance),
92 delegate_(delegate), 92 delegate_(delegate),
93 waiting_for_drag_context_response_(false), 93 waiting_for_drag_context_response_(false),
94 enabled_bindings_(0), 94 enabled_bindings_(0),
95 pending_request_id_(0), 95 pending_request_id_(-1),
96 navigations_suspended_(false), 96 navigations_suspended_(false),
97 suspended_nav_message_(NULL), 97 suspended_nav_message_(NULL),
98 is_swapped_out_(false),
98 run_modal_reply_msg_(NULL), 99 run_modal_reply_msg_(NULL),
99 is_waiting_for_beforeunload_ack_(false), 100 is_waiting_for_beforeunload_ack_(false),
100 is_waiting_for_unload_ack_(false), 101 is_waiting_for_unload_ack_(false),
101 unload_ack_is_for_cross_site_transition_(false), 102 unload_ack_is_for_cross_site_transition_(false),
102 are_javascript_messages_suppressed_(false), 103 are_javascript_messages_suppressed_(false),
103 sudden_termination_allowed_(false), 104 sudden_termination_allowed_(false),
104 session_storage_namespace_(session_storage), 105 session_storage_namespace_(session_storage),
105 is_extension_process_(false), 106 is_extension_process_(false),
106 save_accessibility_tree_for_testing_(false), 107 save_accessibility_tree_for_testing_(false),
107 render_view_termination_status_(base::TERMINATION_STATUS_STILL_RUNNING) { 108 render_view_termination_status_(base::TERMINATION_STATUS_STILL_RUNNING) {
(...skipping 143 matching lines...) Expand 10 before | Expand all | Expand 10 after
251 Navigate(params); 252 Navigate(params);
252 } 253 }
253 254
254 void RenderViewHost::SetNavigationsSuspended(bool suspend) { 255 void RenderViewHost::SetNavigationsSuspended(bool suspend) {
255 // This should only be called to toggle the state. 256 // This should only be called to toggle the state.
256 DCHECK(navigations_suspended_ != suspend); 257 DCHECK(navigations_suspended_ != suspend);
257 258
258 navigations_suspended_ = suspend; 259 navigations_suspended_ = suspend;
259 if (!suspend && suspended_nav_message_.get()) { 260 if (!suspend && suspended_nav_message_.get()) {
260 // There's a navigation message waiting to be sent. Now that we're not 261 // There's a navigation message waiting to be sent. Now that we're not
261 // suspended anymore, resume navigation by sending it. 262 // suspended anymore, resume navigation by sending it. If we were swapped
263 // out, we should also stop filtering out the IPC messages now.
264 is_swapped_out_ = false;
262 Send(suspended_nav_message_.release()); 265 Send(suspended_nav_message_.release());
263 } 266 }
264 } 267 }
265 268
269 void RenderViewHost::CancelSuspendedNavigations() {
270 // Clear any state if a pending navigation is canceled or pre-empted.
271 if (suspended_nav_message_.get())
272 suspended_nav_message_.reset();
273 navigations_suspended_ = false;
274 }
275
266 void RenderViewHost::FirePageBeforeUnload(bool for_cross_site_transition) { 276 void RenderViewHost::FirePageBeforeUnload(bool for_cross_site_transition) {
267 if (!IsRenderViewLive()) { 277 if (!IsRenderViewLive()) {
268 // This RenderViewHost doesn't have a live renderer, so just skip running 278 // This RenderViewHost doesn't have a live renderer, so just skip running
269 // the onbeforeunload handler. 279 // the onbeforeunload handler.
270 is_waiting_for_beforeunload_ack_ = true; // Checked by OnMsgShouldCloseACK. 280 is_waiting_for_beforeunload_ack_ = true; // Checked by OnMsgShouldCloseACK.
271 unload_ack_is_for_cross_site_transition_ = for_cross_site_transition; 281 unload_ack_is_for_cross_site_transition_ = for_cross_site_transition;
272 OnMsgShouldCloseACK(true); 282 OnMsgShouldCloseACK(true);
273 return; 283 return;
274 } 284 }
275 285
(...skipping 12 matching lines...) Expand all
288 } else { 298 } else {
289 // Start the hang monitor in case the renderer hangs in the beforeunload 299 // Start the hang monitor in case the renderer hangs in the beforeunload
290 // handler. 300 // handler.
291 is_waiting_for_beforeunload_ack_ = true; 301 is_waiting_for_beforeunload_ack_ = true;
292 unload_ack_is_for_cross_site_transition_ = for_cross_site_transition; 302 unload_ack_is_for_cross_site_transition_ = for_cross_site_transition;
293 StartHangMonitorTimeout(TimeDelta::FromMilliseconds(kUnloadTimeoutMS)); 303 StartHangMonitorTimeout(TimeDelta::FromMilliseconds(kUnloadTimeoutMS));
294 Send(new ViewMsg_ShouldClose(routing_id())); 304 Send(new ViewMsg_ShouldClose(routing_id()));
295 } 305 }
296 } 306 }
297 307
298 void RenderViewHost::ClosePage(bool for_cross_site_transition, 308 void RenderViewHost::SwapOut(int new_render_process_host_id,
299 int new_render_process_host_id, 309 int new_request_id) {
300 int new_request_id) { 310 // Start filtering IPC messages to avoid confusing the delegate. This will
301 // This will be set back to false in OnClosePageACK, just before we close the 311 // prevent any dialogs from appearing during unload handlers, but we've
302 // tab or replace it with a pending RVH. There are some cases (such as 204 312 // already decided to silence them in crbug.com/68780. We will set it back
303 // errors) where we'll continue to show this RVH. 313 // to false in SetNavigationsSuspended if we swap back in.
314 is_swapped_out_ = true;
315
316 // This will be set back to false in OnSwapOutACK, just before we replace
317 // this RVH with the pending RVH.
304 is_waiting_for_unload_ack_ = true; 318 is_waiting_for_unload_ack_ = true;
305 // Start the hang monitor in case the renderer hangs in the unload handler. 319 // Start the hang monitor in case the renderer hangs in the unload handler.
306 StartHangMonitorTimeout(TimeDelta::FromMilliseconds(kUnloadTimeoutMS)); 320 StartHangMonitorTimeout(TimeDelta::FromMilliseconds(kUnloadTimeoutMS));
307 321
308 ViewMsg_ClosePage_Params params; 322 ViewMsg_SwapOut_Params params;
309 params.closing_process_id = process()->id(); 323 params.closing_process_id = process()->id();
310 params.closing_route_id = routing_id(); 324 params.closing_route_id = routing_id();
311 params.for_cross_site_transition = for_cross_site_transition;
312 params.new_render_process_host_id = new_render_process_host_id; 325 params.new_render_process_host_id = new_render_process_host_id;
313 params.new_request_id = new_request_id; 326 params.new_request_id = new_request_id;
314 if (IsRenderViewLive()) { 327 if (IsRenderViewLive()) {
328 Send(new ViewMsg_SwapOut(routing_id(), params));
329 } else {
330 // This RenderViewHost doesn't have a live renderer, so just skip the unload
331 // event. We must notify the ResourceDispatcherHost on the IO thread,
332 // which we will do through the RenderProcessHost's widget helper.
333 process()->CrossSiteSwapOutACK(params);
334 }
335 }
336
337 void RenderViewHost::OnSwapOutACK() {
338 // Stop the hang monitor now that the unload handler has finished.
339 StopHangMonitorTimeout();
340 is_waiting_for_unload_ack_ = false;
341 }
342
343 void RenderViewHost::WasSwappedOut() {
344 // Don't bother reporting hung state anymore.
345 StopHangMonitorTimeout();
346
347 // Inform the renderer that it can exit if no one else is using it.
348 Send(new ViewMsg_WasSwappedOut(routing_id()));
349 }
350
351 void RenderViewHost::ClosePage() {
352 // Start the hang monitor in case the renderer hangs in the unload handler.
353 is_waiting_for_unload_ack_ = true;
354 StartHangMonitorTimeout(TimeDelta::FromMilliseconds(kUnloadTimeoutMS));
355
356 if (IsRenderViewLive()) {
357 // TODO(creis): Should this be moved to Shutdown? It may not be called for
358 // RenderViewHosts that have been swapped out.
315 NotificationService::current()->Notify( 359 NotificationService::current()->Notify(
316 NotificationType::RENDER_VIEW_HOST_WILL_CLOSE_RENDER_VIEW, 360 NotificationType::RENDER_VIEW_HOST_WILL_CLOSE_RENDER_VIEW,
317 Source<RenderViewHost>(this), 361 Source<RenderViewHost>(this),
318 NotificationService::NoDetails()); 362 NotificationService::NoDetails());
319 363
320 Send(new ViewMsg_ClosePage(routing_id(), params)); 364 Send(new ViewMsg_ClosePage(routing_id()));
321 } else { 365 } else {
322 // This RenderViewHost doesn't have a live renderer, so just skip closing 366 // This RenderViewHost doesn't have a live renderer, so just skip the unload
323 // the page. We must notify the ResourceDispatcherHost on the IO thread, 367 // event and close the page.
324 // which we will do through the RenderProcessHost's widget helper.
325 process()->CrossSiteClosePageACK(params);
326 }
327 }
328
329 void RenderViewHost::OnClosePageACK(bool for_cross_site_transition) {
330 StopHangMonitorTimeout();
331 is_waiting_for_unload_ack_ = false;
332
333 // If this ClosePageACK is not for a cross-site transition, then it is for an
334 // attempt to close the tab. We have now finished the unload handler and can
335 // proceed with closing the tab.
336 if (!for_cross_site_transition) {
337 ClosePageIgnoringUnloadEvents(); 368 ClosePageIgnoringUnloadEvents();
338 } 369 }
339 } 370 }
340 371
341 void RenderViewHost::ClosePageIgnoringUnloadEvents() { 372 void RenderViewHost::ClosePageIgnoringUnloadEvents() {
342 StopHangMonitorTimeout(); 373 StopHangMonitorTimeout();
343 is_waiting_for_beforeunload_ack_ = false; 374 is_waiting_for_beforeunload_ack_ = false;
344 is_waiting_for_unload_ack_ = false; 375 is_waiting_for_unload_ack_ = false;
345 376
346 sudden_termination_allowed_ = true; 377 sudden_termination_allowed_ = true;
(...skipping 333 matching lines...) Expand 10 before | Expand all | Expand 10 after
680 return sudden_termination_allowed_ || process()->sudden_termination_allowed(); 711 return sudden_termination_allowed_ || process()->sudden_termination_allowed();
681 } 712 }
682 713
683 /////////////////////////////////////////////////////////////////////////////// 714 ///////////////////////////////////////////////////////////////////////////////
684 // RenderViewHost, IPC message handlers: 715 // RenderViewHost, IPC message handlers:
685 716
686 bool RenderViewHost::OnMessageReceived(const IPC::Message& msg) { 717 bool RenderViewHost::OnMessageReceived(const IPC::Message& msg) {
687 if (!BrowserMessageFilter::CheckCanDispatchOnUI(msg, this)) 718 if (!BrowserMessageFilter::CheckCanDispatchOnUI(msg, this))
688 return true; 719 return true;
689 720
721 // Filter out most IPC messages if this renderer is swapped out.
722 // We still want to certain ACKs to keep our state consistent.
723 if (is_swapped_out_)
724 if (!CanHandleWhileSwappedOut(msg))
725 return true;
726
690 { 727 {
691 // delegate_->OnMessageReceived can end up deleting |this|, in which case 728 // delegate_->OnMessageReceived can end up deleting |this|, in which case
692 // the destructor for ObserverListBase::Iterator would access the deleted 729 // the destructor for ObserverListBase::Iterator would access the deleted
693 // observers_. 730 // observers_.
694 ObserverListBase<RenderViewHostObserver>::Iterator it(observers_); 731 ObserverListBase<RenderViewHostObserver>::Iterator it(observers_);
695 RenderViewHostObserver* observer; 732 RenderViewHostObserver* observer;
696 while ((observer = it.GetNext()) != NULL) 733 while ((observer = it.GetNext()) != NULL)
697 if (observer->OnMessageReceived(msg)) 734 if (observer->OnMessageReceived(msg))
698 return true; 735 return true;
699 } 736 }
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
737 IPC_MESSAGE_HANDLER(ViewHostMsg_SetTooltipText, OnMsgSetTooltipText) 774 IPC_MESSAGE_HANDLER(ViewHostMsg_SetTooltipText, OnMsgSetTooltipText)
738 IPC_MESSAGE_HANDLER_DELAY_REPLY(ViewHostMsg_RunJavaScriptMessage, 775 IPC_MESSAGE_HANDLER_DELAY_REPLY(ViewHostMsg_RunJavaScriptMessage,
739 OnMsgRunJavaScriptMessage) 776 OnMsgRunJavaScriptMessage)
740 IPC_MESSAGE_HANDLER_DELAY_REPLY(ViewHostMsg_RunBeforeUnloadConfirm, 777 IPC_MESSAGE_HANDLER_DELAY_REPLY(ViewHostMsg_RunBeforeUnloadConfirm,
741 OnMsgRunBeforeUnloadConfirm) 778 OnMsgRunBeforeUnloadConfirm)
742 IPC_MESSAGE_HANDLER(DragHostMsg_StartDragging, OnMsgStartDragging) 779 IPC_MESSAGE_HANDLER(DragHostMsg_StartDragging, OnMsgStartDragging)
743 IPC_MESSAGE_HANDLER(DragHostMsg_UpdateDragCursor, OnUpdateDragCursor) 780 IPC_MESSAGE_HANDLER(DragHostMsg_UpdateDragCursor, OnUpdateDragCursor)
744 IPC_MESSAGE_HANDLER(ViewHostMsg_TakeFocus, OnTakeFocus) 781 IPC_MESSAGE_HANDLER(ViewHostMsg_TakeFocus, OnTakeFocus)
745 IPC_MESSAGE_HANDLER(ViewHostMsg_AddMessageToConsole, OnAddMessageToConsole) 782 IPC_MESSAGE_HANDLER(ViewHostMsg_AddMessageToConsole, OnAddMessageToConsole)
746 IPC_MESSAGE_HANDLER(ViewHostMsg_ShouldClose_ACK, OnMsgShouldCloseACK) 783 IPC_MESSAGE_HANDLER(ViewHostMsg_ShouldClose_ACK, OnMsgShouldCloseACK)
784 IPC_MESSAGE_HANDLER(ViewHostMsg_ClosePage_ACK, OnMsgClosePageACK)
747 IPC_MESSAGE_HANDLER(ViewHostMsg_SelectionChanged, OnMsgSelectionChanged) 785 IPC_MESSAGE_HANDLER(ViewHostMsg_SelectionChanged, OnMsgSelectionChanged)
748 IPC_MESSAGE_HANDLER(ViewHostMsg_AccessibilityNotifications, 786 IPC_MESSAGE_HANDLER(ViewHostMsg_AccessibilityNotifications,
749 OnAccessibilityNotifications) 787 OnAccessibilityNotifications)
750 IPC_MESSAGE_HANDLER(ViewHostMsg_OnCSSInserted, OnCSSInserted) 788 IPC_MESSAGE_HANDLER(ViewHostMsg_OnCSSInserted, OnCSSInserted)
751 IPC_MESSAGE_HANDLER(ViewHostMsg_ContentBlocked, OnContentBlocked) 789 IPC_MESSAGE_HANDLER(ViewHostMsg_ContentBlocked, OnContentBlocked)
752 IPC_MESSAGE_HANDLER(ViewHostMsg_AppCacheAccessed, OnAppCacheAccessed) 790 IPC_MESSAGE_HANDLER(ViewHostMsg_AppCacheAccessed, OnAppCacheAccessed)
753 IPC_MESSAGE_HANDLER(ViewHostMsg_WebDatabaseAccessed, OnWebDatabaseAccessed) 791 IPC_MESSAGE_HANDLER(ViewHostMsg_WebDatabaseAccessed, OnWebDatabaseAccessed)
754 IPC_MESSAGE_HANDLER(ViewHostMsg_FocusedNodeChanged, OnMsgFocusedNodeChanged) 792 IPC_MESSAGE_HANDLER(ViewHostMsg_FocusedNodeChanged, OnMsgFocusedNodeChanged)
755 IPC_MESSAGE_HANDLER(ViewHostMsg_UpdateZoomLimits, OnUpdateZoomLimits) 793 IPC_MESSAGE_HANDLER(ViewHostMsg_UpdateZoomLimits, OnUpdateZoomLimits)
756 IPC_MESSAGE_HANDLER(ViewHostMsg_ScriptEvalResponse, OnScriptEvalResponse) 794 IPC_MESSAGE_HANDLER(ViewHostMsg_ScriptEvalResponse, OnScriptEvalResponse)
757 #if defined(OS_MACOSX) 795 #if defined(OS_MACOSX)
758 IPC_MESSAGE_HANDLER(ViewHostMsg_ShowPopup, OnMsgShowPopup) 796 IPC_MESSAGE_HANDLER(ViewHostMsg_ShowPopup, OnMsgShowPopup)
759 #endif 797 #endif
760 IPC_MESSAGE_HANDLER(ViewHostMsg_CommandStateChanged, 798 IPC_MESSAGE_HANDLER(ViewHostMsg_CommandStateChanged,
761 OnCommandStateChanged) 799 OnCommandStateChanged)
762 // Have the super handle all other messages. 800 // Have the super handle all other messages.
763 IPC_MESSAGE_UNHANDLED(handled = RenderWidgetHost::OnMessageReceived(msg)) 801 IPC_MESSAGE_UNHANDLED(handled = RenderWidgetHost::OnMessageReceived(msg))
764 IPC_END_MESSAGE_MAP_EX() 802 IPC_END_MESSAGE_MAP_EX()
765 803
766 if (!msg_is_ok) { 804 if (!msg_is_ok) {
767 // The message had a handler, but its de-serialization failed. 805 // The message had a handler, but its de-serialization failed.
768 // Kill the renderer. 806 // Kill the renderer.
769 UserMetrics::RecordAction(UserMetricsAction("BadMessageTerminate_RVH")); 807 UserMetrics::RecordAction(UserMetricsAction("BadMessageTerminate_RVH"));
770 process()->ReceivedBadMessage(); 808 process()->ReceivedBadMessage();
771 } 809 }
772 810
773 return handled; 811 return handled;
774 } 812 }
775 813
814 bool RenderViewHost::CanHandleWhileSwappedOut(const IPC::Message& msg) {
815 // We drop most messages that arrive from a swapped out renderer. However,
816 // some are important (e.g., ACKs) for keeping the browser and renderer state
817 // consistent in case we later return to the renderer.
818 switch (msg.type()) {
819 // Sends an ACK.
820 case ViewHostMsg_ShowView::ID:
821 // Sends an ACK.
822 case ViewHostMsg_ShowWidget::ID:
823 // Sends an ACK.
824 case ViewHostMsg_ShowFullscreenWidget::ID:
825 // Updates browser state.
826 case ViewHostMsg_RenderViewReady::ID:
827 // Updates browser state.
828 case ViewHostMsg_RenderViewGone::ID:
829 // Updates the previous navigation entry.
830 case ViewHostMsg_UpdateState::ID:
831 // Sends an ACK.
832 case ViewHostMsg_UpdateTargetURL::ID:
833 // Updates browser state.
834 case ViewHostMsg_Snapshot::ID:
835 // We allow closing even if we are in the process of swapping out.
836 case ViewHostMsg_Close::ID:
837 // Sends an ACK.
838 case ViewHostMsg_RequestMove::ID:
839 // Updates browser state, and important for tests.
840 case ViewHostMsg_DomOperationResponse::ID:
841 // Suppresses dialog and sends an ACK.
842 case ViewHostMsg_RunJavaScriptMessage::ID:
843 // Suppresses dialog and sends an ACK.
844 case ViewHostMsg_RunBeforeUnloadConfirm::ID:
845 // Stops hang monitor.
846 case ViewHostMsg_ShouldClose_ACK::ID:
847 // We allow closing even if we are in the process of swapping out.
848 case ViewHostMsg_ClosePage_ACK::ID:
849 // Sends an ACK.
850 case ViewHostMsg_AccessibilityNotifications::ID:
851 return true;
852 default:
853 break;
854 }
855 return false;
856 }
857
776 void RenderViewHost::Shutdown() { 858 void RenderViewHost::Shutdown() {
777 // If we are being run modally (see RunModal), then we need to cleanup. 859 // If we are being run modally (see RunModal), then we need to cleanup.
778 if (run_modal_reply_msg_) { 860 if (run_modal_reply_msg_) {
779 Send(run_modal_reply_msg_); 861 Send(run_modal_reply_msg_);
780 run_modal_reply_msg_ = NULL; 862 run_modal_reply_msg_ = NULL;
781 } 863 }
782 864
783 RenderWidgetHost::Shutdown(); 865 RenderWidgetHost::Shutdown();
784 } 866 }
785 867
(...skipping 23 matching lines...) Expand all
809 if (view) 891 if (view)
810 view->CreateNewFullscreenWidget(route_id); 892 view->CreateNewFullscreenWidget(route_id);
811 } 893 }
812 894
813 void RenderViewHost::OnMsgShowView(int route_id, 895 void RenderViewHost::OnMsgShowView(int route_id,
814 WindowOpenDisposition disposition, 896 WindowOpenDisposition disposition,
815 const gfx::Rect& initial_pos, 897 const gfx::Rect& initial_pos,
816 bool user_gesture) { 898 bool user_gesture) {
817 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate(); 899 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate();
818 if (view) { 900 if (view) {
819 view->ShowCreatedWindow(route_id, disposition, initial_pos, user_gesture); 901 if (!is_swapped_out_)
902 view->ShowCreatedWindow(route_id, disposition, initial_pos, user_gesture);
820 Send(new ViewMsg_Move_ACK(route_id)); 903 Send(new ViewMsg_Move_ACK(route_id));
821 } 904 }
822 } 905 }
823 906
824 void RenderViewHost::OnMsgShowWidget(int route_id, 907 void RenderViewHost::OnMsgShowWidget(int route_id,
825 const gfx::Rect& initial_pos) { 908 const gfx::Rect& initial_pos) {
826 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate(); 909 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate();
827 if (view) { 910 if (view) {
828 view->ShowCreatedWidget(route_id, initial_pos); 911 if (!is_swapped_out_)
912 view->ShowCreatedWidget(route_id, initial_pos);
829 Send(new ViewMsg_Move_ACK(route_id)); 913 Send(new ViewMsg_Move_ACK(route_id));
830 } 914 }
831 } 915 }
832 916
833 void RenderViewHost::OnMsgShowFullscreenWidget(int route_id) { 917 void RenderViewHost::OnMsgShowFullscreenWidget(int route_id) {
834 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate(); 918 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate();
835 if (view) { 919 if (view) {
836 view->ShowCreatedFullscreenWidget(route_id); 920 if (!is_swapped_out_)
921 view->ShowCreatedFullscreenWidget(route_id);
837 Send(new ViewMsg_Move_ACK(route_id)); 922 Send(new ViewMsg_Move_ACK(route_id));
838 } 923 }
839 } 924 }
840 925
841 void RenderViewHost::OnMsgRunModal(IPC::Message* reply_msg) { 926 void RenderViewHost::OnMsgRunModal(IPC::Message* reply_msg) {
842 DCHECK(!run_modal_reply_msg_); 927 DCHECK(!run_modal_reply_msg_);
843 run_modal_reply_msg_ = reply_msg; 928 run_modal_reply_msg_ = reply_msg;
844 929
845 // TODO(darin): Bug 1107929: Need to inform our delegate to show this view in 930 // TODO(darin): Bug 1107929: Need to inform our delegate to show this view in
846 // an app-modal fashion. 931 // an app-modal fashion.
(...skipping 101 matching lines...) Expand 10 before | Expand all | Expand 10 after
948 } 1033 }
949 delegate_->UpdateTitle(this, page_id, title); 1034 delegate_->UpdateTitle(this, page_id, title);
950 } 1035 }
951 1036
952 void RenderViewHost::OnMsgUpdateEncoding(const std::string& encoding_name) { 1037 void RenderViewHost::OnMsgUpdateEncoding(const std::string& encoding_name) {
953 delegate_->UpdateEncoding(this, encoding_name); 1038 delegate_->UpdateEncoding(this, encoding_name);
954 } 1039 }
955 1040
956 void RenderViewHost::OnMsgUpdateTargetURL(int32 page_id, 1041 void RenderViewHost::OnMsgUpdateTargetURL(int32 page_id,
957 const GURL& url) { 1042 const GURL& url) {
958 delegate_->UpdateTargetURL(page_id, url); 1043 if (!is_swapped_out_)
1044 delegate_->UpdateTargetURL(page_id, url);
959 1045
960 // Send a notification back to the renderer that we are ready to 1046 // Send a notification back to the renderer that we are ready to
961 // receive more target urls. 1047 // receive more target urls.
962 Send(new ViewMsg_UpdateTargetURL_ACK(routing_id())); 1048 Send(new ViewMsg_UpdateTargetURL_ACK(routing_id()));
963 } 1049 }
964 1050
965 void RenderViewHost::OnUpdateInspectorSetting( 1051 void RenderViewHost::OnUpdateInspectorSetting(
966 const std::string& key, const std::string& value) { 1052 const std::string& key, const std::string& value) {
967 delegate_->UpdateInspectorSetting(key, value); 1053 delegate_->UpdateInspectorSetting(key, value);
968 } 1054 }
969 1055
970 void RenderViewHost::OnMsgClose() { 1056 void RenderViewHost::OnMsgClose() {
971 // If the renderer is telling us to close, it has already run the unload 1057 // If the renderer is telling us to close, it has already run the unload
972 // events, and we can take the fast path. 1058 // events, and we can take the fast path.
973 ClosePageIgnoringUnloadEvents(); 1059 ClosePageIgnoringUnloadEvents();
974 } 1060 }
975 1061
976 void RenderViewHost::OnMsgRequestMove(const gfx::Rect& pos) { 1062 void RenderViewHost::OnMsgRequestMove(const gfx::Rect& pos) {
977 delegate_->RequestMove(pos); 1063 if (!is_swapped_out_)
1064 delegate_->RequestMove(pos);
978 Send(new ViewMsg_Move_ACK(routing_id())); 1065 Send(new ViewMsg_Move_ACK(routing_id()));
979 } 1066 }
980 1067
981 void RenderViewHost::OnMsgDidStartLoading() { 1068 void RenderViewHost::OnMsgDidStartLoading() {
982 delegate_->DidStartLoading(); 1069 delegate_->DidStartLoading();
983 } 1070 }
984 1071
985 void RenderViewHost::OnMsgDidStopLoading() { 1072 void RenderViewHost::OnMsgDidStopLoading() {
986 delegate_->DidStopLoading(); 1073 delegate_->DidStopLoading();
987 } 1074 }
(...skipping 100 matching lines...) Expand 10 before | Expand all | Expand 10 after
1088 void RenderViewHost::OnMsgRunJavaScriptMessage( 1175 void RenderViewHost::OnMsgRunJavaScriptMessage(
1089 const std::wstring& message, 1176 const std::wstring& message,
1090 const std::wstring& default_prompt, 1177 const std::wstring& default_prompt,
1091 const GURL& frame_url, 1178 const GURL& frame_url,
1092 const int flags, 1179 const int flags,
1093 IPC::Message* reply_msg) { 1180 IPC::Message* reply_msg) {
1094 // While a JS message dialog is showing, tabs in the same process shouldn't 1181 // While a JS message dialog is showing, tabs in the same process shouldn't
1095 // process input events. 1182 // process input events.
1096 process()->set_ignore_input_events(true); 1183 process()->set_ignore_input_events(true);
1097 StopHangMonitorTimeout(); 1184 StopHangMonitorTimeout();
1098 delegate_->RunJavaScriptMessage(message, default_prompt, frame_url, flags, 1185 delegate_->RunJavaScriptMessage(this, message, default_prompt, frame_url,
1099 reply_msg, 1186 flags, reply_msg,
1100 &are_javascript_messages_suppressed_); 1187 &are_javascript_messages_suppressed_);
1101 } 1188 }
1102 1189
1103 void RenderViewHost::OnMsgRunBeforeUnloadConfirm(const GURL& frame_url, 1190 void RenderViewHost::OnMsgRunBeforeUnloadConfirm(const GURL& frame_url,
1104 const std::wstring& message, 1191 const std::wstring& message,
1105 IPC::Message* reply_msg) { 1192 IPC::Message* reply_msg) {
1106 // While a JS before unload dialog is showing, tabs in the same process 1193 // While a JS before unload dialog is showing, tabs in the same process
1107 // shouldn't process input events. 1194 // shouldn't process input events.
1108 process()->set_ignore_input_events(true); 1195 process()->set_ignore_input_events(true);
1109 StopHangMonitorTimeout(); 1196 StopHangMonitorTimeout();
1110 delegate_->RunBeforeUnloadConfirm(message, reply_msg); 1197 delegate_->RunBeforeUnloadConfirm(this, message, reply_msg);
1111 } 1198 }
1112 1199
1113 void RenderViewHost::MediaPlayerActionAt(const gfx::Point& location, 1200 void RenderViewHost::MediaPlayerActionAt(const gfx::Point& location,
1114 const WebMediaPlayerAction& action) { 1201 const WebMediaPlayerAction& action) {
1115 // TODO(ajwong): Which thread should run this? Does it matter? 1202 // TODO(ajwong): Which thread should run this? Does it matter?
1116 Send(new ViewMsg_MediaPlayerActionAt(routing_id(), location, action)); 1203 Send(new ViewMsg_MediaPlayerActionAt(routing_id(), location, action));
1117 } 1204 }
1118 1205
1119 void RenderViewHost::ContextMenuClosed( 1206 void RenderViewHost::ContextMenuClosed(
1120 const webkit_glue::CustomContextMenuContext& custom_context) { 1207 const webkit_glue::CustomContextMenuContext& custom_context) {
1121 Send(new ViewMsg_ContextMenuClosed(routing_id(), custom_context)); 1208 Send(new ViewMsg_ContextMenuClosed(routing_id(), custom_context));
1122 } 1209 }
1123 1210
1124 void RenderViewHost::OnMsgStartDragging( 1211 void RenderViewHost::OnMsgStartDragging(
1125 const WebDropData& drop_data, 1212 const WebDropData& drop_data,
1126 WebDragOperationsMask drag_operations_mask, 1213 WebDragOperationsMask drag_operations_mask,
1127 const SkBitmap& image, 1214 const SkBitmap& image,
1128 const gfx::Point& image_offset) { 1215 const gfx::Point& image_offset) {
1129 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate(); 1216 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate();
1130 if (view) 1217 if (view)
1131 view->StartDragging(drop_data, drag_operations_mask, image, image_offset); 1218 view->StartDragging(drop_data, drag_operations_mask, image, image_offset);
1132 } 1219 }
1133 1220
1134 void RenderViewHost::OnUpdateDragCursor(WebDragOperation current_op) { 1221 void RenderViewHost::OnUpdateDragCursor(WebDragOperation current_op) {
1135 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate(); 1222 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate();
1136 if (view) 1223 if (view)
1137 view->UpdateDragCursor(current_op); 1224 view->UpdateDragCursor(current_op);
1138 } 1225 }
1139 1226
1140 void RenderViewHost::OnTakeFocus(bool reverse) { 1227 void RenderViewHost::OnTakeFocus(bool reverse) {
1141 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate(); 1228 RenderViewHostDelegate::View* view = delegate_->GetViewDelegate();
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
1178 1265
1179 void RenderViewHost::OnUserGesture() { 1266 void RenderViewHost::OnUserGesture() {
1180 delegate_->OnUserGesture(); 1267 delegate_->OnUserGesture();
1181 } 1268 }
1182 1269
1183 void RenderViewHost::OnMsgShouldCloseACK(bool proceed) { 1270 void RenderViewHost::OnMsgShouldCloseACK(bool proceed) {
1184 StopHangMonitorTimeout(); 1271 StopHangMonitorTimeout();
1185 // If this renderer navigated while the beforeunload request was in flight, we 1272 // If this renderer navigated while the beforeunload request was in flight, we
1186 // may have cleared this state in OnMsgNavigate, in which case we can ignore 1273 // may have cleared this state in OnMsgNavigate, in which case we can ignore
1187 // this message. 1274 // this message.
1188 if (!is_waiting_for_beforeunload_ack_) 1275 if (!is_waiting_for_beforeunload_ack_ || is_swapped_out_)
1189 return; 1276 return;
1190 1277
1191 is_waiting_for_beforeunload_ack_ = false; 1278 is_waiting_for_beforeunload_ack_ = false;
1192 1279
1193 RenderViewHostDelegate::RendererManagement* management_delegate = 1280 RenderViewHostDelegate::RendererManagement* management_delegate =
1194 delegate_->GetRendererManagementDelegate(); 1281 delegate_->GetRendererManagementDelegate();
1195 if (management_delegate) { 1282 if (management_delegate) {
1196 management_delegate->ShouldClosePage( 1283 management_delegate->ShouldClosePage(
1197 unload_ack_is_for_cross_site_transition_, proceed); 1284 unload_ack_is_for_cross_site_transition_, proceed);
1198 } 1285 }
1199 1286
1200 // If canceled, notify the delegate to cancel its pending navigation entry. 1287 // If canceled, notify the delegate to cancel its pending navigation entry.
1201 if (!proceed) 1288 if (!proceed)
1202 delegate_->DidCancelLoading(); 1289 delegate_->DidCancelLoading();
1203 } 1290 }
1204 1291
1292 void RenderViewHost::OnMsgClosePageACK() {
1293 ClosePageIgnoringUnloadEvents();
1294 }
1295
1205 void RenderViewHost::WindowMoveOrResizeStarted() { 1296 void RenderViewHost::WindowMoveOrResizeStarted() {
1206 Send(new ViewMsg_MoveOrResizeStarted(routing_id())); 1297 Send(new ViewMsg_MoveOrResizeStarted(routing_id()));
1207 } 1298 }
1208 1299
1209 void RenderViewHost::NotifyRendererUnresponsive() { 1300 void RenderViewHost::NotifyRendererUnresponsive() {
1210 delegate_->RendererUnresponsive( 1301 delegate_->RendererUnresponsive(
1211 this, is_waiting_for_beforeunload_ack_ || is_waiting_for_unload_ack_); 1302 this, is_waiting_for_beforeunload_ack_ || is_waiting_for_unload_ack_);
1212 } 1303 }
1213 1304
1214 void RenderViewHost::NotifyRendererResponsive() { 1305 void RenderViewHost::NotifyRendererResponsive() {
(...skipping 122 matching lines...) Expand 10 before | Expand all | Expand 10 after
1337 // If this renderer is not permitted to request this URL, we invalidate the 1428 // If this renderer is not permitted to request this URL, we invalidate the
1338 // URL. This prevents us from storing the blocked URL and becoming confused 1429 // URL. This prevents us from storing the blocked URL and becoming confused
1339 // later. 1430 // later.
1340 VLOG(1) << "Blocked URL " << url->spec(); 1431 VLOG(1) << "Blocked URL " << url->spec();
1341 *url = GURL(); 1432 *url = GURL();
1342 } 1433 }
1343 } 1434 }
1344 1435
1345 void RenderViewHost::OnAccessibilityNotifications( 1436 void RenderViewHost::OnAccessibilityNotifications(
1346 const std::vector<ViewHostMsg_AccessibilityNotification_Params>& params) { 1437 const std::vector<ViewHostMsg_AccessibilityNotification_Params>& params) {
1347 if (view()) 1438 if (view() && !is_swapped_out_)
1348 view()->OnAccessibilityNotifications(params); 1439 view()->OnAccessibilityNotifications(params);
1349 1440
1350 if (!params.empty()) { 1441 if (!params.empty()) {
1351 for (unsigned i = 0; i < params.size(); i++) { 1442 for (unsigned i = 0; i < params.size(); i++) {
1352 const ViewHostMsg_AccessibilityNotification_Params& param = params[i]; 1443 const ViewHostMsg_AccessibilityNotification_Params& param = params[i];
1353 1444
1354 if (param.notification_type == 1445 if (param.notification_type ==
1355 ViewHostMsg_AccessibilityNotification_Type:: 1446 ViewHostMsg_AccessibilityNotification_Type::
1356 NOTIFICATION_TYPE_LOAD_COMPLETE) { 1447 NOTIFICATION_TYPE_LOAD_COMPLETE) {
1357 // TODO(ctguil): Remove when mac processes OnAccessibilityNotifications. 1448 // TODO(ctguil): Remove when mac processes OnAccessibilityNotifications.
(...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after
1454 LOG(DFATAL) << "Invalid checked state " << checked_state; 1545 LOG(DFATAL) << "Invalid checked state " << checked_state;
1455 return; 1546 return;
1456 } 1547 }
1457 1548
1458 CommandState state; 1549 CommandState state;
1459 state.is_enabled = is_enabled; 1550 state.is_enabled = is_enabled;
1460 state.checked_state = 1551 state.checked_state =
1461 static_cast<RenderViewCommandCheckedState>(checked_state); 1552 static_cast<RenderViewCommandCheckedState>(checked_state);
1462 command_states_[static_cast<RenderViewCommand>(command)] = state; 1553 command_states_[static_cast<RenderViewCommand>(command)] = state;
1463 } 1554 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698