| 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;
|
|
|