Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(223)

Side by Side Diff: content/browser/renderer_host/frame_tree.cc

Issue 23841002: Create a new RenderFrameHost per child frame when --site-per-process is enabled. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase and add some comments. Created 7 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "content/browser/renderer_host/frame_tree.h"
6
7 #include <queue>
8
9 #include "base/bind.h"
10 #include "base/callback.h"
11 #include "content/browser/renderer_host/frame_tree_node.h"
12 #include "content/browser/renderer_host/render_frame_host_impl.h"
13
14 namespace content {
15
16 namespace {
17 bool FindHelper(int64 frame_id, FrameTreeNode** out_node,
18 FrameTreeNode* node) {
19 if (node->frame_id() == frame_id) {
20 *out_node = node;
21 return false;
nasko 2013/09/11 22:26:24 Put a comment on why we return false. It is not im
awong 2013/09/21 01:19:56 Done.
22 }
23 return true;
24 }
25
26 } // namespace
27
28 FrameTree::FrameTree()
29 : root_(new FrameTreeNode(FrameTreeNode::kInvalidFrameId, std::string(),
30 scoped_ptr<RenderFrameHostImpl>())) {
31 }
32
33 FrameTree::~FrameTree() {
34 }
35
36 FrameTreeNode* FrameTree::FindByID(int64 frame_id) {
37 FrameTreeNode* node = NULL;
38 ForEach(base::Bind(&FindHelper, frame_id, &node));
39 return node;
40 }
41
42 void FrameTree::ForEach(
43 const base::Callback<bool(FrameTreeNode*)>& on_node) const {
44 std::queue<FrameTreeNode*> queue;
45 queue.push(root_.get());
46
47 while (!queue.empty()) {
48 FrameTreeNode* node = queue.front();
49 queue.pop();
50 if (!on_node.Run(node))
51 break;
52
53 for (size_t i = 0; i < node->child_count(); ++i)
54 queue.push(node->child_at(i));
55 }
56 }
57
58 bool FrameTree::IsFirstNavigation() const {
59 return root_->frame_id() == FrameTreeNode::kInvalidFrameId;
60 }
61
62 void FrameTree::OnFirstNavigation(int main_frame_id) {
63 root_->set_frame_id(main_frame_id);
64 }
65
66 void FrameTree::AddFrame(int render_frame_host_id, int64 parent_frame_id,
67 int64 frame_id, const std::string& frame_name) {
68 FrameTreeNode* parent = FindByID(parent_frame_id);
69 parent->AddChild(CreateNode(frame_id, frame_name, render_frame_host_id,
70 parent->render_frame_host()->GetProcess()));
71 }
72
73 void FrameTree::RemoveFrame(int64 parent_frame_id, int64 frame_id) {
74 FrameTreeNode* parent = FindByID(parent_frame_id);
75
76 // TODO(ajwong): Should this DCHECK()?
nasko 2013/09/11 22:26:24 Yes, it will be helpful to DCHECK here.
awong 2013/09/21 01:19:56 Just removed the check cause we crash immediately.
Charlie Reis 2013/09/24 18:25:58 Is this done in response to a message from the ren
77 if (!parent)
78 return;
79
80 parent->RemoveChild(frame_id);
81 if (!on_frame_removed_.is_null())
82 on_frame_removed_.Run(frame_id);
83 }
84
85 void FrameTree::SetFrameUrl(int64 frame_id, const GURL& url) {
86 FrameTreeNode* node = FindByID(frame_id);
87 if (node)
88 node->set_current_url(url);
89 }
90
91 scoped_ptr<RenderFrameHostImpl> FrameTree::SwapMainFrame(
92 scoped_ptr<RenderFrameHostImpl> render_frame_host) {
93 return root_->ResetRenderFrameHost(render_frame_host.Pass());
94 }
95
96 RenderFrameHostImpl* FrameTree::GetMainFrame() const {
97 return root_->render_frame_host();
98 }
99
100 void FrameTree::SetFrameRemoveListener(
101 const base::Callback<void(int64)>& on_frame_removed) {
102 on_frame_removed_ = on_frame_removed;
103 }
104
105 scoped_ptr<FrameTreeNode> FrameTree::CreateNode(
106 int64 frame_id, const std::string& frame_name, int render_frame_host_id,
107 RenderProcessHost* render_process_host) {
108 scoped_ptr<RenderFrameHostImpl> render_frame_host(
109 new RenderFrameHostImpl(render_process_host, this, render_frame_host_id,
110 false));
111
112 return make_scoped_ptr(new FrameTreeNode(frame_id, frame_name,
113 render_frame_host.Pass()));
114 }
115
116 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698