OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 // PageNavigator defines an interface that can be used to express the user's | 5 // PageNavigator defines an interface that can be used to express the user's |
6 // intention to navigate to a particular URL. The implementing class should | 6 // intention to navigate to a particular URL. The implementing class should |
7 // perform the navigation. | 7 // perform the navigation. |
8 | 8 |
9 #ifndef CONTENT_PUBLIC_BROWSER_PAGE_NAVIGATOR_H_ | 9 #ifndef CONTENT_PUBLIC_BROWSER_PAGE_NAVIGATOR_H_ |
10 #define CONTENT_PUBLIC_BROWSER_PAGE_NAVIGATOR_H_ | 10 #define CONTENT_PUBLIC_BROWSER_PAGE_NAVIGATOR_H_ |
(...skipping 15 matching lines...) Expand all Loading... |
26 | 26 |
27 struct CONTENT_EXPORT OpenURLParams { | 27 struct CONTENT_EXPORT OpenURLParams { |
28 OpenURLParams(const GURL& url, | 28 OpenURLParams(const GURL& url, |
29 const Referrer& referrer, | 29 const Referrer& referrer, |
30 WindowOpenDisposition disposition, | 30 WindowOpenDisposition disposition, |
31 PageTransition transition, | 31 PageTransition transition, |
32 bool is_renderer_initiated); | 32 bool is_renderer_initiated); |
33 OpenURLParams(const GURL& url, | 33 OpenURLParams(const GURL& url, |
34 const Referrer& referrer, | 34 const Referrer& referrer, |
35 int64 source_frame_id, | 35 int64 source_frame_id, |
| 36 int64 frame_tree_node_id, |
36 WindowOpenDisposition disposition, | 37 WindowOpenDisposition disposition, |
37 PageTransition transition, | 38 PageTransition transition, |
38 bool is_renderer_initiated); | 39 bool is_renderer_initiated); |
39 ~OpenURLParams(); | 40 ~OpenURLParams(); |
40 | 41 |
41 // The URL/referrer to be opened. | 42 // The URL/referrer to be opened. |
42 GURL url; | 43 GURL url; |
43 Referrer referrer; | 44 Referrer referrer; |
44 | 45 |
45 // Any redirect URLs that occurred for this navigation before |url|. | 46 // Any redirect URLs that occurred for this navigation before |url|. |
46 std::vector<GURL> redirect_chain; | 47 std::vector<GURL> redirect_chain; |
47 | 48 |
48 // Indicates whether this navigation will be sent using POST. | 49 // Indicates whether this navigation will be sent using POST. |
49 // The POST method is limited support for basic POST data by leveraging | 50 // The POST method is limited support for basic POST data by leveraging |
50 // NavigationController::LOAD_TYPE_BROWSER_INITIATED_HTTP_POST. | 51 // NavigationController::LOAD_TYPE_BROWSER_INITIATED_HTTP_POST. |
51 // It is not for things like file uploads. | 52 // It is not for things like file uploads. |
52 bool uses_post; | 53 bool uses_post; |
53 | 54 |
54 // The post data when the navigation uses POST. | 55 // The post data when the navigation uses POST. |
55 scoped_refptr<base::RefCountedMemory> browser_initiated_post_data; | 56 scoped_refptr<base::RefCountedMemory> browser_initiated_post_data; |
56 | 57 |
57 // Extra headers to add to the request for this page. Headers are | 58 // Extra headers to add to the request for this page. Headers are |
58 // represented as "<name>: <value>" and separated by \r\n. The entire string | 59 // represented as "<name>: <value>" and separated by \r\n. The entire string |
59 // is terminated by \r\n. May be empty if no extra headers are needed. | 60 // is terminated by \r\n. May be empty if no extra headers are needed. |
60 std::string extra_headers; | 61 std::string extra_headers; |
61 | 62 |
62 // The source frame id or -1 to indicate the main frame. | 63 // The renderer-specific source frame id or -1 to indicate the main frame. |
63 int64 source_frame_id; | 64 int64 source_frame_id; |
64 | 65 |
| 66 // The browser-global FrameTreeNode ID or -1 to indicate the main frame. |
| 67 int64 frame_tree_node_id; |
| 68 |
65 // The disposition requested by the navigation source. | 69 // The disposition requested by the navigation source. |
66 WindowOpenDisposition disposition; | 70 WindowOpenDisposition disposition; |
67 | 71 |
68 // The transition type of navigation. | 72 // The transition type of navigation. |
69 PageTransition transition; | 73 PageTransition transition; |
70 | 74 |
71 // Whether this navigation is initiated by the renderer process. | 75 // Whether this navigation is initiated by the renderer process. |
72 bool is_renderer_initiated; | 76 bool is_renderer_initiated; |
73 | 77 |
74 // Reference to the old request id in case this is a navigation that is being | 78 // Reference to the old request id in case this is a navigation that is being |
(...skipping 19 matching lines...) Expand all Loading... |
94 // Opens a URL with the given disposition. The transition specifies how this | 98 // Opens a URL with the given disposition. The transition specifies how this |
95 // navigation should be recorded in the history system (for example, typed). | 99 // navigation should be recorded in the history system (for example, typed). |
96 // Returns the WebContents the URL is opened in, or NULL if the URL wasn't | 100 // Returns the WebContents the URL is opened in, or NULL if the URL wasn't |
97 // opened immediately. | 101 // opened immediately. |
98 virtual WebContents* OpenURL(const OpenURLParams& params) = 0; | 102 virtual WebContents* OpenURL(const OpenURLParams& params) = 0; |
99 }; | 103 }; |
100 | 104 |
101 } // namespace content | 105 } // namespace content |
102 | 106 |
103 #endif // CONTENT_PUBLIC_BROWSER_PAGE_NAVIGATOR_H_ | 107 #endif // CONTENT_PUBLIC_BROWSER_PAGE_NAVIGATOR_H_ |
OLD | NEW |