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 import "mojo/services/public/interfaces/network/url_loader.mojom" | 5 import "mojo/services/public/interfaces/network/url_loader.mojom" |
6 | 6 |
7 module mojo { | 7 module mojo { |
8 | 8 |
9 // Expresses a preference for where a navigation will be performed. | 9 // Expresses a preference for where a navigation will be performed. |
10 enum Target { | 10 enum Target { |
11 // No preference | 11 // No preference |
12 DEFAULT, | 12 DEFAULT, |
13 | 13 |
14 // In the same ViewManager node that the navigation was initiated | 14 // In the same ViewManager node that the navigation was initiated |
15 SOURCE_NODE, | 15 SOURCE_NODE, |
16 | 16 |
17 // In a new ViewManager node | 17 // In a new ViewManager node |
18 NEW_NODE | 18 NEW_NODE |
19 }; | 19 }; |
20 | 20 |
21 struct NavigationDetails { | 21 struct NavigationDetails { |
22 // TODO(mpcomplete): will we ever need more than the URLRequest? Can | 22 // TODO(mpcomplete): will we ever need more than the URLRequest? Can |
23 // we pass that around directly? | 23 // we pass that around directly? |
24 URLRequest request = default; | 24 URLRequest? request = default; |
25 }; | 25 }; |
26 | 26 |
27 struct ResponseDetails { | 27 struct ResponseDetails { |
28 // TODO(beng): consider providing access to URLRequest too. Currently it is | 28 // TODO(beng): consider providing access to URLRequest too. Currently it is |
29 // not possible to obtain from the URLLoader. | 29 // not possible to obtain from the URLLoader. |
30 | 30 |
31 URLResponse response; | 31 URLResponse? response; |
32 | 32 |
33 // The URLLoader instance that generated the response. This must be kept | 33 // The URLLoader instance that generated the response. This must be kept |
34 // alive until the response body has been completely consumed. | 34 // alive until the response body has been completely consumed. |
35 URLLoader loader; | 35 URLLoader? loader; |
36 }; | 36 }; |
37 | 37 |
38 // Embedders that support navigation of implement this interface. | 38 // Embedders that support navigation of implement this interface. |
39 interface NavigatorHost { | 39 interface NavigatorHost { |
40 RequestNavigate(uint32 source_node_id, Target target, | 40 RequestNavigate(uint32 source_node_id, Target target, |
41 NavigationDetails details); | 41 NavigationDetails? details); |
42 | 42 |
43 // Applications call this to inform hosts of navigations they performed | 43 // Applications call this to inform hosts of navigations they performed |
44 // locally. For example, pushState() navigations in an HTML application. | 44 // locally. For example, pushState() navigations in an HTML application. |
45 DidNavigateLocally(uint32 source_node_id, string url); | 45 DidNavigateLocally(uint32 source_node_id, string? url); |
46 }; | 46 }; |
47 | 47 |
48 // Applications implement this interface to support navigation of their views | 48 // Applications implement this interface to support navigation of their views |
49 // by embedders. | 49 // by embedders. |
50 // |response_details| can be NULL when a navigation was not the result of a | 50 // |response_details| can be NULL when a navigation was not the result of a |
51 // network load. | 51 // network load. |
52 interface Navigator { | 52 interface Navigator { |
53 Navigate(uint32 node_id, | 53 Navigate(uint32 node_id, |
54 NavigationDetails navigation_details, | 54 NavigationDetails? navigation_details, |
55 ResponseDetails response_details); | 55 ResponseDetails? response_details); |
56 }; | 56 }; |
57 | 57 |
58 } | 58 } |
OLD | NEW |