| 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 #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 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 52 | 52 |
| 53 FrameTreeNode* root() const { return root_.get(); } | 53 FrameTreeNode* root() const { return root_.get(); } |
| 54 | 54 |
| 55 // Returns the FrameTreeNode with the given |frame_tree_node_id| if it is part | 55 // Returns the FrameTreeNode with the given |frame_tree_node_id| if it is part |
| 56 // of this FrameTree. | 56 // of this FrameTree. |
| 57 FrameTreeNode* FindByID(int64 frame_tree_node_id); | 57 FrameTreeNode* FindByID(int64 frame_tree_node_id); |
| 58 | 58 |
| 59 // Returns the FrameTreeNode with the given renderer-specific |routing_id|. | 59 // Returns the FrameTreeNode with the given renderer-specific |routing_id|. |
| 60 FrameTreeNode* FindByRoutingID(int process_id, int routing_id); | 60 FrameTreeNode* FindByRoutingID(int process_id, int routing_id); |
| 61 | 61 |
| 62 // Returns the first frame in this tree with the given |name|, or the main |
| 63 // frame if |name| is empty. |
| 64 // Note that this does NOT support pseudo-names like _self, _top, and _blank, |
| 65 // nor searching other FrameTrees (unlike blink::WebView::findFrameByName). |
| 66 FrameTreeNode* FindByName(const std::string& name); |
| 67 |
| 62 // Executes |on_node| on each node in the frame tree. If |on_node| returns | 68 // Executes |on_node| on each node in the frame tree. If |on_node| returns |
| 63 // false, terminates the iteration immediately. Returning false is useful | 69 // false, terminates the iteration immediately. Returning false is useful |
| 64 // if |on_node| is just doing a search over the tree. The iteration proceeds | 70 // if |on_node| is just doing a search over the tree. The iteration proceeds |
| 65 // top-down and visits a node before adding its children to the queue, making | 71 // top-down and visits a node before adding its children to the queue, making |
| 66 // it safe to remove children during the callback. | 72 // it safe to remove children during the callback. |
| 67 void ForEach(const base::Callback<bool(FrameTreeNode*)>& on_node) const; | 73 void ForEach(const base::Callback<bool(FrameTreeNode*)>& on_node) const; |
| 68 | 74 |
| 69 // Frame tree manipulation routines. | 75 // Frame tree manipulation routines. |
| 70 // |process_id| is required to disambiguate |new_routing_id|, and it must | 76 // |process_id| is required to disambiguate |new_routing_id|, and it must |
| 71 // match the process of the |parent| node. Otherwise this method returns | 77 // match the process of the |parent| node. Otherwise this method returns |
| (...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 177 | 183 |
| 178 // Overall load progress. | 184 // Overall load progress. |
| 179 double load_progress_; | 185 double load_progress_; |
| 180 | 186 |
| 181 DISALLOW_COPY_AND_ASSIGN(FrameTree); | 187 DISALLOW_COPY_AND_ASSIGN(FrameTree); |
| 182 }; | 188 }; |
| 183 | 189 |
| 184 } // namespace content | 190 } // namespace content |
| 185 | 191 |
| 186 #endif // CONTENT_BROWSER_FRAME_HOST_FRAME_TREE_H_ | 192 #endif // CONTENT_BROWSER_FRAME_HOST_FRAME_TREE_H_ |
| OLD | NEW |