| Index: content/browser/frame_host/frame_tree_node.cc
|
| diff --git a/content/browser/frame_host/frame_tree_node.cc b/content/browser/frame_host/frame_tree_node.cc
|
| index 37b61b4fadf33f20ebe736497138bb582e3d40a7..cca17fdedfe43ad201c945f24af32c832b29fc2d 100644
|
| --- a/content/browser/frame_host/frame_tree_node.cc
|
| +++ b/content/browser/frame_host/frame_tree_node.cc
|
| @@ -7,39 +7,53 @@
|
| #include <queue>
|
|
|
| #include "base/stl_util.h"
|
| +#include "content/browser/frame_host/frame_tree.h"
|
| #include "content/browser/frame_host/navigator.h"
|
| #include "content/browser/frame_host/render_frame_host_impl.h"
|
| +#include "content/browser/renderer_host/render_view_host_impl.h"
|
|
|
| namespace content {
|
|
|
| const int64 FrameTreeNode::kInvalidFrameId = -1;
|
| int64 FrameTreeNode::next_frame_tree_node_id_ = 1;
|
|
|
| -FrameTreeNode::FrameTreeNode(Navigator* navigator,
|
| +FrameTreeNode::FrameTreeNode(FrameTree* frame_tree,
|
| + Navigator* navigator,
|
| RenderFrameHostDelegate* render_frame_delegate,
|
| RenderViewHostDelegate* render_view_delegate,
|
| RenderWidgetHostDelegate* render_widget_delegate,
|
| RenderFrameHostManager::Delegate* manager_delegate,
|
| int64 frame_id,
|
| const std::string& name)
|
| - : navigator_(navigator),
|
| - render_manager_(render_frame_delegate,
|
| + : frame_tree_(frame_tree),
|
| + navigator_(navigator),
|
| + render_manager_(this,
|
| + render_frame_delegate,
|
| render_view_delegate,
|
| render_widget_delegate,
|
| manager_delegate),
|
| frame_tree_node_id_(next_frame_tree_node_id_++),
|
| frame_id_(frame_id),
|
| - frame_name_(name),
|
| - owns_render_frame_host_(true),
|
| - render_frame_host_(NULL) {
|
| + frame_name_(name) {
|
| }
|
|
|
| FrameTreeNode::~FrameTreeNode() {
|
| - if (owns_render_frame_host_)
|
| - delete render_frame_host_;
|
| }
|
|
|
| -void FrameTreeNode::AddChild(scoped_ptr<FrameTreeNode> child) {
|
| +bool FrameTreeNode::IsMainFrame() const {
|
| + return frame_tree_->root() == this;
|
| +}
|
| +
|
| +void FrameTreeNode::AddChild(scoped_ptr<FrameTreeNode> child,
|
| + int frame_routing_id) {
|
| + // Initialize the RenderFrameHost for the new node. We always create child
|
| + // frames in the same SiteInstance as the current frame, and they can swap to
|
| + // a different one if they navigate away.
|
| + child->render_manager()->Init(
|
| + render_manager_.current_host()->GetSiteInstance()->GetBrowserContext(),
|
| + render_manager_.current_host()->GetSiteInstance(),
|
| + render_manager_.current_host()->GetRoutingID(),
|
| + frame_routing_id);
|
| children_.push_back(child.release());
|
| }
|
|
|
| @@ -55,9 +69,7 @@ void FrameTreeNode::RemoveChild(FrameTreeNode* child) {
|
| children_.erase(iter);
|
| }
|
|
|
| -void FrameTreeNode::ResetForMainFrame(
|
| - RenderFrameHostImpl* new_render_frame_host) {
|
| - owns_render_frame_host_ = false;
|
| +void FrameTreeNode::ResetForMainFrameSwap() {
|
| frame_id_ = kInvalidFrameId;
|
| current_url_ = GURL();
|
|
|
| @@ -65,8 +77,6 @@ void FrameTreeNode::ResetForMainFrame(
|
| // commits before the old process cleans everything up. Make sure the child
|
| // nodes get deleted.
|
| children_.clear();
|
| -
|
| - render_frame_host_ = new_render_frame_host;
|
| }
|
|
|
| } // namespace content
|
|
|