Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/frame_host/frame_tree_node.h" | 5 #include "content/browser/frame_host/frame_tree_node.h" |
| 6 | 6 |
| 7 #include <queue> | 7 #include <queue> |
| 8 | 8 |
| 9 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
| 10 #include "content/browser/frame_host/navigator.h" | 10 #include "content/browser/frame_host/navigator.h" |
| 11 #include "content/browser/frame_host/render_frame_host_impl.h" | 11 #include "content/browser/frame_host/render_frame_host_impl.h" |
| 12 #include "content/browser/renderer_host/render_view_host_impl.h" | |
| 12 | 13 |
| 13 namespace content { | 14 namespace content { |
| 14 | 15 |
| 15 const int64 FrameTreeNode::kInvalidFrameId = -1; | 16 const int64 FrameTreeNode::kInvalidFrameId = -1; |
| 16 int64 FrameTreeNode::next_frame_tree_node_id_ = 1; | 17 int64 FrameTreeNode::next_frame_tree_node_id_ = 1; |
| 17 | 18 |
| 18 FrameTreeNode::FrameTreeNode(Navigator* navigator, | 19 FrameTreeNode::FrameTreeNode(Navigator* navigator, |
| 19 RenderFrameHostDelegate* render_frame_delegate, | 20 RenderFrameHostDelegate* render_frame_delegate, |
| 20 RenderViewHostDelegate* render_view_delegate, | 21 RenderViewHostDelegate* render_view_delegate, |
| 21 RenderWidgetHostDelegate* render_widget_delegate, | 22 RenderWidgetHostDelegate* render_widget_delegate, |
| 22 RenderFrameHostManager::Delegate* manager_delegate, | 23 RenderFrameHostManager::Delegate* manager_delegate, |
| 23 int64 frame_id, | 24 int64 frame_id, |
| 24 const std::string& name) | 25 const std::string& name) |
| 25 : navigator_(navigator), | 26 : navigator_(navigator), |
| 26 render_manager_(render_frame_delegate, | 27 render_manager_(render_frame_delegate, |
| 27 render_view_delegate, | 28 render_view_delegate, |
| 28 render_widget_delegate, | 29 render_widget_delegate, |
| 29 manager_delegate), | 30 manager_delegate), |
| 30 frame_tree_node_id_(next_frame_tree_node_id_++), | 31 frame_tree_node_id_(next_frame_tree_node_id_++), |
| 31 frame_id_(frame_id), | 32 frame_id_(frame_id), |
| 32 frame_name_(name), | 33 frame_name_(name) { |
| 33 owns_render_frame_host_(true), | |
| 34 render_frame_host_(NULL) { | |
| 35 } | 34 } |
| 36 | 35 |
| 37 FrameTreeNode::~FrameTreeNode() { | 36 FrameTreeNode::~FrameTreeNode() { |
| 38 if (owns_render_frame_host_) | |
| 39 delete render_frame_host_; | |
| 40 } | 37 } |
| 41 | 38 |
| 42 void FrameTreeNode::AddChild(scoped_ptr<FrameTreeNode> child) { | 39 void FrameTreeNode::AddChild(scoped_ptr<FrameTreeNode> child, |
| 40 int render_frame_host_id) { | |
|
nasko
2013/12/12 02:22:12
nit: This is a bit unclear. This is the routing id
Charlie Reis
2013/12/12 18:19:30
That's a good idea. We were using "frame_routing_
| |
| 41 // Initialize the RenderFrameHost for the new node. | |
|
nasko
2013/12/12 02:22:12
Maybe add a note that when adding frames, they are
Charlie Reis
2013/12/12 18:19:30
Done.
| |
| 42 child->render_manager()->Init( | |
| 43 render_manager_.current_host()->GetSiteInstance()->GetBrowserContext(), | |
| 44 render_manager_.current_host()->GetSiteInstance(), | |
| 45 render_manager_.current_host()->GetRoutingID(), | |
| 46 render_frame_host_id); | |
| 43 children_.push_back(child.release()); | 47 children_.push_back(child.release()); |
| 44 } | 48 } |
| 45 | 49 |
| 46 void FrameTreeNode::RemoveChild(FrameTreeNode* child) { | 50 void FrameTreeNode::RemoveChild(FrameTreeNode* child) { |
| 47 std::vector<FrameTreeNode*>::iterator iter; | 51 std::vector<FrameTreeNode*>::iterator iter; |
| 48 | 52 |
| 49 for (iter = children_.begin(); iter != children_.end(); ++iter) { | 53 for (iter = children_.begin(); iter != children_.end(); ++iter) { |
| 50 if ((*iter) == child) | 54 if ((*iter) == child) |
| 51 break; | 55 break; |
| 52 } | 56 } |
| 53 | 57 |
| 54 if (iter != children_.end()) | 58 if (iter != children_.end()) |
| 55 children_.erase(iter); | 59 children_.erase(iter); |
| 56 } | 60 } |
| 57 | 61 |
| 58 void FrameTreeNode::ResetForMainFrame( | 62 void FrameTreeNode::ResetForMainFrameSwap() { |
| 59 RenderFrameHostImpl* new_render_frame_host) { | |
| 60 owns_render_frame_host_ = false; | |
| 61 frame_id_ = kInvalidFrameId; | 63 frame_id_ = kInvalidFrameId; |
| 62 current_url_ = GURL(); | 64 current_url_ = GURL(); |
| 63 | 65 |
| 64 // The children may not have been cleared if a cross-process navigation | 66 // The children may not have been cleared if a cross-process navigation |
| 65 // commits before the old process cleans everything up. Make sure the child | 67 // commits before the old process cleans everything up. Make sure the child |
| 66 // nodes get deleted. | 68 // nodes get deleted. |
| 67 children_.clear(); | 69 children_.clear(); |
| 68 | |
| 69 render_frame_host_ = new_render_frame_host; | |
| 70 } | 70 } |
| 71 | 71 |
| 72 } // namespace content | 72 } // namespace content |
| OLD | NEW |