OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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_NAVIGATION_HANDLE_IMPL_H_ | 5 #ifndef CONTENT_BROWSER_FRAME_HOST_NAVIGATION_HANDLE_IMPL_H_ |
6 #define CONTENT_BROWSER_FRAME_HOST_NAVIGATION_HANDLE_IMPL_H_ | 6 #define CONTENT_BROWSER_FRAME_HOST_NAVIGATION_HANDLE_IMPL_H_ |
7 | 7 |
8 #include "content/public/browser/navigation_handle.h" | 8 #include "content/public/browser/navigation_handle.h" |
9 | 9 |
10 #include <stddef.h> | 10 #include <stddef.h> |
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
87 const GURL& url, | 87 const GURL& url, |
88 const std::vector<GURL>& redirect_chain, | 88 const std::vector<GURL>& redirect_chain, |
89 FrameTreeNode* frame_tree_node, | 89 FrameTreeNode* frame_tree_node, |
90 bool is_renderer_initiated, | 90 bool is_renderer_initiated, |
91 bool is_same_page, | 91 bool is_same_page, |
92 const base::TimeTicks& navigation_start, | 92 const base::TimeTicks& navigation_start, |
93 int pending_nav_entry_id, | 93 int pending_nav_entry_id, |
94 bool started_from_context_menu); | 94 bool started_from_context_menu); |
95 ~NavigationHandleImpl() override; | 95 ~NavigationHandleImpl() override; |
96 | 96 |
| 97 // Used to track the state the navigation is currently in. |
| 98 enum State { |
| 99 INITIAL = 0, |
| 100 WILL_SEND_REQUEST, |
| 101 DEFERRING_START, |
| 102 WILL_REDIRECT_REQUEST, |
| 103 DEFERRING_REDIRECT, |
| 104 CANCELING, |
| 105 WILL_PROCESS_RESPONSE, |
| 106 DEFERRING_RESPONSE, |
| 107 READY_TO_COMMIT, |
| 108 DID_COMMIT, |
| 109 DID_COMMIT_ERROR_PAGE, |
| 110 }; |
| 111 |
97 // NavigationHandle implementation: | 112 // NavigationHandle implementation: |
98 const GURL& GetURL() override; | 113 const GURL& GetURL() override; |
99 SiteInstance* GetStartingSiteInstance() override; | 114 SiteInstance* GetStartingSiteInstance() override; |
100 bool IsInMainFrame() override; | 115 bool IsInMainFrame() override; |
101 bool IsParentMainFrame() override; | 116 bool IsParentMainFrame() override; |
102 bool IsRendererInitiated() override; | 117 bool IsRendererInitiated() override; |
103 bool WasServerRedirect() override; | 118 bool WasServerRedirect() override; |
104 const std::vector<GURL>& GetRedirectChain() override; | 119 const std::vector<GURL>& GetRedirectChain() override; |
105 int GetFrameTreeNodeId() override; | 120 int GetFrameTreeNodeId() override; |
106 int GetParentFrameTreeNodeId() override; | 121 int GetParentFrameTreeNodeId() override; |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
142 const std::string& raw_response_header) override; | 157 const std::string& raw_response_header) override; |
143 void CallDidCommitNavigationForTesting(const GURL& url) override; | 158 void CallDidCommitNavigationForTesting(const GURL& url) override; |
144 bool WasStartedFromContextMenu() const override; | 159 bool WasStartedFromContextMenu() const override; |
145 const GURL& GetSearchableFormURL() override; | 160 const GURL& GetSearchableFormURL() override; |
146 const std::string& GetSearchableFormEncoding() override; | 161 const std::string& GetSearchableFormEncoding() override; |
147 ReloadType GetReloadType() override; | 162 ReloadType GetReloadType() override; |
148 const GlobalRequestID& GetGlobalRequestID() override; | 163 const GlobalRequestID& GetGlobalRequestID() override; |
149 | 164 |
150 NavigationData* GetNavigationData() override; | 165 NavigationData* GetNavigationData() override; |
151 | 166 |
| 167 // Used in tests. |
| 168 State state_for_testing() const { return state_; } |
| 169 |
152 // The NavigatorDelegate to notify/query for various navigation events. | 170 // The NavigatorDelegate to notify/query for various navigation events. |
153 // Normally this is the WebContents, except if this NavigationHandle was | 171 // Normally this is the WebContents, except if this NavigationHandle was |
154 // created during a navigation to an interstitial page. In this case it will | 172 // created during a navigation to an interstitial page. In this case it will |
155 // be the InterstitialPage itself. | 173 // be the InterstitialPage itself. |
156 // | 174 // |
157 // Note: due to the interstitial navigation case, all calls that can possibly | 175 // Note: due to the interstitial navigation case, all calls that can possibly |
158 // expose the NavigationHandle to code outside of content/ MUST go though the | 176 // expose the NavigationHandle to code outside of content/ MUST go though the |
159 // NavigatorDelegate. In particular, the ContentBrowserClient should not be | 177 // NavigatorDelegate. In particular, the ContentBrowserClient should not be |
160 // called directly form the NavigationHandle code. Thus, these calls will not | 178 // called directly form the NavigationHandle code. Thus, these calls will not |
161 // expose the NavigationHandle when navigating to an InterstialPage. | 179 // expose the NavigationHandle when navigating to an InterstialPage. |
(...skipping 160 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
322 } | 340 } |
323 | 341 |
324 void set_response_headers_for_testing( | 342 void set_response_headers_for_testing( |
325 scoped_refptr<net::HttpResponseHeaders> response_headers) { | 343 scoped_refptr<net::HttpResponseHeaders> response_headers) { |
326 response_headers_ = response_headers; | 344 response_headers_ = response_headers; |
327 } | 345 } |
328 | 346 |
329 private: | 347 private: |
330 friend class NavigationHandleImplTest; | 348 friend class NavigationHandleImplTest; |
331 | 349 |
332 // Used to track the state the navigation is currently in. | |
333 enum State { | |
334 INITIAL = 0, | |
335 WILL_SEND_REQUEST, | |
336 DEFERRING_START, | |
337 WILL_REDIRECT_REQUEST, | |
338 DEFERRING_REDIRECT, | |
339 CANCELING, | |
340 WILL_PROCESS_RESPONSE, | |
341 DEFERRING_RESPONSE, | |
342 READY_TO_COMMIT, | |
343 DID_COMMIT, | |
344 DID_COMMIT_ERROR_PAGE, | |
345 }; | |
346 | |
347 NavigationHandleImpl(const GURL& url, | 350 NavigationHandleImpl(const GURL& url, |
348 const std::vector<GURL>& redirect_chain, | 351 const std::vector<GURL>& redirect_chain, |
349 FrameTreeNode* frame_tree_node, | 352 FrameTreeNode* frame_tree_node, |
350 bool is_renderer_initiated, | 353 bool is_renderer_initiated, |
351 bool is_same_page, | 354 bool is_same_page, |
352 const base::TimeTicks& navigation_start, | 355 const base::TimeTicks& navigation_start, |
353 int pending_nav_entry_id, | 356 int pending_nav_entry_id, |
354 bool started_from_context_menu); | 357 bool started_from_context_menu); |
355 | 358 |
356 NavigationThrottle::ThrottleCheckResult CheckWillStartRequest(); | 359 NavigationThrottle::ThrottleCheckResult CheckWillStartRequest(); |
(...skipping 134 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
491 NavigationType navigation_type_; | 494 NavigationType navigation_type_; |
492 | 495 |
493 base::WeakPtrFactory<NavigationHandleImpl> weak_factory_; | 496 base::WeakPtrFactory<NavigationHandleImpl> weak_factory_; |
494 | 497 |
495 DISALLOW_COPY_AND_ASSIGN(NavigationHandleImpl); | 498 DISALLOW_COPY_AND_ASSIGN(NavigationHandleImpl); |
496 }; | 499 }; |
497 | 500 |
498 } // namespace content | 501 } // namespace content |
499 | 502 |
500 #endif // CONTENT_BROWSER_FRAME_HOST_NAVIGATION_HANDLE_IMPL_H_ | 503 #endif // CONTENT_BROWSER_FRAME_HOST_NAVIGATION_HANDLE_IMPL_H_ |
OLD | NEW |