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 e982660a8a5b0a44e669ff5ea94555b00fa36481..7d1de67e21e972e7d80b06e5f9f141e24fe1ec7a 100644 |
--- a/content/browser/frame_host/render_frame_host_impl.cc |
+++ b/content/browser/frame_host/render_frame_host_impl.cc |
@@ -206,6 +206,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), |
@@ -2658,11 +2659,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->set_browser_plugin_embedder_ax_tree_id(GetAXTreeID()); |
+ |
return guest->GetAXTreeID(); |
} |
@@ -2707,6 +2710,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; |