OLD | NEW |
(Empty) | |
| 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 |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #ifndef CHROME_BROWSER_NET_PREDICTION_OPTIONS_H_ |
| 6 #define CHROME_BROWSER_NET_PREDICTION_OPTIONS_H_ |
| 7 |
| 8 namespace user_prefs { |
| 9 class PrefRegistrySyncable; |
| 10 } |
| 11 |
| 12 namespace content { |
| 13 class ResourceContext; |
| 14 } |
| 15 |
| 16 class PrefService; |
| 17 |
| 18 namespace chrome_browser_net { |
| 19 |
| 20 // Enum describing when to allow network predictions based on connection type. |
| 21 // The numerical value is stored in the prefs file, therefore the same enum |
| 22 // with the same order must be used by the platform-dependent components. |
| 23 // TODO(bnc): implement as per crbug.com/334602. |
| 24 // NETWORK_PREDICTION_UNSET means that the old preferences, |
| 25 // kNetworkPredictionEnabled and kAllowPrerender, should be observed. |
| 26 enum NetworkPredictionOptions { |
| 27 NETWORK_PREDICTION_ALWAYS, |
| 28 NETWORK_PREDICTION_WIFI_ONLY, |
| 29 NETWORK_PREDICTION_NEVER, |
| 30 NETWORK_PREDICTION_UNSET, |
| 31 }; |
| 32 |
| 33 void RegisterPredictionOptionsProfilePrefs( |
| 34 user_prefs::PrefRegistrySyncable* registry); |
| 35 |
| 36 // The following two global functions determine whether predictive network |
| 37 // actions are enabled, based on preferences and network type. |
| 38 |
| 39 // To be executed on the IO thread only. |
| 40 bool CanPredictNetworkActionsIO(content::ResourceContext* resource_context); |
| 41 |
| 42 // To be executed on the UI thread only. |
| 43 bool CanPredictNetworkActionsUI(PrefService* prefs); |
| 44 |
| 45 } // namespace chrome_browser_net |
| 46 |
| 47 #endif // CHROME_BROWSER_NET_PREDICTION_OPTIONS_H_ |
OLD | NEW |