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

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

Issue 273423004: Migrate accessibility from RenderView to RenderFrame. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 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) 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>
11 11
12 #include "base/callback.h" 12 #include "base/callback.h"
13 #include "base/command_line.h" 13 #include "base/command_line.h"
14 #include "base/debug/trace_event.h" 14 #include "base/debug/trace_event.h"
15 #include "base/i18n/rtl.h" 15 #include "base/i18n/rtl.h"
16 #include "base/json/json_reader.h" 16 #include "base/json/json_reader.h"
17 #include "base/message_loop/message_loop.h" 17 #include "base/message_loop/message_loop.h"
18 #include "base/metrics/histogram.h" 18 #include "base/metrics/histogram.h"
19 #include "base/stl_util.h" 19 #include "base/stl_util.h"
20 #include "base/strings/string_util.h" 20 #include "base/strings/string_util.h"
21 #include "base/strings/utf_string_conversions.h" 21 #include "base/strings/utf_string_conversions.h"
22 #include "base/sys_info.h" 22 #include "base/sys_info.h"
23 #include "base/time/time.h" 23 #include "base/time/time.h"
24 #include "base/values.h" 24 #include "base/values.h"
25 #include "cc/base/switches.h" 25 #include "cc/base/switches.h"
26 #include "content/browser/accessibility/browser_accessibility_manager.h"
27 #include "content/browser/child_process_security_policy_impl.h" 26 #include "content/browser/child_process_security_policy_impl.h"
28 #include "content/browser/cross_site_request_manager.h" 27 #include "content/browser/cross_site_request_manager.h"
29 #include "content/browser/dom_storage/session_storage_namespace_impl.h" 28 #include "content/browser/dom_storage/session_storage_namespace_impl.h"
30 #include "content/browser/frame_host/frame_tree.h" 29 #include "content/browser/frame_host/frame_tree.h"
31 #include "content/browser/gpu/compositor_util.h" 30 #include "content/browser/gpu/compositor_util.h"
32 #include "content/browser/gpu/gpu_data_manager_impl.h" 31 #include "content/browser/gpu/gpu_data_manager_impl.h"
33 #include "content/browser/gpu/gpu_process_host.h" 32 #include "content/browser/gpu/gpu_process_host.h"
34 #include "content/browser/gpu/gpu_surface_tracker.h" 33 #include "content/browser/gpu/gpu_surface_tracker.h"
35 #include "content/browser/host_zoom_map_impl.h" 34 #include "content/browser/host_zoom_map_impl.h"
36 #include "content/browser/loader/resource_dispatcher_host_impl.h" 35 #include "content/browser/loader/resource_dispatcher_host_impl.h"
37 #include "content/browser/renderer_host/dip_util.h" 36 #include "content/browser/renderer_host/dip_util.h"
38 #include "content/browser/renderer_host/input/timeout_monitor.h" 37 #include "content/browser/renderer_host/input/timeout_monitor.h"
39 #include "content/browser/renderer_host/media/audio_renderer_host.h" 38 #include "content/browser/renderer_host/media/audio_renderer_host.h"
40 #include "content/browser/renderer_host/render_process_host_impl.h" 39 #include "content/browser/renderer_host/render_process_host_impl.h"
41 #include "content/browser/renderer_host/render_view_host_delegate.h" 40 #include "content/browser/renderer_host/render_view_host_delegate.h"
42 #include "content/browser/renderer_host/render_view_host_delegate_view.h" 41 #include "content/browser/renderer_host/render_view_host_delegate_view.h"
43 #include "content/browser/renderer_host/render_widget_host_view_base.h" 42 #include "content/browser/renderer_host/render_widget_host_view_base.h"
44 #include "content/common/accessibility_messages.h"
45 #include "content/common/browser_plugin/browser_plugin_messages.h" 43 #include "content/common/browser_plugin/browser_plugin_messages.h"
46 #include "content/common/content_switches_internal.h" 44 #include "content/common/content_switches_internal.h"
47 #include "content/common/drag_messages.h" 45 #include "content/common/drag_messages.h"
48 #include "content/common/frame_messages.h" 46 #include "content/common/frame_messages.h"
49 #include "content/common/input_messages.h" 47 #include "content/common/input_messages.h"
50 #include "content/common/inter_process_time_ticks_converter.h" 48 #include "content/common/inter_process_time_ticks_converter.h"
51 #include "content/common/mojo/mojo_service_names.h" 49 #include "content/common/mojo/mojo_service_names.h"
52 #include "content/common/speech_recognition_messages.h" 50 #include "content/common/speech_recognition_messages.h"
53 #include "content/common/swapped_out_messages.h" 51 #include "content/common/swapped_out_messages.h"
54 #include "content/common/view_messages.h" 52 #include "content/common/view_messages.h"
55 #include "content/common/web_ui_setup.mojom.h" 53 #include "content/common/web_ui_setup.mojom.h"
56 #include "content/public/browser/ax_event_notification_details.h"
57 #include "content/public/browser/browser_accessibility_state.h"
58 #include "content/public/browser/browser_context.h" 54 #include "content/public/browser/browser_context.h"
59 #include "content/public/browser/browser_message_filter.h" 55 #include "content/public/browser/browser_message_filter.h"
60 #include "content/public/browser/content_browser_client.h" 56 #include "content/public/browser/content_browser_client.h"
61 #include "content/public/browser/native_web_keyboard_event.h" 57 #include "content/public/browser/native_web_keyboard_event.h"
62 #include "content/public/browser/notification_details.h" 58 #include "content/public/browser/notification_details.h"
63 #include "content/public/browser/notification_service.h" 59 #include "content/public/browser/notification_service.h"
64 #include "content/public/browser/notification_types.h" 60 #include "content/public/browser/notification_types.h"
65 #include "content/public/browser/render_frame_host.h" 61 #include "content/public/browser/render_frame_host.h"
66 #include "content/public/browser/render_widget_host_iterator.h" 62 #include "content/public/browser/render_widget_host_iterator.h"
67 #include "content/public/browser/storage_partition.h" 63 #include "content/public/browser/storage_partition.h"
68 #include "content/public/browser/user_metrics.h" 64 #include "content/public/browser/user_metrics.h"
69 #include "content/public/common/bindings_policy.h" 65 #include "content/public/common/bindings_policy.h"
70 #include "content/public/common/content_constants.h" 66 #include "content/public/common/content_constants.h"
71 #include "content/public/common/content_switches.h" 67 #include "content/public/common/content_switches.h"
72 #include "content/public/common/context_menu_params.h" 68 #include "content/public/common/context_menu_params.h"
73 #include "content/public/common/drop_data.h" 69 #include "content/public/common/drop_data.h"
74 #include "content/public/common/result_codes.h" 70 #include "content/public/common/result_codes.h"
75 #include "content/public/common/url_constants.h" 71 #include "content/public/common/url_constants.h"
76 #include "content/public/common/url_utils.h" 72 #include "content/public/common/url_utils.h"
77 #include "net/base/filename_util.h" 73 #include "net/base/filename_util.h"
78 #include "net/base/net_util.h" 74 #include "net/base/net_util.h"
79 #include "net/base/network_change_notifier.h" 75 #include "net/base/network_change_notifier.h"
80 #include "net/url_request/url_request_context_getter.h" 76 #include "net/url_request/url_request_context_getter.h"
81 #include "third_party/skia/include/core/SkBitmap.h" 77 #include "third_party/skia/include/core/SkBitmap.h"
82 #include "ui/accessibility/ax_tree.h"
83 #include "ui/base/touch/touch_device.h" 78 #include "ui/base/touch/touch_device.h"
84 #include "ui/base/touch/touch_enabled.h" 79 #include "ui/base/touch/touch_enabled.h"
85 #include "ui/base/ui_base_switches.h" 80 #include "ui/base/ui_base_switches.h"
86 #include "ui/gfx/image/image_skia.h" 81 #include "ui/gfx/image/image_skia.h"
87 #include "ui/gfx/native_widget_types.h" 82 #include "ui/gfx/native_widget_types.h"
88 #include "ui/native_theme/native_theme_switches.h" 83 #include "ui/native_theme/native_theme_switches.h"
89 #include "ui/shell_dialogs/selected_file_info.h" 84 #include "ui/shell_dialogs/selected_file_info.h"
90 #include "webkit/browser/fileapi/isolated_context.h" 85 #include "webkit/browser/fileapi/isolated_context.h"
91 86
92 #if defined(OS_MACOSX) 87 #if defined(OS_MACOSX)
(...skipping 219 matching lines...) Expand 10 before | Expand all | Expand 10 after
312 delegate_->GetSessionStorageNamespace(instance_)->id(); 307 delegate_->GetSessionStorageNamespace(instance_)->id();
313 params.frame_name = frame_name; 308 params.frame_name = frame_name;
314 // Ensure the RenderView sets its opener correctly. 309 // Ensure the RenderView sets its opener correctly.
315 params.opener_route_id = opener_route_id; 310 params.opener_route_id = opener_route_id;
316 params.swapped_out = !IsRVHStateActive(rvh_state_); 311 params.swapped_out = !IsRVHStateActive(rvh_state_);
317 params.hidden = is_hidden(); 312 params.hidden = is_hidden();
318 params.never_visible = delegate_->IsNeverVisible(); 313 params.never_visible = delegate_->IsNeverVisible();
319 params.window_was_created_with_opener = window_was_created_with_opener; 314 params.window_was_created_with_opener = window_was_created_with_opener;
320 params.next_page_id = next_page_id; 315 params.next_page_id = next_page_id;
321 GetWebScreenInfo(&params.screen_info); 316 GetWebScreenInfo(&params.screen_info);
322 params.accessibility_mode = accessibility_mode();
323 317
324 Send(new ViewMsg_New(params)); 318 Send(new ViewMsg_New(params));
325 319
326 // If it's enabled, tell the renderer to set up the Javascript bindings for 320 // If it's enabled, tell the renderer to set up the Javascript bindings for
327 // sending messages back to the browser. 321 // sending messages back to the browser.
328 if (GetProcess()->IsGuest()) 322 if (GetProcess()->IsGuest())
329 DCHECK_EQ(0, enabled_bindings_); 323 DCHECK_EQ(0, enabled_bindings_);
330 Send(new ViewMsg_AllowBindings(GetRoutingID(), enabled_bindings_)); 324 Send(new ViewMsg_AllowBindings(GetRoutingID(), enabled_bindings_));
331 // Let our delegate know that we created a RenderView. 325 // Let our delegate know that we created a RenderView.
332 delegate_->RenderViewCreated(this); 326 delegate_->RenderViewCreated(this);
(...skipping 692 matching lines...) Expand 10 before | Expand all | Expand 10 after
1025 #if defined(OS_ANDROID) 1019 #if defined(OS_ANDROID)
1026 IPC_MESSAGE_HANDLER(ViewHostMsg_SelectionRootBoundsChanged, 1020 IPC_MESSAGE_HANDLER(ViewHostMsg_SelectionRootBoundsChanged,
1027 OnSelectionRootBoundsChanged) 1021 OnSelectionRootBoundsChanged)
1028 #endif 1022 #endif
1029 IPC_MESSAGE_HANDLER(ViewHostMsg_DidZoomURL, OnDidZoomURL) 1023 IPC_MESSAGE_HANDLER(ViewHostMsg_DidZoomURL, OnDidZoomURL)
1030 #if defined(OS_MACOSX) || defined(OS_ANDROID) 1024 #if defined(OS_MACOSX) || defined(OS_ANDROID)
1031 IPC_MESSAGE_HANDLER(ViewHostMsg_ShowPopup, OnShowPopup) 1025 IPC_MESSAGE_HANDLER(ViewHostMsg_ShowPopup, OnShowPopup)
1032 IPC_MESSAGE_HANDLER(ViewHostMsg_HidePopup, OnHidePopup) 1026 IPC_MESSAGE_HANDLER(ViewHostMsg_HidePopup, OnHidePopup)
1033 #endif 1027 #endif
1034 IPC_MESSAGE_HANDLER(ViewHostMsg_RunFileChooser, OnRunFileChooser) 1028 IPC_MESSAGE_HANDLER(ViewHostMsg_RunFileChooser, OnRunFileChooser)
1035 IPC_MESSAGE_HANDLER(AccessibilityHostMsg_Events, OnAccessibilityEvents)
1036 IPC_MESSAGE_HANDLER(AccessibilityHostMsg_LocationChanges,
1037 OnAccessibilityLocationChanges)
1038 IPC_MESSAGE_HANDLER(ViewHostMsg_FocusedNodeTouched, OnFocusedNodeTouched) 1029 IPC_MESSAGE_HANDLER(ViewHostMsg_FocusedNodeTouched, OnFocusedNodeTouched)
1039 // Have the super handle all other messages. 1030 // Have the super handle all other messages.
1040 IPC_MESSAGE_UNHANDLED( 1031 IPC_MESSAGE_UNHANDLED(
1041 handled = RenderWidgetHostImpl::OnMessageReceived(msg)) 1032 handled = RenderWidgetHostImpl::OnMessageReceived(msg))
1042 IPC_END_MESSAGE_MAP_EX() 1033 IPC_END_MESSAGE_MAP_EX()
1043 1034
1044 if (!msg_is_ok) { 1035 if (!msg_is_ok) {
1045 // The message had a handler, but its de-serialization failed. 1036 // The message had a handler, but its de-serialization failed.
1046 // Kill the renderer. 1037 // Kill the renderer.
1047 RecordAction(base::UserMetricsAction("BadMessageTerminate_RVH")); 1038 RecordAction(base::UserMetricsAction("BadMessageTerminate_RVH"));
(...skipping 459 matching lines...) Expand 10 before | Expand all | Expand 10 after
1507 return delegate_->GetWebkitPrefs(); 1498 return delegate_->GetWebkitPrefs();
1508 } 1499 }
1509 1500
1510 void RenderViewHostImpl::DisownOpener() { 1501 void RenderViewHostImpl::DisownOpener() {
1511 // This should only be called when swapped out. 1502 // This should only be called when swapped out.
1512 DCHECK(IsSwappedOut()); 1503 DCHECK(IsSwappedOut());
1513 1504
1514 Send(new ViewMsg_DisownOpener(GetRoutingID())); 1505 Send(new ViewMsg_DisownOpener(GetRoutingID()));
1515 } 1506 }
1516 1507
1517 void RenderViewHostImpl::SetAccessibilityCallbackForTesting(
1518 const base::Callback<void(ui::AXEvent)>& callback) {
1519 accessibility_testing_callback_ = callback;
1520 }
1521
1522 void RenderViewHostImpl::UpdateWebkitPreferences(const WebPreferences& prefs) { 1508 void RenderViewHostImpl::UpdateWebkitPreferences(const WebPreferences& prefs) {
1523 Send(new ViewMsg_UpdateWebPreferences(GetRoutingID(), prefs)); 1509 Send(new ViewMsg_UpdateWebPreferences(GetRoutingID(), prefs));
1524 } 1510 }
1525 1511
1526 void RenderViewHostImpl::GetAudioOutputControllers( 1512 void RenderViewHostImpl::GetAudioOutputControllers(
1527 const GetAudioOutputControllersCallback& callback) const { 1513 const GetAudioOutputControllersCallback& callback) const {
1528 AudioRendererHost* audio_host = 1514 AudioRendererHost* audio_host =
1529 static_cast<RenderProcessHostImpl*>(GetProcess())->audio_renderer_host(); 1515 static_cast<RenderProcessHostImpl*>(GetProcess())->audio_renderer_host();
1530 audio_host->GetOutputControllers(GetRoutingID(), callback); 1516 audio_host->GetOutputControllers(GetRoutingID(), callback);
1531 } 1517 }
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
1568 1554
1569 void RenderViewHostImpl::ExecutePluginActionAtLocation( 1555 void RenderViewHostImpl::ExecutePluginActionAtLocation(
1570 const gfx::Point& location, const blink::WebPluginAction& action) { 1556 const gfx::Point& location, const blink::WebPluginAction& action) {
1571 Send(new ViewMsg_PluginActionAt(GetRoutingID(), location, action)); 1557 Send(new ViewMsg_PluginActionAt(GetRoutingID(), location, action));
1572 } 1558 }
1573 1559
1574 void RenderViewHostImpl::NotifyMoveOrResizeStarted() { 1560 void RenderViewHostImpl::NotifyMoveOrResizeStarted() {
1575 Send(new ViewMsg_MoveOrResizeStarted(GetRoutingID())); 1561 Send(new ViewMsg_MoveOrResizeStarted(GetRoutingID()));
1576 } 1562 }
1577 1563
1578 void RenderViewHostImpl::OnAccessibilityEvents(
1579 const std::vector<AccessibilityHostMsg_EventParams>& params) {
1580 if ((accessibility_mode() != AccessibilityModeOff) && view_ &&
1581 IsRVHStateActive(rvh_state_)) {
1582 if (accessibility_mode() & AccessibilityModeFlagPlatform) {
1583 view_->CreateBrowserAccessibilityManagerIfNeeded();
1584 BrowserAccessibilityManager* manager =
1585 view_->GetBrowserAccessibilityManager();
1586 if (manager)
1587 manager->OnAccessibilityEvents(params);
1588 }
1589
1590 std::vector<AXEventNotificationDetails> details;
1591 for (unsigned int i = 0; i < params.size(); ++i) {
1592 const AccessibilityHostMsg_EventParams& param = params[i];
1593 AXEventNotificationDetails detail(param.update.nodes,
1594 param.event_type,
1595 param.id,
1596 GetProcess()->GetID(),
1597 GetRoutingID());
1598 details.push_back(detail);
1599 }
1600
1601 delegate_->AccessibilityEventReceived(details);
1602 }
1603
1604 // Always send an ACK or the renderer can be in a bad state.
1605 Send(new AccessibilityMsg_Events_ACK(GetRoutingID()));
1606
1607 // The rest of this code is just for testing; bail out if we're not
1608 // in that mode.
1609 if (accessibility_testing_callback_.is_null())
1610 return;
1611
1612 for (unsigned i = 0; i < params.size(); i++) {
1613 const AccessibilityHostMsg_EventParams& param = params[i];
1614 if (static_cast<int>(param.event_type) < 0)
1615 continue;
1616 if (!ax_tree_)
1617 ax_tree_.reset(new ui::AXTree(param.update));
1618 else
1619 CHECK(ax_tree_->Unserialize(param.update)) << ax_tree_->error();
1620 accessibility_testing_callback_.Run(param.event_type);
1621 }
1622 }
1623
1624 void RenderViewHostImpl::OnAccessibilityLocationChanges(
1625 const std::vector<AccessibilityHostMsg_LocationChangeParams>& params) {
1626 if (view_ && IsRVHStateActive(rvh_state_)) {
1627 if (accessibility_mode() & AccessibilityModeFlagPlatform) {
1628 view_->CreateBrowserAccessibilityManagerIfNeeded();
1629 BrowserAccessibilityManager* manager =
1630 view_->GetBrowserAccessibilityManager();
1631 if (manager)
1632 manager->OnLocationChanges(params);
1633 }
1634 // TODO(aboxhall): send location change events to web contents observers too
1635 }
1636 }
1637
1638 void RenderViewHostImpl::OnDidZoomURL(double zoom_level, 1564 void RenderViewHostImpl::OnDidZoomURL(double zoom_level,
1639 bool remember, 1565 bool remember,
1640 const GURL& url) { 1566 const GURL& url) {
1641 HostZoomMapImpl* host_zoom_map = static_cast<HostZoomMapImpl*>( 1567 HostZoomMapImpl* host_zoom_map = static_cast<HostZoomMapImpl*>(
1642 HostZoomMap::GetForBrowserContext(GetProcess()->GetBrowserContext())); 1568 HostZoomMap::GetForBrowserContext(GetProcess()->GetBrowserContext()));
1643 if (remember) { 1569 if (remember) {
1644 host_zoom_map-> 1570 host_zoom_map->
1645 SetZoomLevelForHost(net::GetHostOrSpecFromURL(url), zoom_level); 1571 SetZoomLevelForHost(net::GetHostOrSpecFromURL(url), zoom_level);
1646 } else { 1572 } else {
1647 host_zoom_map->SetTemporaryZoomLevel( 1573 host_zoom_map->SetTemporaryZoomLevel(
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after
1721 return true; 1647 return true;
1722 } 1648 }
1723 1649
1724 void RenderViewHostImpl::AttachToFrameTree() { 1650 void RenderViewHostImpl::AttachToFrameTree() {
1725 FrameTree* frame_tree = delegate_->GetFrameTree(); 1651 FrameTree* frame_tree = delegate_->GetFrameTree();
1726 1652
1727 frame_tree->ResetForMainFrameSwap(); 1653 frame_tree->ResetForMainFrameSwap();
1728 } 1654 }
1729 1655
1730 } // namespace content 1656 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698