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/renderer_host/render_view_host_impl.h" | 5 #include "content/browser/renderer_host/render_view_host_impl.h" |
6 | 6 |
7 #include <set> | 7 #include <set> |
8 #include <string> | 8 #include <string> |
9 #include <utility> | 9 #include <utility> |
10 #include <vector> | 10 #include <vector> |
(...skipping 271 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
282 | 282 |
283 // Ensure the RenderView starts with a next_page_id larger than any existing | 283 // Ensure the RenderView starts with a next_page_id larger than any existing |
284 // page ID it might be asked to render. | 284 // page ID it might be asked to render. |
285 int32 next_page_id = 1; | 285 int32 next_page_id = 1; |
286 if (max_page_id > -1) | 286 if (max_page_id > -1) |
287 next_page_id = max_page_id + 1; | 287 next_page_id = max_page_id + 1; |
288 | 288 |
289 ViewMsg_New_Params params; | 289 ViewMsg_New_Params params; |
290 params.renderer_preferences = | 290 params.renderer_preferences = |
291 delegate_->GetRendererPrefs(GetProcess()->GetBrowserContext()); | 291 delegate_->GetRendererPrefs(GetProcess()->GetBrowserContext()); |
292 params.web_preferences = delegate_->GetWebkitPrefs(); | 292 params.web_preferences = GetWebkitPreferences(); |
293 params.view_id = GetRoutingID(); | 293 params.view_id = GetRoutingID(); |
294 params.main_frame_routing_id = main_frame_routing_id_; | 294 params.main_frame_routing_id = main_frame_routing_id_; |
295 params.surface_id = surface_id(); | 295 params.surface_id = surface_id(); |
296 params.session_storage_namespace_id = | 296 params.session_storage_namespace_id = |
297 delegate_->GetSessionStorageNamespace(instance_)->id(); | 297 delegate_->GetSessionStorageNamespace(instance_)->id(); |
298 params.frame_name = frame_name; | 298 params.frame_name = frame_name; |
299 // Ensure the RenderView sets its opener correctly. | 299 // Ensure the RenderView sets its opener correctly. |
300 params.opener_route_id = opener_route_id; | 300 params.opener_route_id = opener_route_id; |
301 params.swapped_out = !IsRVHStateActive(rvh_state_); | 301 params.swapped_out = !IsRVHStateActive(rvh_state_); |
302 params.proxy_routing_id = proxy_route_id; | 302 params.proxy_routing_id = proxy_route_id; |
(...skipping 19 matching lines...) Expand all Loading... |
322 bool RenderViewHostImpl::IsRenderViewLive() const { | 322 bool RenderViewHostImpl::IsRenderViewLive() const { |
323 return GetProcess()->HasConnection() && renderer_initialized_; | 323 return GetProcess()->HasConnection() && renderer_initialized_; |
324 } | 324 } |
325 | 325 |
326 void RenderViewHostImpl::SyncRendererPrefs() { | 326 void RenderViewHostImpl::SyncRendererPrefs() { |
327 Send(new ViewMsg_SetRendererPrefs(GetRoutingID(), | 327 Send(new ViewMsg_SetRendererPrefs(GetRoutingID(), |
328 delegate_->GetRendererPrefs( | 328 delegate_->GetRendererPrefs( |
329 GetProcess()->GetBrowserContext()))); | 329 GetProcess()->GetBrowserContext()))); |
330 } | 330 } |
331 | 331 |
332 WebPreferences RenderViewHostImpl::GetWebkitPrefs(const GURL& url) { | 332 WebPreferences RenderViewHostImpl::ComputeWebkitPrefs(const GURL& url) { |
333 TRACE_EVENT0("browser", "RenderViewHostImpl::GetWebkitPrefs"); | 333 TRACE_EVENT0("browser", "RenderViewHostImpl::GetWebkitPrefs"); |
334 WebPreferences prefs; | 334 WebPreferences prefs; |
335 | 335 |
336 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); | 336 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); |
337 | 337 |
338 prefs.javascript_enabled = | 338 prefs.javascript_enabled = |
339 !command_line.HasSwitch(switches::kDisableJavaScript); | 339 !command_line.HasSwitch(switches::kDisableJavaScript); |
340 prefs.web_security_enabled = | 340 prefs.web_security_enabled = |
341 !command_line.HasSwitch(switches::kDisableWebSecurity); | 341 !command_line.HasSwitch(switches::kDisableWebSecurity); |
342 prefs.plugins_enabled = | 342 prefs.plugins_enabled = |
(...skipping 1070 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1413 view_->OnTextSurroundingSelectionResponse(content, start_offset, end_offset); | 1413 view_->OnTextSurroundingSelectionResponse(content, start_offset, end_offset); |
1414 } | 1414 } |
1415 | 1415 |
1416 void RenderViewHostImpl::ExitFullscreen() { | 1416 void RenderViewHostImpl::ExitFullscreen() { |
1417 RejectMouseLockOrUnlockIfNecessary(); | 1417 RejectMouseLockOrUnlockIfNecessary(); |
1418 // Notify delegate_ and renderer of fullscreen state change. | 1418 // Notify delegate_ and renderer of fullscreen state change. |
1419 OnToggleFullscreen(false); | 1419 OnToggleFullscreen(false); |
1420 } | 1420 } |
1421 | 1421 |
1422 WebPreferences RenderViewHostImpl::GetWebkitPreferences() { | 1422 WebPreferences RenderViewHostImpl::GetWebkitPreferences() { |
1423 return delegate_->GetWebkitPrefs(); | 1423 if (!web_preferences_.get()) { |
| 1424 OnWebkitPreferencesChanged(); |
| 1425 } |
| 1426 return *web_preferences_; |
1424 } | 1427 } |
1425 | 1428 |
1426 void RenderViewHostImpl::DisownOpener() { | 1429 void RenderViewHostImpl::DisownOpener() { |
1427 // This should only be called when swapped out. | 1430 // This should only be called when swapped out. |
1428 DCHECK(IsSwappedOut()); | 1431 DCHECK(IsSwappedOut()); |
1429 | 1432 |
1430 Send(new ViewMsg_DisownOpener(GetRoutingID())); | 1433 Send(new ViewMsg_DisownOpener(GetRoutingID())); |
1431 } | 1434 } |
1432 | 1435 |
1433 void RenderViewHostImpl::UpdateWebkitPreferences(const WebPreferences& prefs) { | 1436 void RenderViewHostImpl::UpdateWebkitPreferences(const WebPreferences& prefs) { |
| 1437 web_preferences_.reset(new WebPreferences(prefs)); |
1434 Send(new ViewMsg_UpdateWebPreferences(GetRoutingID(), prefs)); | 1438 Send(new ViewMsg_UpdateWebPreferences(GetRoutingID(), prefs)); |
1435 } | 1439 } |
1436 | 1440 |
| 1441 void RenderViewHostImpl::OnWebkitPreferencesChanged() { |
| 1442 UpdateWebkitPreferences(delegate_->ComputeWebkitPrefs()); |
| 1443 } |
| 1444 |
1437 void RenderViewHostImpl::GetAudioOutputControllers( | 1445 void RenderViewHostImpl::GetAudioOutputControllers( |
1438 const GetAudioOutputControllersCallback& callback) const { | 1446 const GetAudioOutputControllersCallback& callback) const { |
1439 AudioRendererHost* audio_host = | 1447 AudioRendererHost* audio_host = |
1440 static_cast<RenderProcessHostImpl*>(GetProcess())->audio_renderer_host(); | 1448 static_cast<RenderProcessHostImpl*>(GetProcess())->audio_renderer_host(); |
1441 audio_host->GetOutputControllers(GetRoutingID(), callback); | 1449 audio_host->GetOutputControllers(GetRoutingID(), callback); |
1442 } | 1450 } |
1443 | 1451 |
1444 void RenderViewHostImpl::ClearFocusedElement() { | 1452 void RenderViewHostImpl::ClearFocusedElement() { |
1445 is_focused_element_editable_ = false; | 1453 is_focused_element_editable_ = false; |
1446 Send(new ViewMsg_ClearFocusedElement(GetRoutingID())); | 1454 Send(new ViewMsg_ClearFocusedElement(GetRoutingID())); |
(...skipping 135 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1582 FrameTree* frame_tree = delegate_->GetFrameTree(); | 1590 FrameTree* frame_tree = delegate_->GetFrameTree(); |
1583 | 1591 |
1584 frame_tree->ResetForMainFrameSwap(); | 1592 frame_tree->ResetForMainFrameSwap(); |
1585 } | 1593 } |
1586 | 1594 |
1587 void RenderViewHostImpl::SelectWordAroundCaret() { | 1595 void RenderViewHostImpl::SelectWordAroundCaret() { |
1588 Send(new ViewMsg_SelectWordAroundCaret(GetRoutingID())); | 1596 Send(new ViewMsg_SelectWordAroundCaret(GetRoutingID())); |
1589 } | 1597 } |
1590 | 1598 |
1591 } // namespace content | 1599 } // namespace content |
OLD | NEW |