| 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_NAVIGATOR_IMPL_H_ | 5 #ifndef CONTENT_BROWSER_FRAME_HOST_NAVIGATOR_IMPL_H_ |
| 6 #define CONTENT_BROWSER_FRAME_HOST_NAVIGATOR_IMPL_H_ | 6 #define CONTENT_BROWSER_FRAME_HOST_NAVIGATOR_IMPL_H_ |
| 7 | 7 |
| 8 #include "base/containers/scoped_ptr_hash_map.h" | 8 #include "base/containers/scoped_ptr_hash_map.h" |
| 9 #include "base/memory/ref_counted.h" | 9 #include "base/memory/ref_counted.h" |
| 10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 49 int error_code, | 49 int error_code, |
| 50 const base::string16& error_description, | 50 const base::string16& error_description, |
| 51 bool was_ignored_by_handler) override; | 51 bool was_ignored_by_handler) override; |
| 52 void DidNavigate( | 52 void DidNavigate( |
| 53 RenderFrameHostImpl* render_frame_host, | 53 RenderFrameHostImpl* render_frame_host, |
| 54 const FrameHostMsg_DidCommitProvisionalLoad_Params& params) override; | 54 const FrameHostMsg_DidCommitProvisionalLoad_Params& params) override; |
| 55 bool NavigateToPendingEntry(FrameTreeNode* frame_tree_node, | 55 bool NavigateToPendingEntry(FrameTreeNode* frame_tree_node, |
| 56 const FrameNavigationEntry& frame_entry, | 56 const FrameNavigationEntry& frame_entry, |
| 57 NavigationController::ReloadType reload_type, | 57 NavigationController::ReloadType reload_type, |
| 58 bool is_same_document_history_load) override; | 58 bool is_same_document_history_load) override; |
| 59 bool NavigateNewChildFrame(RenderFrameHostImpl* render_frame_host, |
| 60 const std::string& unique_name) override; |
| 59 void RequestOpenURL(RenderFrameHostImpl* render_frame_host, | 61 void RequestOpenURL(RenderFrameHostImpl* render_frame_host, |
| 60 const GURL& url, | 62 const GURL& url, |
| 61 SiteInstance* source_site_instance, | 63 SiteInstance* source_site_instance, |
| 62 const Referrer& referrer, | 64 const Referrer& referrer, |
| 63 WindowOpenDisposition disposition, | 65 WindowOpenDisposition disposition, |
| 64 bool should_replace_current_entry, | 66 bool should_replace_current_entry, |
| 65 bool user_gesture) override; | 67 bool user_gesture) override; |
| 66 void RequestTransferURL(RenderFrameHostImpl* render_frame_host, | 68 void RequestTransferURL(RenderFrameHostImpl* render_frame_host, |
| 67 const GURL& url, | 69 const GURL& url, |
| 68 SiteInstance* source_site_instance, | 70 SiteInstance* source_site_instance, |
| (...skipping 22 matching lines...) Expand all Loading... |
| 91 const base::TimeTicks& renderer_before_unload_end_time) override; | 93 const base::TimeTicks& renderer_before_unload_end_time) override; |
| 92 void CancelNavigation(FrameTreeNode* frame_tree_node) override; | 94 void CancelNavigation(FrameTreeNode* frame_tree_node) override; |
| 93 | 95 |
| 94 private: | 96 private: |
| 95 // Holds data used to track browser side navigation metrics. | 97 // Holds data used to track browser side navigation metrics. |
| 96 struct NavigationMetricsData; | 98 struct NavigationMetricsData; |
| 97 | 99 |
| 98 friend class NavigatorTestWithBrowserSideNavigation; | 100 friend class NavigatorTestWithBrowserSideNavigation; |
| 99 ~NavigatorImpl() override; | 101 ~NavigatorImpl() override; |
| 100 | 102 |
| 101 // Navigates to the given entry, which must be the pending entry. Private | 103 // Navigates to the given entry, which might be the pending entry (if |
| 102 // because all callers should use NavigateToPendingEntry. | 104 // |is_pending_entry| is true). Private because all callers should use either |
| 105 // NavigateToPendingEntry or NavigateToNewChildFrame. |
| 103 bool NavigateToEntry(FrameTreeNode* frame_tree_node, | 106 bool NavigateToEntry(FrameTreeNode* frame_tree_node, |
| 104 const FrameNavigationEntry& frame_entry, | 107 const FrameNavigationEntry& frame_entry, |
| 105 const NavigationEntryImpl& entry, | 108 const NavigationEntryImpl& entry, |
| 106 NavigationController::ReloadType reload_type, | 109 NavigationController::ReloadType reload_type, |
| 107 bool is_same_document_history_load); | 110 bool is_same_document_history_load, |
| 111 bool is_pending_entry); |
| 108 | 112 |
| 109 bool ShouldAssignSiteForURL(const GURL& url); | 113 bool ShouldAssignSiteForURL(const GURL& url); |
| 110 | 114 |
| 111 void CheckWebUIRendererDoesNotDisplayNormalURL( | 115 void CheckWebUIRendererDoesNotDisplayNormalURL( |
| 112 RenderFrameHostImpl* render_frame_host, | 116 RenderFrameHostImpl* render_frame_host, |
| 113 const GURL& url); | 117 const GURL& url); |
| 114 | 118 |
| 115 // PlzNavigate: if needed, sends a BeforeUnload IPC to the renderer to ask it | 119 // PlzNavigate: if needed, sends a BeforeUnload IPC to the renderer to ask it |
| 116 // to execute the beforeUnload event. Otherwise, the navigation request will | 120 // to execute the beforeUnload event. Otherwise, the navigation request will |
| 117 // be started. | 121 // be started. |
| (...skipping 28 matching lines...) Expand all Loading... |
| 146 NavigatorDelegate* delegate_; | 150 NavigatorDelegate* delegate_; |
| 147 | 151 |
| 148 scoped_ptr<NavigatorImpl::NavigationMetricsData> navigation_data_; | 152 scoped_ptr<NavigatorImpl::NavigationMetricsData> navigation_data_; |
| 149 | 153 |
| 150 DISALLOW_COPY_AND_ASSIGN(NavigatorImpl); | 154 DISALLOW_COPY_AND_ASSIGN(NavigatorImpl); |
| 151 }; | 155 }; |
| 152 | 156 |
| 153 } // namespace content | 157 } // namespace content |
| 154 | 158 |
| 155 #endif // CONTENT_BROWSER_FRAME_HOST_NAVIGATOR_IMPL_H_ | 159 #endif // CONTENT_BROWSER_FRAME_HOST_NAVIGATOR_IMPL_H_ |
| OLD | NEW |