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

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

Issue 1661423002: Solidify Entry discarding logic (NavigationHandle keeps its ID) (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: merge @377292 Created 4 years, 9 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 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 54 matching lines...) Expand 10 before | Expand all | Expand 10 after
65 public: 65 public:
66 // |navigation_start| comes from the DidStartProvisionalLoad IPC, which tracks 66 // |navigation_start| comes from the DidStartProvisionalLoad IPC, which tracks
67 // both renderer-initiated and browser-initiated navigation start. 67 // both renderer-initiated and browser-initiated navigation start.
68 // PlzNavigate: This value always comes from the CommonNavigationParams 68 // PlzNavigate: This value always comes from the CommonNavigationParams
69 // associated with this navigation. 69 // associated with this navigation.
70 static scoped_ptr<NavigationHandleImpl> Create( 70 static scoped_ptr<NavigationHandleImpl> Create(
71 const GURL& url, 71 const GURL& url,
72 FrameTreeNode* frame_tree_node, 72 FrameTreeNode* frame_tree_node,
73 bool is_synchronous, 73 bool is_synchronous,
74 bool is_srcdoc, 74 bool is_srcdoc,
75 const base::TimeTicks& navigation_start); 75 const base::TimeTicks& navigation_start,
76 int pending_nav_entry_id);
76 ~NavigationHandleImpl() override; 77 ~NavigationHandleImpl() override;
77 78
78 // NavigationHandle implementation: 79 // NavigationHandle implementation:
79 const GURL& GetURL() override; 80 const GURL& GetURL() override;
80 bool IsInMainFrame() override; 81 bool IsInMainFrame() override;
81 bool IsParentMainFrame() override; 82 bool IsParentMainFrame() override;
82 bool IsSynchronousNavigation() override; 83 bool IsSynchronousNavigation() override;
83 bool IsSrcdoc() override; 84 bool IsSrcdoc() override;
84 bool WasServerRedirect() override; 85 bool WasServerRedirect() override;
85 int GetFrameTreeNodeId() override; 86 int GetFrameTreeNodeId() override;
(...skipping 27 matching lines...) Expand all
113 bool new_is_external_protocol) override; 114 bool new_is_external_protocol) override;
114 115
115 NavigatorDelegate* GetDelegate() const; 116 NavigatorDelegate* GetDelegate() const;
116 117
117 // Returns the response headers for the request or nullptr if there are none. 118 // Returns the response headers for the request or nullptr if there are none.
118 // This should only be accessed after a redirect was encountered or after the 119 // This should only be accessed after a redirect was encountered or after the
119 // navigation is ready to commit. The headers returned should not be modified, 120 // navigation is ready to commit. The headers returned should not be modified,
120 // as modifications will not be reflected in the network stack. 121 // as modifications will not be reflected in the network stack.
121 const net::HttpResponseHeaders* GetResponseHeaders(); 122 const net::HttpResponseHeaders* GetResponseHeaders();
122 123
124 // Get the unique id from the NavigationEntry associated with this
125 // NavigationHandle. Note that a synchronous, renderer-initiated navigation
126 // will not have a NavigationEntry associated with it, and this will return 0.
127 int pending_nav_entry_id() const { return pending_nav_entry_id_; }
128
123 void set_net_error_code(net::Error net_error_code) { 129 void set_net_error_code(net::Error net_error_code) {
124 net_error_code_ = net_error_code; 130 net_error_code_ = net_error_code;
125 } 131 }
126 132
127 // Returns whether the navigation is currently being transferred from one 133 // Returns whether the navigation is currently being transferred from one
128 // RenderFrameHost to another. In particular, a DidStartProvisionalLoad IPC 134 // RenderFrameHost to another. In particular, a DidStartProvisionalLoad IPC
129 // for the navigation URL, received in the new RenderFrameHost, should not 135 // for the navigation URL, received in the new RenderFrameHost, should not
130 // indicate the start of a new navigation in that case. 136 // indicate the start of a new navigation in that case.
131 bool is_transferring() const { return is_transferring_; } 137 bool is_transferring() const { return is_transferring_; }
132 void set_is_transferring(bool is_transferring) { 138 void set_is_transferring(bool is_transferring) {
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after
215 DEFERRING_RESPONSE, 221 DEFERRING_RESPONSE,
216 READY_TO_COMMIT, 222 READY_TO_COMMIT,
217 DID_COMMIT, 223 DID_COMMIT,
218 DID_COMMIT_ERROR_PAGE, 224 DID_COMMIT_ERROR_PAGE,
219 }; 225 };
220 226
221 NavigationHandleImpl(const GURL& url, 227 NavigationHandleImpl(const GURL& url,
222 FrameTreeNode* frame_tree_node, 228 FrameTreeNode* frame_tree_node,
223 bool is_synchronous, 229 bool is_synchronous,
224 bool is_srcdoc, 230 bool is_srcdoc,
225 const base::TimeTicks& navigation_start); 231 const base::TimeTicks& navigation_start,
232 int pending_nav_entry_id);
226 233
227 NavigationThrottle::ThrottleCheckResult CheckWillStartRequest(); 234 NavigationThrottle::ThrottleCheckResult CheckWillStartRequest();
228 NavigationThrottle::ThrottleCheckResult CheckWillRedirectRequest(); 235 NavigationThrottle::ThrottleCheckResult CheckWillRedirectRequest();
229 NavigationThrottle::ThrottleCheckResult CheckWillProcessResponse(); 236 NavigationThrottle::ThrottleCheckResult CheckWillProcessResponse();
230 237
231 // Helper function to run and reset the |complete_callback_|. This marks the 238 // Helper function to run and reset the |complete_callback_|. This marks the
232 // end of a round of NavigationThrottleChecks. 239 // end of a round of NavigationThrottleChecks.
233 void RunCompleteCallback(NavigationThrottle::ThrottleCheckResult result); 240 void RunCompleteCallback(NavigationThrottle::ThrottleCheckResult result);
234 241
235 // Used in tests. 242 // Used in tests.
(...skipping 26 matching lines...) Expand all
262 269
263 // A list of Throttles registered for this navigation. 270 // A list of Throttles registered for this navigation.
264 ScopedVector<NavigationThrottle> throttles_; 271 ScopedVector<NavigationThrottle> throttles_;
265 272
266 // The index of the next throttle to check. 273 // The index of the next throttle to check.
267 size_t next_index_; 274 size_t next_index_;
268 275
269 // The time this navigation started. 276 // The time this navigation started.
270 const base::TimeTicks navigation_start_; 277 const base::TimeTicks navigation_start_;
271 278
279 // The unique id of the corresponding NavigationEntry.
280 const int pending_nav_entry_id_;
281
272 // This callback will be run when all throttle checks have been performed. 282 // This callback will be run when all throttle checks have been performed.
273 ThrottleChecksFinishedCallback complete_callback_; 283 ThrottleChecksFinishedCallback complete_callback_;
274 284
275 // PlzNavigate 285 // PlzNavigate
276 // Manages the lifetime of a pre-created ServiceWorkerProviderHost until a 286 // Manages the lifetime of a pre-created ServiceWorkerProviderHost until a
277 // corresponding ServiceWorkerNetworkProvider is created in the renderer. 287 // corresponding ServiceWorkerNetworkProvider is created in the renderer.
278 scoped_ptr<ServiceWorkerNavigationHandle> service_worker_handle_; 288 scoped_ptr<ServiceWorkerNavigationHandle> service_worker_handle_;
279 289
280 DISALLOW_COPY_AND_ASSIGN(NavigationHandleImpl); 290 DISALLOW_COPY_AND_ASSIGN(NavigationHandleImpl);
281 }; 291 };
282 292
283 } // namespace content 293 } // namespace content
284 294
285 #endif // CONTENT_BROWSER_FRAME_HOST_NAVIGATION_HANDLE_IMPL_H_ 295 #endif // CONTENT_BROWSER_FRAME_HOST_NAVIGATION_HANDLE_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698