Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/browser_plugin/browser_plugin_guest.h" | 5 #include "content/browser/browser_plugin/browser_plugin_guest.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
| 10 #include "base/pickle.h" | 10 #include "base/pickle.h" |
| (...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 65 private: | 65 private: |
| 66 BrowserPluginGuest* browser_plugin_guest_; | 66 BrowserPluginGuest* browser_plugin_guest_; |
| 67 | 67 |
| 68 DISALLOW_COPY_AND_ASSIGN(EmbedderVisibilityObserver); | 68 DISALLOW_COPY_AND_ASSIGN(EmbedderVisibilityObserver); |
| 69 }; | 69 }; |
| 70 | 70 |
| 71 BrowserPluginGuest::BrowserPluginGuest(bool has_render_view, | 71 BrowserPluginGuest::BrowserPluginGuest(bool has_render_view, |
| 72 WebContentsImpl* web_contents, | 72 WebContentsImpl* web_contents, |
| 73 BrowserPluginGuestDelegate* delegate) | 73 BrowserPluginGuestDelegate* delegate) |
| 74 : WebContentsObserver(web_contents), | 74 : WebContentsObserver(web_contents), |
| 75 owner_web_contents_(NULL), | 75 owner_web_contents_(nullptr), |
| 76 attached_(false), | 76 attached_(false), |
| 77 browser_plugin_instance_id_(browser_plugin::kInstanceIDNone), | 77 browser_plugin_instance_id_(browser_plugin::kInstanceIDNone), |
| 78 guest_device_scale_factor_(1.0f), | 78 guest_device_scale_factor_(1.0f), |
| 79 focused_(false), | 79 focused_(false), |
| 80 mouse_locked_(false), | 80 mouse_locked_(false), |
| 81 pending_lock_request_(false), | 81 pending_lock_request_(false), |
| 82 guest_visible_(false), | 82 guest_visible_(false), |
| 83 embedder_visible_(true), | 83 embedder_visible_(true), |
| 84 is_full_page_plugin_(false), | 84 is_full_page_plugin_(false), |
| 85 has_render_view_(has_render_view), | 85 has_render_view_(has_render_view), |
| 86 is_in_destruction_(false), | 86 is_in_destruction_(false), |
| 87 initialized_(false), | |
| 87 last_text_input_type_(ui::TEXT_INPUT_TYPE_NONE), | 88 last_text_input_type_(ui::TEXT_INPUT_TYPE_NONE), |
| 88 last_input_mode_(ui::TEXT_INPUT_MODE_DEFAULT), | 89 last_input_mode_(ui::TEXT_INPUT_MODE_DEFAULT), |
| 89 last_input_flags_(0), | 90 last_input_flags_(0), |
| 90 last_can_compose_inline_(true), | 91 last_can_compose_inline_(true), |
| 91 guest_proxy_routing_id_(MSG_ROUTING_NONE), | 92 guest_proxy_routing_id_(MSG_ROUTING_NONE), |
| 92 delegate_(delegate), | 93 delegate_(delegate), |
| 93 weak_ptr_factory_(this) { | 94 weak_ptr_factory_(this) { |
| 94 DCHECK(web_contents); | 95 DCHECK(web_contents); |
| 95 DCHECK(delegate); | 96 DCHECK(delegate); |
| 96 RecordAction(base::UserMetricsAction("BrowserPlugin.Guest.Create")); | 97 RecordAction(base::UserMetricsAction("BrowserPlugin.Guest.Create")); |
| 97 web_contents->SetBrowserPluginGuest(this); | 98 web_contents->SetBrowserPluginGuest(this); |
| 98 delegate->RegisterDestructionCallback( | 99 delegate->RegisterDestructionCallback( |
| 99 base::Bind(&BrowserPluginGuest::WillDestroy, AsWeakPtr())); | 100 base::Bind(&BrowserPluginGuest::WillDestroy, AsWeakPtr())); |
| 100 } | 101 } |
| 101 | 102 |
| 103 void BrowserPluginGuest::Init() { | |
| 104 if (initialized_) | |
| 105 return; | |
| 106 initialized_ = true; | |
| 107 | |
| 108 if (!delegate_->CanRunInDetachedState()) | |
|
lazyboy
2014/12/04 16:51:13
Add a todo saying we should guard this with WTFram
Fady Samuel
2014/12/04 20:54:44
Done.
| |
| 109 return; | |
| 110 | |
| 111 WebContentsImpl* owner_web_contents = static_cast<WebContentsImpl*>( | |
| 112 delegate_->GetOwnerWebContents()); | |
| 113 InitInternal(BrowserPluginHostMsg_Attach_Params(), owner_web_contents); | |
| 114 } | |
| 115 | |
| 102 void BrowserPluginGuest::WillDestroy() { | 116 void BrowserPluginGuest::WillDestroy() { |
| 103 is_in_destruction_ = true; | 117 is_in_destruction_ = true; |
| 104 owner_web_contents_ = NULL; | 118 owner_web_contents_ = NULL; |
| 105 attached_ = false; | 119 attached_ = false; |
| 106 } | 120 } |
| 107 | 121 |
| 108 base::WeakPtr<BrowserPluginGuest> BrowserPluginGuest::AsWeakPtr() { | 122 base::WeakPtr<BrowserPluginGuest> BrowserPluginGuest::AsWeakPtr() { |
| 109 return weak_ptr_factory_.GetWeakPtr(); | 123 return weak_ptr_factory_.GetWeakPtr(); |
| 110 } | 124 } |
| 111 | 125 |
| (...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 186 OnSetEditCommandsForNextKeyEvent) | 200 OnSetEditCommandsForNextKeyEvent) |
| 187 IPC_MESSAGE_HANDLER(BrowserPluginHostMsg_SetFocus, OnSetFocus) | 201 IPC_MESSAGE_HANDLER(BrowserPluginHostMsg_SetFocus, OnSetFocus) |
| 188 IPC_MESSAGE_HANDLER(BrowserPluginHostMsg_SetVisibility, OnSetVisibility) | 202 IPC_MESSAGE_HANDLER(BrowserPluginHostMsg_SetVisibility, OnSetVisibility) |
| 189 IPC_MESSAGE_HANDLER(BrowserPluginHostMsg_UnlockMouse_ACK, OnUnlockMouseAck) | 203 IPC_MESSAGE_HANDLER(BrowserPluginHostMsg_UnlockMouse_ACK, OnUnlockMouseAck) |
| 190 IPC_MESSAGE_HANDLER(BrowserPluginHostMsg_UpdateGeometry, OnUpdateGeometry) | 204 IPC_MESSAGE_HANDLER(BrowserPluginHostMsg_UpdateGeometry, OnUpdateGeometry) |
| 191 IPC_MESSAGE_UNHANDLED(handled = false) | 205 IPC_MESSAGE_UNHANDLED(handled = false) |
| 192 IPC_END_MESSAGE_MAP() | 206 IPC_END_MESSAGE_MAP() |
| 193 return handled; | 207 return handled; |
| 194 } | 208 } |
| 195 | 209 |
| 196 void BrowserPluginGuest::Initialize( | 210 void BrowserPluginGuest::InitInternal( |
| 197 int browser_plugin_instance_id, | |
| 198 const BrowserPluginHostMsg_Attach_Params& params, | 211 const BrowserPluginHostMsg_Attach_Params& params, |
| 199 WebContentsImpl* embedder_web_contents) { | 212 WebContentsImpl* owner_web_contents) { |
| 200 browser_plugin_instance_id_ = browser_plugin_instance_id; | |
| 201 focused_ = params.focused; | 213 focused_ = params.focused; |
| 214 OnSetFocus(0, focused_); | |
| 215 | |
| 202 guest_visible_ = params.visible; | 216 guest_visible_ = params.visible; |
| 217 UpdateVisibility(); | |
| 218 | |
| 203 is_full_page_plugin_ = params.is_full_page_plugin; | 219 is_full_page_plugin_ = params.is_full_page_plugin; |
| 204 guest_window_rect_ = gfx::Rect(params.origin, | 220 guest_window_rect_ = gfx::Rect(params.origin, |
| 205 params.resize_guest_params.view_size); | 221 params.resize_guest_params.view_size); |
| 206 | 222 |
| 207 WebContentsViewGuest* new_view = | 223 if (owner_web_contents_ != owner_web_contents) { |
| 208 static_cast<WebContentsViewGuest*>(GetWebContents()->GetView()); | 224 WebContentsViewGuest* new_view = |
| 209 if (attached()) | 225 static_cast<WebContentsViewGuest*>(GetWebContents()->GetView()); |
| 210 new_view->OnGuestDetached(owner_web_contents_->GetView()); | 226 if (owner_web_contents_) |
| 227 new_view->OnGuestDetached(owner_web_contents_->GetView()); | |
| 211 | 228 |
| 212 // Once a BrowserPluginGuest has an embedder WebContents, it's considered to | 229 // Once a BrowserPluginGuest has an embedder WebContents, it's considered to |
| 213 // be attached. | 230 // be attached. |
| 214 owner_web_contents_ = embedder_web_contents; | 231 owner_web_contents_ = owner_web_contents; |
| 215 new_view->OnGuestAttached(owner_web_contents_->GetView()); | 232 new_view->OnGuestAttached(owner_web_contents_->GetView()); |
| 233 } | |
| 216 | 234 |
| 217 RendererPreferences* renderer_prefs = | 235 RendererPreferences* renderer_prefs = |
| 218 GetWebContents()->GetMutableRendererPrefs(); | 236 GetWebContents()->GetMutableRendererPrefs(); |
| 219 std::string guest_user_agent_override = renderer_prefs->user_agent_override; | 237 std::string guest_user_agent_override = renderer_prefs->user_agent_override; |
| 220 // Copy renderer preferences (and nothing else) from the embedder's | 238 // Copy renderer preferences (and nothing else) from the embedder's |
| 221 // WebContents to the guest. | 239 // WebContents to the guest. |
| 222 // | 240 // |
| 223 // For GTK and Aura this is necessary to get proper renderer configuration | 241 // For GTK and Aura this is necessary to get proper renderer configuration |
| 224 // values for caret blinking interval, colors related to selection and | 242 // values for caret blinking interval, colors related to selection and |
| 225 // focus. | 243 // focus. |
| 226 *renderer_prefs = *owner_web_contents_->GetMutableRendererPrefs(); | 244 *renderer_prefs = *owner_web_contents_->GetMutableRendererPrefs(); |
| 227 renderer_prefs->user_agent_override = guest_user_agent_override; | 245 renderer_prefs->user_agent_override = guest_user_agent_override; |
| 228 | 246 |
| 229 // We would like the guest to report changes to frame names so that we can | 247 // We would like the guest to report changes to frame names so that we can |
| 230 // update the BrowserPlugin's corresponding 'name' attribute. | 248 // update the BrowserPlugin's corresponding 'name' attribute. |
| 231 // TODO(fsamuel): Remove this once http://crbug.com/169110 is addressed. | 249 // TODO(fsamuel): Remove this once http://crbug.com/169110 is addressed. |
| 232 renderer_prefs->report_frame_name_changes = true; | 250 renderer_prefs->report_frame_name_changes = true; |
| 233 // Navigation is disabled in Chrome Apps. We want to make sure guest-initiated | 251 // Navigation is disabled in Chrome Apps. We want to make sure guest-initiated |
| 234 // navigations still continue to function inside the app. | 252 // navigations still continue to function inside the app. |
| 235 renderer_prefs->browser_handles_all_top_level_requests = false; | 253 renderer_prefs->browser_handles_all_top_level_requests = false; |
| 236 // Disable "client blocked" error page for browser plugin. | 254 // Disable "client blocked" error page for browser plugin. |
| 237 renderer_prefs->disable_client_blocked_error_page = true; | 255 renderer_prefs->disable_client_blocked_error_page = true; |
| 238 | 256 |
| 239 embedder_visibility_observer_.reset(new EmbedderVisibilityObserver(this)); | 257 embedder_visibility_observer_.reset(new EmbedderVisibilityObserver(this)); |
| 240 | 258 |
| 241 OnResizeGuest(browser_plugin_instance_id_, params.resize_guest_params); | 259 // The instance ID does not matter here. |
| 260 OnResizeGuest(browser_plugin::kInstanceIDNone, params.resize_guest_params); | |
| 242 | 261 |
| 243 // TODO(chrishtr): this code is wrong. The navigate_on_drag_drop field will | 262 // TODO(chrishtr): this code is wrong. The navigate_on_drag_drop field will |
| 244 // be reset again the next time preferences are updated. | 263 // be reset again the next time preferences are updated. |
| 245 WebPreferences prefs = | 264 WebPreferences prefs = |
| 246 GetWebContents()->GetRenderViewHost()->GetWebkitPreferences(); | 265 GetWebContents()->GetRenderViewHost()->GetWebkitPreferences(); |
| 247 prefs.navigate_on_drag_drop = false; | 266 prefs.navigate_on_drag_drop = false; |
| 248 GetWebContents()->GetRenderViewHost()->UpdateWebkitPreferences(prefs); | 267 GetWebContents()->GetRenderViewHost()->UpdateWebkitPreferences(prefs); |
| 249 | 268 |
| 250 // Enable input method for guest if it's enabled for the embedder. | 269 // Enable input method for guest if it's enabled for the embedder. |
| 251 if (static_cast<RenderViewHostImpl*>( | 270 if (static_cast<RenderViewHostImpl*>( |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 313 frame->delegated_frame_data->render_pass_list.back(); | 332 frame->delegated_frame_data->render_pass_list.back(); |
| 314 gfx::Size view_size(gfx::ToFlooredSize(gfx::ScaleSize( | 333 gfx::Size view_size(gfx::ToFlooredSize(gfx::ScaleSize( |
| 315 root_pass->output_rect.size(), | 334 root_pass->output_rect.size(), |
| 316 1.0f / frame->metadata.device_scale_factor))); | 335 1.0f / frame->metadata.device_scale_factor))); |
| 317 | 336 |
| 318 if (last_seen_view_size_ != view_size) { | 337 if (last_seen_view_size_ != view_size) { |
| 319 delegate_->GuestSizeChanged(last_seen_view_size_, view_size); | 338 delegate_->GuestSizeChanged(last_seen_view_size_, view_size); |
| 320 last_seen_view_size_ = view_size; | 339 last_seen_view_size_ = view_size; |
| 321 } | 340 } |
| 322 | 341 |
| 323 FrameMsg_CompositorFrameSwapped_Params guest_params; | 342 pending_frame_.reset(new FrameMsg_CompositorFrameSwapped_Params()); |
| 324 frame->AssignTo(&guest_params.frame); | 343 frame->AssignTo(&pending_frame_->frame); |
| 325 guest_params.output_surface_id = output_surface_id; | 344 pending_frame_->output_surface_id = output_surface_id; |
| 326 guest_params.producing_route_id = host_routing_id; | 345 pending_frame_->producing_route_id = host_routing_id; |
| 327 guest_params.producing_host_id = host_process_id; | 346 pending_frame_->producing_host_id = host_process_id; |
| 347 | |
| 328 SendMessageToEmbedder( | 348 SendMessageToEmbedder( |
| 329 new BrowserPluginMsg_CompositorFrameSwapped( | 349 new BrowserPluginMsg_CompositorFrameSwapped( |
| 330 browser_plugin_instance_id(), guest_params)); | 350 browser_plugin_instance_id(), *pending_frame_)); |
| 331 } | 351 } |
| 332 | 352 |
| 333 void BrowserPluginGuest::SetContentsOpaque(bool opaque) { | 353 void BrowserPluginGuest::SetContentsOpaque(bool opaque) { |
| 334 SendMessageToEmbedder( | 354 SendMessageToEmbedder( |
| 335 new BrowserPluginMsg_SetContentsOpaque( | 355 new BrowserPluginMsg_SetContentsOpaque( |
| 336 browser_plugin_instance_id(), opaque)); | 356 browser_plugin_instance_id(), opaque)); |
| 337 } | 357 } |
| 338 | 358 |
| 339 bool BrowserPluginGuest::Find(int request_id, | 359 bool BrowserPluginGuest::Find(int request_id, |
| 340 const base::string16& search_text, | 360 const base::string16& search_text, |
| (...skipping 165 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 506 return handled; | 526 return handled; |
| 507 #else | 527 #else |
| 508 return false; | 528 return false; |
| 509 #endif | 529 #endif |
| 510 } | 530 } |
| 511 | 531 |
| 512 void BrowserPluginGuest::Attach( | 532 void BrowserPluginGuest::Attach( |
| 513 int browser_plugin_instance_id, | 533 int browser_plugin_instance_id, |
| 514 WebContentsImpl* embedder_web_contents, | 534 WebContentsImpl* embedder_web_contents, |
| 515 const BrowserPluginHostMsg_Attach_Params& params) { | 535 const BrowserPluginHostMsg_Attach_Params& params) { |
| 536 browser_plugin_instance_id_ = browser_plugin_instance_id; | |
| 537 if (pending_frame_) { | |
|
lazyboy
2014/12/04 16:51:12
Add a not when this can happen.
Fady Samuel
2014/12/04 20:54:44
Done.
| |
| 538 cc::CompositorFrameAck ack; | |
| 539 RenderWidgetHostImpl::SendSwapCompositorFrameAck( | |
| 540 pending_frame_->producing_route_id, | |
| 541 pending_frame_->output_surface_id, | |
| 542 pending_frame_->producing_host_id, | |
| 543 ack); | |
| 544 pending_frame_.reset(); | |
| 545 } | |
| 516 delegate_->WillAttach(embedder_web_contents, browser_plugin_instance_id, | 546 delegate_->WillAttach(embedder_web_contents, browser_plugin_instance_id, |
| 517 params.is_full_page_plugin); | 547 params.is_full_page_plugin); |
| 518 | 548 |
| 519 // If a RenderView has already been created for this new window, then we need | 549 // If a RenderView has already been created for this new window, then we need |
| 520 // to initialize the browser-side state now so that the RenderFrameHostManager | 550 // to initialize the browser-side state now so that the RenderFrameHostManager |
| 521 // does not create a new RenderView on navigation. | 551 // does not create a new RenderView on navigation. |
| 522 if (has_render_view_) { | 552 if (has_render_view_) { |
| 523 // This will trigger a callback to RenderViewReady after a round-trip IPC. | 553 // This will trigger a callback to RenderViewReady after a round-trip IPC. |
| 524 static_cast<RenderViewHostImpl*>( | 554 static_cast<RenderViewHostImpl*>( |
| 525 GetWebContents()->GetRenderViewHost())->Init(); | 555 GetWebContents()->GetRenderViewHost())->Init(); |
| 526 WebContentsViewGuest* web_contents_view = | 556 WebContentsViewGuest* web_contents_view = |
| 527 static_cast<WebContentsViewGuest*>(GetWebContents()->GetView()); | 557 static_cast<WebContentsViewGuest*>(GetWebContents()->GetView()); |
| 528 if (!web_contents()->GetRenderViewHost()->GetView()) { | 558 if (!web_contents()->GetRenderViewHost()->GetView()) { |
| 529 web_contents_view->CreateViewForWidget( | 559 web_contents_view->CreateViewForWidget( |
| 530 web_contents()->GetRenderViewHost(), true); | 560 web_contents()->GetRenderViewHost(), true); |
| 531 } | 561 } |
| 532 } | 562 } |
| 533 | 563 |
| 534 Initialize(browser_plugin_instance_id, params, embedder_web_contents); | 564 InitInternal(params, embedder_web_contents); |
| 535 | 565 |
| 536 attached_ = true; | 566 attached_ = true; |
| 537 SendQueuedMessages(); | 567 SendQueuedMessages(); |
| 538 | 568 |
| 539 // Create a swapped out RenderView for the guest in the embedder render | 569 // Create a swapped out RenderView for the guest in the embedder render |
| 540 // process, so that the embedder can access the guest's window object. | 570 // process, so that the embedder can access the guest's window object. |
| 541 // On reattachment, we can reuse the same swapped out RenderView because | 571 // On reattachment, we can reuse the same swapped out RenderView because |
| 542 // the embedder process will always be the same even if the embedder | 572 // the embedder process will always be the same even if the embedder |
| 543 // WebContents changes. | 573 // WebContents changes. |
| 544 if (guest_proxy_routing_id_ == MSG_ROUTING_NONE) { | 574 if (guest_proxy_routing_id_ == MSG_ROUTING_NONE) { |
| 545 guest_proxy_routing_id_ = | 575 guest_proxy_routing_id_ = |
| 546 GetWebContents()->CreateSwappedOutRenderView( | 576 GetWebContents()->CreateSwappedOutRenderView( |
| 547 owner_web_contents_->GetSiteInstance()); | 577 owner_web_contents_->GetSiteInstance()); |
| 548 } | 578 } |
| 549 | 579 |
| 550 delegate_->DidAttach(guest_proxy_routing_id_); | 580 delegate_->DidAttach(guest_proxy_routing_id_); |
| 551 | 581 |
| 552 has_render_view_ = true; | 582 has_render_view_ = true; |
| 553 | 583 |
| 554 RecordAction(base::UserMetricsAction("BrowserPlugin.Guest.Attached")); | 584 RecordAction(base::UserMetricsAction("BrowserPlugin.Guest.Attached")); |
| 555 } | 585 } |
| 556 | 586 |
| 557 void BrowserPluginGuest::OnCompositorFrameSwappedACK( | 587 void BrowserPluginGuest::OnCompositorFrameSwappedACK( |
| 558 int browser_plugin_instance_id, | 588 int browser_plugin_instance_id, |
| 559 const FrameHostMsg_CompositorFrameSwappedACK_Params& params) { | 589 const FrameHostMsg_CompositorFrameSwappedACK_Params& params) { |
| 560 RenderWidgetHostImpl::SendSwapCompositorFrameAck(params.producing_route_id, | 590 RenderWidgetHostImpl::SendSwapCompositorFrameAck(params.producing_route_id, |
| 561 params.output_surface_id, | 591 params.output_surface_id, |
| 562 params.producing_host_id, | 592 params.producing_host_id, |
| 563 params.ack); | 593 params.ack); |
| 594 pending_frame_.reset(); | |
| 564 } | 595 } |
| 565 | 596 |
| 566 void BrowserPluginGuest::OnDetach(int browser_plugin_instance_id) { | 597 void BrowserPluginGuest::OnDetach(int browser_plugin_instance_id) { |
| 567 if (!attached()) | 598 if (!attached()) |
| 568 return; | 599 return; |
| 569 | 600 |
| 570 // This tells BrowserPluginGuest to queue up all IPCs to BrowserPlugin until | 601 // This tells BrowserPluginGuest to queue up all IPCs to BrowserPlugin until |
| 571 // it's attached again. | 602 // it's attached again. |
| 572 attached_ = false; | 603 attached_ = false; |
| 573 | 604 |
| (...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 668 | 699 |
| 669 void BrowserPluginGuest::OnLockMouseAck(int browser_plugin_instance_id, | 700 void BrowserPluginGuest::OnLockMouseAck(int browser_plugin_instance_id, |
| 670 bool succeeded) { | 701 bool succeeded) { |
| 671 Send(new ViewMsg_LockMouse_ACK(routing_id(), succeeded)); | 702 Send(new ViewMsg_LockMouse_ACK(routing_id(), succeeded)); |
| 672 pending_lock_request_ = false; | 703 pending_lock_request_ = false; |
| 673 if (succeeded) | 704 if (succeeded) |
| 674 mouse_locked_ = true; | 705 mouse_locked_ = true; |
| 675 } | 706 } |
| 676 | 707 |
| 677 void BrowserPluginGuest::OnResizeGuest( | 708 void BrowserPluginGuest::OnResizeGuest( |
| 678 int browser_plugin_instance_id, | 709 int /* unused */, |
|
lazyboy
2014/12/04 16:51:13
nit: This is not consistent in this file, revert t
Fady Samuel
2014/12/04 20:54:44
Done.
| |
| 679 const BrowserPluginHostMsg_ResizeGuest_Params& params) { | 710 const BrowserPluginHostMsg_ResizeGuest_Params& params) { |
| 680 // If we are setting the size for the first time before navigating then | 711 // If we are setting the size for the first time before navigating then |
| 681 // BrowserPluginGuest does not yet have a RenderViewHost. | 712 // BrowserPluginGuest does not yet have a RenderViewHost. |
| 682 if (guest_device_scale_factor_ != params.scale_factor && | 713 if (guest_device_scale_factor_ != params.scale_factor && |
| 683 GetWebContents()->GetRenderViewHost()) { | 714 GetWebContents()->GetRenderViewHost()) { |
| 684 RenderWidgetHostImpl* render_widget_host = | 715 RenderWidgetHostImpl* render_widget_host = |
| 685 RenderWidgetHostImpl::From(GetWebContents()->GetRenderViewHost()); | 716 RenderWidgetHostImpl::From(GetWebContents()->GetRenderViewHost()); |
| 686 guest_device_scale_factor_ = params.scale_factor; | 717 guest_device_scale_factor_ = params.scale_factor; |
| 687 render_widget_host->NotifyScreenInfoChanged(); | 718 render_widget_host->NotifyScreenInfoChanged(); |
| 688 } | 719 } |
| (...skipping 117 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 806 void BrowserPluginGuest::OnImeCompositionRangeChanged( | 837 void BrowserPluginGuest::OnImeCompositionRangeChanged( |
| 807 const gfx::Range& range, | 838 const gfx::Range& range, |
| 808 const std::vector<gfx::Rect>& character_bounds) { | 839 const std::vector<gfx::Rect>& character_bounds) { |
| 809 static_cast<RenderWidgetHostViewBase*>( | 840 static_cast<RenderWidgetHostViewBase*>( |
| 810 web_contents()->GetRenderWidgetHostView())->ImeCompositionRangeChanged( | 841 web_contents()->GetRenderWidgetHostView())->ImeCompositionRangeChanged( |
| 811 range, character_bounds); | 842 range, character_bounds); |
| 812 } | 843 } |
| 813 #endif | 844 #endif |
| 814 | 845 |
| 815 } // namespace content | 846 } // namespace content |
| OLD | NEW |