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 |