OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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_REQUEST_H_ | 5 #ifndef CONTENT_BROWSER_FRAME_HOST_NAVIGATION_REQUEST_H_ |
6 #define CONTENT_BROWSER_FRAME_HOST_NAVIGATION_REQUEST_H_ | 6 #define CONTENT_BROWSER_FRAME_HOST_NAVIGATION_REQUEST_H_ |
7 | 7 |
8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
9 #include "base/memory/ref_counted.h" | 9 #include "base/memory/ref_counted.h" |
| 10 #include "content/browser/frame_host/navigation_entry_impl.h" |
10 #include "content/browser/frame_host/navigation_request_info.h" | 11 #include "content/browser/frame_host/navigation_request_info.h" |
11 | 12 |
12 namespace content { | 13 namespace content { |
13 class ResourceRequestBody; | 14 class ResourceRequestBody; |
14 | 15 |
| 16 // PlzNavigate |
15 // A UI thread object that owns a navigation request until it commits. It | 17 // A UI thread object that owns a navigation request until it commits. It |
16 // ensures the UI thread can start a navigation request in the | 18 // ensures the UI thread can start a navigation request in the |
17 // ResourceDispatcherHost (that lives on the IO thread). | 19 // ResourceDispatcherHost (that lives on the IO thread). |
18 // TODO(clamy): Describe the interactions between the UI and IO thread during | 20 // TODO(clamy): Describe the interactions between the UI and IO thread during |
19 // the navigation following its refactoring. | 21 // the navigation following its refactoring. |
20 class NavigationRequest { | 22 class NavigationRequest { |
21 public: | 23 public: |
22 NavigationRequest(const NavigationRequestInfo& info, int64 frame_node_id); | 24 NavigationRequest(const NavigationRequestInfo& info, |
| 25 const NavigationEntryImpl& entry, |
| 26 int64 frame_node_id); |
23 | 27 |
24 ~NavigationRequest(); | 28 ~NavigationRequest(); |
25 | 29 |
26 const NavigationRequestInfo& info_for_testing() const { return info_; } | 30 const NavigationRequestInfo& info_for_testing() const { return info_; } |
| 31 const NavigationEntryImpl& entry() const { return entry_; } |
27 int64 frame_node_id() const { return frame_node_id_; } | 32 int64 frame_node_id() const { return frame_node_id_; } |
28 | 33 |
29 // Called on the UI thread by the RenderFrameHostManager which owns the | 34 // Called on the UI thread by the RenderFrameHostManager which owns the |
30 // NavigationRequest. After calling this function, |body| can no longer be | 35 // NavigationRequest. After calling this function, |body| can no longer be |
31 // manipulated on the UI thread. | 36 // manipulated on the UI thread. |
32 void BeginNavigation(scoped_refptr<ResourceRequestBody> body); | 37 void BeginNavigation(scoped_refptr<ResourceRequestBody> body); |
33 | 38 |
| 39 // Change the url of entry_ to |final_url|, that the url the browser navigated |
| 40 // to after the chain of redirects. |
| 41 void UpdateEntryForCommit(const GURL& final_url); |
| 42 |
34 private: | 43 private: |
35 const NavigationRequestInfo info_; | 44 const NavigationRequestInfo info_; |
| 45 NavigationEntryImpl entry_; |
36 const int64 frame_node_id_; | 46 const int64 frame_node_id_; |
37 | 47 |
38 DISALLOW_COPY_AND_ASSIGN(NavigationRequest); | 48 DISALLOW_COPY_AND_ASSIGN(NavigationRequest); |
39 }; | 49 }; |
40 | 50 |
41 } // namespace content | 51 } // namespace content |
42 | 52 |
43 #endif // CONTENT_BROWSER_FRAME_HOST_NAVIGATION_REQUEST_H_ | 53 #endif // CONTENT_BROWSER_FRAME_HOST_NAVIGATION_REQUEST_H_ |
OLD | NEW |