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_request_info.h" | 10 #include "content/browser/frame_host/navigation_request_info.h" |
| 11 #include "content/common/content_export.h" |
11 | 12 |
12 namespace content { | 13 namespace content { |
13 class ResourceRequestBody; | 14 class ResourceRequestBody; |
14 | 15 |
15 // PlzNavigate | 16 // PlzNavigate |
16 // 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 |
17 // ensures the UI thread can start a navigation request in the | 18 // ensures the UI thread can start a navigation request in the |
18 // ResourceDispatcherHost (that lives on the IO thread). | 19 // ResourceDispatcherHost (that lives on the IO thread). |
19 // 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 |
20 // the navigation following its refactoring. | 21 // the navigation following its refactoring. |
21 class NavigationRequest { | 22 class NavigationRequest { |
22 public: | 23 public: |
23 NavigationRequest(const NavigationRequestInfo& info, int64 frame_node_id); | 24 NavigationRequest(const NavigationRequestInfo& info, |
| 25 int64 frame_tree_node_id); |
24 | 26 |
25 ~NavigationRequest(); | 27 ~NavigationRequest(); |
26 | 28 |
27 const NavigationRequestInfo& info() const { return info_; } | |
28 int64 frame_node_id() const { return frame_node_id_; } | |
29 | |
30 // Called on the UI thread by the RenderFrameHostManager which owns the | 29 // Called on the UI thread by the RenderFrameHostManager which owns the |
31 // NavigationRequest. After calling this function, |body| can no longer be | 30 // NavigationRequest. After calling this function, |body| can no longer be |
32 // manipulated on the UI thread. | 31 // manipulated on the UI thread. |
33 void BeginNavigation(scoped_refptr<ResourceRequestBody> body); | 32 void BeginNavigation(scoped_refptr<ResourceRequestBody> body); |
34 | 33 |
| 34 // Called on the UI thread by the RenderFrameHostManager which owns the |
| 35 // NavigationRequest whenever this navigation request should be canceled. |
| 36 void CancelNavigation(); |
| 37 |
| 38 const NavigationRequestInfo& info() const { return info_; } |
| 39 |
| 40 int64 frame_tree_node_id() const { return frame_tree_node_id_; } |
| 41 |
| 42 int64 navigation_request_id() const { return navigation_request_id_; } |
| 43 |
35 private: | 44 private: |
| 45 const int64 navigation_request_id_; |
36 const NavigationRequestInfo info_; | 46 const NavigationRequestInfo info_; |
37 const int64 frame_node_id_; | 47 const int64 frame_tree_node_id_; |
38 | 48 |
39 DISALLOW_COPY_AND_ASSIGN(NavigationRequest); | 49 DISALLOW_COPY_AND_ASSIGN(NavigationRequest); |
40 }; | 50 }; |
41 | 51 |
42 } // namespace content | 52 } // namespace content |
43 | 53 |
44 #endif // CONTENT_BROWSER_FRAME_HOST_NAVIGATION_REQUEST_H_ | 54 #endif // CONTENT_BROWSER_FRAME_HOST_NAVIGATION_REQUEST_H_ |
OLD | NEW |