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

Side by Side Diff: content/browser/frame_host/frame_tree.h

Issue 894843003: Move the RenderProcessGone IPC from RenderViewHost to RenderFrameHost (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix for swapped out RFHs. Created 5 years, 10 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
OLDNEW
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 #ifndef CONTENT_BROWSER_FRAME_HOST_FRAME_TREE_H_ 5 #ifndef CONTENT_BROWSER_FRAME_HOST_FRAME_TREE_H_
6 #define CONTENT_BROWSER_FRAME_HOST_FRAME_TREE_H_ 6 #define CONTENT_BROWSER_FRAME_HOST_FRAME_TREE_H_
7 7
8 #include <string> 8 #include <string>
9 9
10 #include "base/callback.h" 10 #include "base/callback.h"
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after
84 FrameTreeNode* source, 84 FrameTreeNode* source,
85 SiteInstance* site_instance); 85 SiteInstance* site_instance);
86 86
87 // Clears process specific-state after a main frame process swap. 87 // Clears process specific-state after a main frame process swap.
88 // This destroys most of the frame tree but retains the root node so that 88 // This destroys most of the frame tree but retains the root node so that
89 // navigation state may be kept on it between process swaps. Used to 89 // navigation state may be kept on it between process swaps. Used to
90 // support bookkeeping for top-level navigations. 90 // support bookkeeping for top-level navigations.
91 // TODO(creis): Look into how we can remove the need for this method. 91 // TODO(creis): Look into how we can remove the need for this method.
92 void ResetForMainFrameSwap(); 92 void ResetForMainFrameSwap();
93 93
94 // Update the frame tree after a process exits. Any nodes currently using the
95 // given |render_view_host| will lose all their children.
96 // TODO(creis): This should take a RenderProcessHost once RenderFrameHost
97 // knows its process. Until then, we would just be asking the RenderViewHost
98 // for its process, so we'll skip that step.
99 void RenderProcessGone(RenderViewHost* render_view_host);
100
101 // Convenience accessor for the main frame's RenderFrameHostImpl. 94 // Convenience accessor for the main frame's RenderFrameHostImpl.
102 RenderFrameHostImpl* GetMainFrame() const; 95 RenderFrameHostImpl* GetMainFrame() const;
103 96
104 // Returns the focused frame. 97 // Returns the focused frame.
105 FrameTreeNode* GetFocusedFrame(); 98 FrameTreeNode* GetFocusedFrame();
106 99
107 // Sets the focused frame. 100 // Sets the focused frame.
108 void SetFocusedFrame(FrameTreeNode* node); 101 void SetFocusedFrame(FrameTreeNode* node);
109 102
110 // Allows a client to listen for frame removal. The listener should expect 103 // Allows a client to listen for frame removal. The listener should expect
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after
170 int64 focused_frame_tree_node_id_; 163 int64 focused_frame_tree_node_id_;
171 164
172 base::Callback<void(RenderFrameHost*)> on_frame_removed_; 165 base::Callback<void(RenderFrameHost*)> on_frame_removed_;
173 166
174 DISALLOW_COPY_AND_ASSIGN(FrameTree); 167 DISALLOW_COPY_AND_ASSIGN(FrameTree);
175 }; 168 };
176 169
177 } // namespace content 170 } // namespace content
178 171
179 #endif // CONTENT_BROWSER_FRAME_HOST_FRAME_TREE_H_ 172 #endif // CONTENT_BROWSER_FRAME_HOST_FRAME_TREE_H_
OLDNEW
« no previous file with comments | « no previous file | content/browser/frame_host/frame_tree.cc » ('j') | content/browser/frame_host/frame_tree.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698