| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #include "net/proxy/proxy_config_service_linux.h" | 5 #include "net/proxy/proxy_config_service_linux.h" |
| 6 | 6 |
| 7 #include <map> | 7 #include <map> |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 56 // integers | 56 // integers |
| 57 int http_port, secure_port, ftp_port, socks_port; | 57 int http_port, secure_port, ftp_port, socks_port; |
| 58 // booleans | 58 // booleans |
| 59 BoolSettingValue use_proxy, same_proxy, use_auth; | 59 BoolSettingValue use_proxy, same_proxy, use_auth; |
| 60 // string list | 60 // string list |
| 61 std::vector<std::string> ignore_hosts; | 61 std::vector<std::string> ignore_hosts; |
| 62 }; | 62 }; |
| 63 | 63 |
| 64 // Mapping from a setting name to the location of the corresponding | 64 // Mapping from a setting name to the location of the corresponding |
| 65 // value (inside a EnvVarValues or GConfValues struct). | 65 // value (inside a EnvVarValues or GConfValues struct). |
| 66 template<typename value_type> | 66 template<typename key_type, typename value_type> |
| 67 struct SettingsTable { | 67 struct SettingsTable { |
| 68 typedef ProxyConfigServiceLinux::SettingGetter::Setting Setting; | 68 typedef std::map<key_type, value_type*> map_type; |
| 69 typedef std::map<Setting, value_type*> map_type; | |
| 70 | 69 |
| 71 // Gets the value from its location | 70 // Gets the value from its location |
| 72 value_type Get(Setting key) { | 71 value_type Get(key_type key) { |
| 73 typename map_type::const_iterator it = settings.find(key); | 72 typename map_type::const_iterator it = settings.find(key); |
| 74 // In case there's a typo or the unittest becomes out of sync. | 73 // In case there's a typo or the unittest becomes out of sync. |
| 75 CHECK(it != settings.end()) << "key " << key << " not found"; | 74 CHECK(it != settings.end()) << "key " << key << " not found"; |
| 76 value_type* value_ptr = it->second; | 75 value_type* value_ptr = it->second; |
| 77 return *value_ptr; | 76 return *value_ptr; |
| 78 } | 77 } |
| 79 | 78 |
| 80 map_type settings; | 79 map_type settings; |
| 81 }; | 80 }; |
| 82 | 81 |
| (...skipping 103 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 186 } | 185 } |
| 187 | 186 |
| 188 virtual MessageLoop* GetNotificationLoop() { | 187 virtual MessageLoop* GetNotificationLoop() { |
| 189 return NULL; | 188 return NULL; |
| 190 } | 189 } |
| 191 | 190 |
| 192 virtual const char* GetDataSource() { | 191 virtual const char* GetDataSource() { |
| 193 return "test"; | 192 return "test"; |
| 194 } | 193 } |
| 195 | 194 |
| 196 virtual bool GetString(Setting key, std::string* result) { | 195 virtual bool GetString(StringSetting key, std::string* result) { |
| 197 const char* value = strings_table.Get(key); | 196 const char* value = strings_table.Get(key); |
| 198 if (value) { | 197 if (value) { |
| 199 *result = value; | 198 *result = value; |
| 200 return true; | 199 return true; |
| 201 } | 200 } |
| 202 return false; | 201 return false; |
| 203 } | 202 } |
| 204 | 203 |
| 205 virtual bool GetInt(Setting key, int* result) { | 204 virtual bool GetBool(BoolSetting key, bool* result) { |
| 206 // We don't bother to distinguish unset keys from 0 values. | |
| 207 *result = ints_table.Get(key); | |
| 208 return true; | |
| 209 } | |
| 210 | |
| 211 virtual bool GetBool(Setting key, bool* result) { | |
| 212 BoolSettingValue value = bools_table.Get(key); | 205 BoolSettingValue value = bools_table.Get(key); |
| 213 switch (value) { | 206 switch (value) { |
| 214 case UNSET: | 207 case UNSET: |
| 215 return false; | 208 return false; |
| 216 case TRUE: | 209 case TRUE: |
| 217 *result = true; | 210 *result = true; |
| 218 break; | 211 break; |
| 219 case FALSE: | 212 case FALSE: |
| 220 *result = false; | 213 *result = false; |
| 221 } | 214 } |
| 222 return true; | 215 return true; |
| 223 } | 216 } |
| 224 | 217 |
| 225 virtual bool GetStringList(Setting key, std::vector<std::string>* result) { | 218 virtual bool GetInt(IntSetting key, int* result) { |
| 219 // We don't bother to distinguish unset keys from 0 values. |
| 220 *result = ints_table.Get(key); |
| 221 return true; |
| 222 } |
| 223 |
| 224 virtual bool GetStringList(StringListSetting key, |
| 225 std::vector<std::string>* result) { |
| 226 *result = string_lists_table.Get(key); | 226 *result = string_lists_table.Get(key); |
| 227 // We don't bother to distinguish unset keys from empty lists. | 227 // We don't bother to distinguish unset keys from empty lists. |
| 228 return !result->empty(); | 228 return !result->empty(); |
| 229 } | 229 } |
| 230 | 230 |
| 231 virtual bool BypassListIsReversed() { | 231 virtual bool BypassListIsReversed() { |
| 232 return false; | 232 return false; |
| 233 } | 233 } |
| 234 | 234 |
| 235 virtual bool MatchHostsUsingSuffixMatching() { | 235 virtual bool MatchHostsUsingSuffixMatching() { |
| 236 return false; | 236 return false; |
| 237 } | 237 } |
| 238 | 238 |
| 239 // Intentionally public, for convenience when setting up a test. | 239 // Intentionally public, for convenience when setting up a test. |
| 240 GConfValues values; | 240 GConfValues values; |
| 241 | 241 |
| 242 private: | 242 private: |
| 243 SettingsTable<const char*> strings_table; | 243 SettingsTable<StringSetting, const char*> strings_table; |
| 244 SettingsTable<int> ints_table; | 244 SettingsTable<BoolSetting, BoolSettingValue> bools_table; |
| 245 SettingsTable<BoolSettingValue> bools_table; | 245 SettingsTable<IntSetting, int> ints_table; |
| 246 SettingsTable<std::vector<std::string> > string_lists_table; | 246 SettingsTable<StringListSetting, |
| 247 std::vector<std::string> > string_lists_table; |
| 247 }; | 248 }; |
| 248 | 249 |
| 249 } // namespace | 250 } // namespace |
| 250 } // namespace net | 251 } // namespace net |
| 251 | 252 |
| 252 // This helper class runs ProxyConfigServiceLinux::GetLatestProxyConfig() on | 253 // This helper class runs ProxyConfigServiceLinux::GetLatestProxyConfig() on |
| 253 // the IO thread and synchronously waits for the result. | 254 // the IO thread and synchronously waits for the result. |
| 254 // Some code duplicated from proxy_script_fetcher_unittest.cc. | 255 // Some code duplicated from proxy_script_fetcher_unittest.cc. |
| 255 class SynchConfigGetter { | 256 class SynchConfigGetter { |
| 256 public: | 257 public: |
| (...skipping 1281 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1538 ProxyConfig config; | 1539 ProxyConfig config; |
| 1539 sync_config_getter.SetupAndInitialFetch(); | 1540 sync_config_getter.SetupAndInitialFetch(); |
| 1540 EXPECT_EQ(ProxyConfigService::CONFIG_VALID, | 1541 EXPECT_EQ(ProxyConfigService::CONFIG_VALID, |
| 1541 sync_config_getter.SyncGetLatestProxyConfig(&config)); | 1542 sync_config_getter.SyncGetLatestProxyConfig(&config)); |
| 1542 EXPECT_TRUE(config.auto_detect()); | 1543 EXPECT_TRUE(config.auto_detect()); |
| 1543 EXPECT_EQ(GURL(), config.pac_url()); | 1544 EXPECT_EQ(GURL(), config.pac_url()); |
| 1544 } | 1545 } |
| 1545 } | 1546 } |
| 1546 | 1547 |
| 1547 } // namespace net | 1548 } // namespace net |
| OLD | NEW |