| Index: content/browser/frame_host/render_frame_host_impl.cc
|
| diff --git a/content/browser/frame_host/render_frame_host_impl.cc b/content/browser/frame_host/render_frame_host_impl.cc
|
| index 5c47a5e73341b62b98a43d514dd642f74ffa96aa..8a9ae7b8fca5122f638c0f226b3d2a80b7d4070d 100644
|
| --- a/content/browser/frame_host/render_frame_host_impl.cc
|
| +++ b/content/browser/frame_host/render_frame_host_impl.cc
|
| @@ -205,6 +205,7 @@ RenderFrameHostImpl::RenderFrameHostImpl(SiteInstance* site_instance,
|
| nav_entry_id_(0),
|
| accessibility_reset_token_(0),
|
| accessibility_reset_count_(0),
|
| + browser_plugin_embedder_ax_tree_id_(AXTreeIDRegistry::kNoAXTreeID),
|
| no_create_browser_accessibility_manager_for_testing_(false),
|
| web_ui_type_(WebUI::kNoWebUI),
|
| pending_web_ui_type_(WebUI::kNoWebUI),
|
| @@ -2407,6 +2408,11 @@ void RenderFrameHostImpl::UpdateAXTreeData() {
|
| delegate_->AccessibilityEventReceived(details);
|
| }
|
|
|
| +void RenderFrameHostImpl::SetBrowserPluginEmbedderAXTreeID(
|
| + AXTreeIDRegistry::AXTreeID ax_tree_id) {
|
| + browser_plugin_embedder_ax_tree_id_ = ax_tree_id;
|
| +}
|
| +
|
| void RenderFrameHostImpl::SetTextTrackSettings(
|
| const FrameMsg_TextTrackSettings_Params& params) {
|
| DCHECK(!GetParent());
|
| @@ -2638,11 +2644,13 @@ AXTreeIDRegistry::AXTreeID RenderFrameHostImpl::RoutingIDToAXTreeID(
|
| AXTreeIDRegistry::AXTreeID
|
| RenderFrameHostImpl::BrowserPluginInstanceIDToAXTreeID(
|
| int instance_id) {
|
| - RenderFrameHost* guest = delegate()->GetGuestByInstanceID(
|
| - this, instance_id);
|
| + RenderFrameHostImpl* guest = static_cast<RenderFrameHostImpl*>(
|
| + delegate()->GetGuestByInstanceID(this, instance_id));
|
| if (!guest)
|
| return AXTreeIDRegistry::kNoAXTreeID;
|
|
|
| + guest->SetBrowserPluginEmbedderAXTreeID(GetAXTreeID());
|
| +
|
| return guest->GetAXTreeID();
|
| }
|
|
|
| @@ -2687,6 +2695,9 @@ void RenderFrameHostImpl::AXContentTreeDataToAXTreeData(
|
| if (src.parent_routing_id != -1)
|
| dst->parent_tree_id = RoutingIDToAXTreeID(src.parent_routing_id);
|
|
|
| + if (browser_plugin_embedder_ax_tree_id_ != AXTreeIDRegistry::kNoAXTreeID)
|
| + dst->parent_tree_id = browser_plugin_embedder_ax_tree_id_;
|
| +
|
| // If this is not the root frame tree node, we're done.
|
| if (frame_tree_node()->parent())
|
| return;
|
|
|