| 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_COMMON_NAVIGATION_PARAMS_H_ | 5 #ifndef CONTENT_COMMON_NAVIGATION_PARAMS_H_ |
| 6 #define CONTENT_COMMON_NAVIGATION_PARAMS_H_ | 6 #define CONTENT_COMMON_NAVIGATION_PARAMS_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| 11 #include "base/time/time.h" | 11 #include "base/time/time.h" |
| 12 #include "content/common/content_export.h" | 12 #include "content/common/content_export.h" |
| 13 #include "content/common/frame_message_enums.h" | 13 #include "content/common/frame_message_enums.h" |
| 14 #include "content/public/common/page_state.h" | 14 #include "content/public/common/page_state.h" |
| 15 #include "content/public/common/referrer.h" | 15 #include "content/public/common/referrer.h" |
| 16 #include "ui/base/page_transition_types.h" | 16 #include "ui/base/page_transition_types.h" |
| 17 #include "url/gurl.h" | 17 #include "url/gurl.h" |
| 18 | 18 |
| 19 namespace base { | 19 namespace base { |
| 20 class RefCountedMemory; | 20 class RefCountedMemory; |
| 21 } | 21 } |
| 22 | 22 |
| 23 namespace content { | 23 namespace content { |
| 24 | 24 |
| 25 // The LoFi state which determines whether to add the LoFi header. Must stay in |
| 26 // sync with the enum in data_reduction_proxy_lofi_helper.h. |
| 27 enum LoFiState { |
| 28 // Request a LoFi version of the resource. |
| 29 LOFI_ON = 0, |
| 30 // Request a normal (non-LoFi) version of the resource. |
| 31 LOFI_OFF, |
| 32 // Let the browser process decide whether or not to request the LoFi version. |
| 33 LOFI_DEFAULT, |
| 34 }; |
| 35 |
| 25 // PlzNavigate | 36 // PlzNavigate |
| 26 // Helper function to determine if the navigation to |url| should make a request | 37 // Helper function to determine if the navigation to |url| should make a request |
| 27 // to the network stack. A request should not be sent for data URLs, JavaScript | 38 // to the network stack. A request should not be sent for data URLs, JavaScript |
| 28 // URLs or about:blank. In these cases, no request needs to be sent. | 39 // URLs or about:blank. In these cases, no request needs to be sent. |
| 29 bool ShouldMakeNetworkRequestForURL(const GURL& url); | 40 bool ShouldMakeNetworkRequestForURL(const GURL& url); |
| 30 | 41 |
| 31 // The following structures hold parameters used during a navigation. In | 42 // The following structures hold parameters used during a navigation. In |
| 32 // particular they are used by FrameMsg_Navigate, FrameMsg_CommitNavigation and | 43 // particular they are used by FrameMsg_Navigate, FrameMsg_CommitNavigation and |
| 33 // FrameHostMsg_BeginNavigation. | 44 // FrameHostMsg_BeginNavigation. |
| 34 | 45 |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 82 // The report type to be used when recording the metric using |ui_timestamp|. | 93 // The report type to be used when recording the metric using |ui_timestamp|. |
| 83 FrameMsg_UILoadMetricsReportType::Value report_type; | 94 FrameMsg_UILoadMetricsReportType::Value report_type; |
| 84 | 95 |
| 85 // Base URL for use in Blink's SubstituteData. | 96 // Base URL for use in Blink's SubstituteData. |
| 86 // Is only used with data: URLs. | 97 // Is only used with data: URLs. |
| 87 GURL base_url_for_data_url; | 98 GURL base_url_for_data_url; |
| 88 | 99 |
| 89 // History URL for use in Blink's SubstituteData. | 100 // History URL for use in Blink's SubstituteData. |
| 90 // Is only used with data: URLs. | 101 // Is only used with data: URLs. |
| 91 GURL history_url_for_data_url; | 102 GURL history_url_for_data_url; |
| 103 |
| 104 // Whether or not to request a LoFi version of the document or let the browser |
| 105 // decide. |
| 106 LoFiState lofi_state; |
| 92 }; | 107 }; |
| 93 | 108 |
| 94 // Provided by the renderer ---------------------------------------------------- | 109 // Provided by the renderer ---------------------------------------------------- |
| 95 // | 110 // |
| 96 // This struct holds parameters sent by the renderer to the browser. It is only | 111 // This struct holds parameters sent by the renderer to the browser. It is only |
| 97 // used in PlzNavigate (since in the current architecture, the renderer does not | 112 // used in PlzNavigate (since in the current architecture, the renderer does not |
| 98 // inform the browser of navigations until they commit). | 113 // inform the browser of navigations until they commit). |
| 99 | 114 |
| 100 // This struct is not used outside of the PlzNavigate project. | 115 // This struct is not used outside of the PlzNavigate project. |
| 101 // PlzNavigate: parameters needed to start a navigation on the IO thread, | 116 // PlzNavigate: parameters needed to start a navigation on the IO thread, |
| (...skipping 166 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 268 ~NavigationParams(); | 283 ~NavigationParams(); |
| 269 | 284 |
| 270 CommonNavigationParams common_params; | 285 CommonNavigationParams common_params; |
| 271 StartNavigationParams start_params; | 286 StartNavigationParams start_params; |
| 272 RequestNavigationParams request_params; | 287 RequestNavigationParams request_params; |
| 273 }; | 288 }; |
| 274 | 289 |
| 275 } // namespace content | 290 } // namespace content |
| 276 | 291 |
| 277 #endif // CONTENT_COMMON_NAVIGATION_PARAMS_H_ | 292 #endif // CONTENT_COMMON_NAVIGATION_PARAMS_H_ |
| OLD | NEW |