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 "chrome/browser/browser_main.h" | 5 #include "chrome/browser/browser_main.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <string> | 8 #include <string> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
49 #include "chrome/browser/net/chrome_dns_cert_provenance_checker.h" | 49 #include "chrome/browser/net/chrome_dns_cert_provenance_checker.h" |
50 #include "chrome/browser/net/chrome_dns_cert_provenance_checker_factory.h" | 50 #include "chrome/browser/net/chrome_dns_cert_provenance_checker_factory.h" |
51 #include "chrome/browser/net/metadata_url_request.h" | 51 #include "chrome/browser/net/metadata_url_request.h" |
52 #include "chrome/browser/net/predictor_api.h" | 52 #include "chrome/browser/net/predictor_api.h" |
53 #include "chrome/browser/net/sdch_dictionary_fetcher.h" | 53 #include "chrome/browser/net/sdch_dictionary_fetcher.h" |
54 #include "chrome/browser/net/websocket_experiment/websocket_experiment_runner.h" | 54 #include "chrome/browser/net/websocket_experiment/websocket_experiment_runner.h" |
55 #include "chrome/browser/plugin_service.h" | 55 #include "chrome/browser/plugin_service.h" |
56 #include "chrome/browser/prefs/browser_prefs.h" | 56 #include "chrome/browser/prefs/browser_prefs.h" |
57 #include "chrome/browser/prefs/pref_service.h" | 57 #include "chrome/browser/prefs/pref_service.h" |
58 #include "chrome/browser/prefs/pref_value_store.h" | 58 #include "chrome/browser/prefs/pref_value_store.h" |
| 59 #include "chrome/browser/prerender/prerender_manager.h" |
59 #include "chrome/browser/printing/cloud_print/cloud_print_proxy_service.h" | 60 #include "chrome/browser/printing/cloud_print/cloud_print_proxy_service.h" |
60 #include "chrome/browser/printing/print_dialog_cloud.h" | 61 #include "chrome/browser/printing/print_dialog_cloud.h" |
61 #include "chrome/browser/process_singleton.h" | 62 #include "chrome/browser/process_singleton.h" |
62 #include "chrome/browser/profiles/profile.h" | 63 #include "chrome/browser/profiles/profile.h" |
63 #include "chrome/browser/profiles/profile_manager.h" | 64 #include "chrome/browser/profiles/profile_manager.h" |
64 #include "chrome/browser/renderer_host/resource_dispatcher_host.h" | 65 #include "chrome/browser/renderer_host/resource_dispatcher_host.h" |
65 #include "chrome/browser/search_engines/search_engine_type.h" | 66 #include "chrome/browser/search_engines/search_engine_type.h" |
66 #include "chrome/browser/search_engines/template_url.h" | 67 #include "chrome/browser/search_engines/template_url.h" |
67 #include "chrome/browser/search_engines/template_url_model.h" | 68 #include "chrome/browser/search_engines/template_url_model.h" |
68 #include "chrome/browser/service/service_process_control.h" | 69 #include "chrome/browser/service/service_process_control.h" |
(...skipping 148 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
217 PostEarlyInitialization(); | 218 PostEarlyInitialization(); |
218 } | 219 } |
219 | 220 |
220 // This will be called after the command-line has been mutated by about:flags | 221 // This will be called after the command-line has been mutated by about:flags |
221 void BrowserMainParts::SetupFieldTrials() { | 222 void BrowserMainParts::SetupFieldTrials() { |
222 // Note: make sure to call ConnectionFieldTrial() before | 223 // Note: make sure to call ConnectionFieldTrial() before |
223 // ProxyConnectionsFieldTrial(). | 224 // ProxyConnectionsFieldTrial(). |
224 ConnectionFieldTrial(); | 225 ConnectionFieldTrial(); |
225 SocketTimeoutFieldTrial(); | 226 SocketTimeoutFieldTrial(); |
226 ProxyConnectionsFieldTrial(); | 227 ProxyConnectionsFieldTrial(); |
227 PrefetchFieldTrial(); | 228 PrefetchAndPrerenderFieldTrial(); |
228 SpdyFieldTrial(); | 229 SpdyFieldTrial(); |
229 ConnectBackupJobsFieldTrial(); | 230 ConnectBackupJobsFieldTrial(); |
230 } | 231 } |
231 | 232 |
232 // This is an A/B test for the maximum number of persistent connections per | 233 // This is an A/B test for the maximum number of persistent connections per |
233 // host. Currently Chrome, Firefox, and IE8 have this value set at 6. Safari | 234 // host. Currently Chrome, Firefox, and IE8 have this value set at 6. Safari |
234 // uses 4, and Fasterfox (a plugin for Firefox that supposedly configures it to | 235 // uses 4, and Fasterfox (a plugin for Firefox that supposedly configures it to |
235 // run faster) uses 8. We would like to see how much of an effect this value has | 236 // run faster) uses 8. We would like to see how much of an effect this value has |
236 // on browsing. Too large a value might cause us to run into SYN flood detection | 237 // on browsing. Too large a value might cause us to run into SYN flood detection |
237 // mechanisms. | 238 // mechanisms. |
(...skipping 184 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
422 &value); | 423 &value); |
423 if (value > 0) | 424 if (value > 0) |
424 net::SpdySession::set_max_concurrent_streams(value); | 425 net::SpdySession::set_max_concurrent_streams(value); |
425 } | 426 } |
426 } | 427 } |
427 | 428 |
428 // If any of --enable-prerender, --enable-content-prefetch or | 429 // If any of --enable-prerender, --enable-content-prefetch or |
429 // --disable-content-prefetch are set, use those to determine if | 430 // --disable-content-prefetch are set, use those to determine if |
430 // prefetch is enabled. Otherwise, randomly assign users to an A/B test for | 431 // prefetch is enabled. Otherwise, randomly assign users to an A/B test for |
431 // prefetching. | 432 // prefetching. |
432 void BrowserMainParts::PrefetchFieldTrial() { | 433 void BrowserMainParts::PrefetchAndPrerenderFieldTrial() { |
433 if (parsed_command_line().HasSwitch(switches::kEnableContentPrefetch) || | 434 if (parsed_command_line().HasSwitch(switches::kEnableContentPrefetch) || |
434 parsed_command_line().HasSwitch(switches::kEnablePagePrerender)) | 435 parsed_command_line().HasSwitch(switches::kEnablePagePrerender)) |
435 ResourceDispatcherHost::set_is_prefetch_enabled(true); | 436 ResourceDispatcherHost::set_is_prefetch_enabled(true); |
436 else if (parsed_command_line().HasSwitch(switches::kDisableContentPrefetch)) { | 437 else if (parsed_command_line().HasSwitch(switches::kDisableContentPrefetch)) { |
437 ResourceDispatcherHost::set_is_prefetch_enabled(false); | 438 ResourceDispatcherHost::set_is_prefetch_enabled(false); |
438 } else { | 439 } else { |
439 const base::FieldTrial::Probability kPrefetchDivisor = 1000; | 440 const base::FieldTrial::Probability kPrefetchDivisor = 1000; |
440 const base::FieldTrial::Probability no_prefetch_probability = 500; | 441 const base::FieldTrial::Probability no_prefetch_probability = 500; |
441 // After June 30, 2011 builds, it will always be in default group. | 442 // After June 30, 2011 builds, it will always be in default group. |
442 scoped_refptr<base::FieldTrial> trial( | 443 scoped_refptr<base::FieldTrial> trial( |
443 new base::FieldTrial("Prefetch", kPrefetchDivisor, | 444 new base::FieldTrial("Prefetch", kPrefetchDivisor, |
444 "ContentPrefetchEnabled", 2011, 6, 30)); | 445 "ContentPrefetchEnabled", 2011, 6, 30)); |
445 const int yes_prefetch_grp = trial->kDefaultGroupNumber; | 446 const int yes_prefetch_grp = trial->kDefaultGroupNumber; |
446 trial->AppendGroup("ContentPrefetchDisabled", no_prefetch_probability); | 447 trial->AppendGroup("ContentPrefetchDisabled", no_prefetch_probability); |
447 const int trial_grp = trial->group(); | 448 const int trial_grp = trial->group(); |
448 ResourceDispatcherHost::set_is_prefetch_enabled( | 449 ResourceDispatcherHost::set_is_prefetch_enabled( |
449 trial_grp == yes_prefetch_grp); | 450 trial_grp == yes_prefetch_grp); |
450 } | 451 } |
| 452 |
| 453 PrerenderManager::PrerenderManagerMode prerender_mode = |
| 454 PrerenderManager::PRERENDER_MODE_DISABLED; |
| 455 if (parsed_command_line().HasSwitch(switches::kEnablePagePrerender)) |
| 456 prerender_mode = PrerenderManager::PRERENDER_MODE_ENABLED; |
| 457 else |
| 458 prerender_mode = PrerenderManager::PRERENDER_MODE_DISABLED; |
| 459 PrerenderManager::SetMode(prerender_mode); |
| 460 |
| 461 UMA_HISTOGRAM_ENUMERATION("Prerender.Sessions", prerender_mode, |
| 462 PrerenderManager::PRERENDER_MODE_MAX); |
451 } | 463 } |
452 | 464 |
453 // If neither --enable-connect-backup-jobs or --disable-connect-backup-jobs is | 465 // If neither --enable-connect-backup-jobs or --disable-connect-backup-jobs is |
454 // specified, run an A/B test for automatically establishing backup TCP | 466 // specified, run an A/B test for automatically establishing backup TCP |
455 // connections when a certain timeout value is exceeded. | 467 // connections when a certain timeout value is exceeded. |
456 void BrowserMainParts::ConnectBackupJobsFieldTrial() { | 468 void BrowserMainParts::ConnectBackupJobsFieldTrial() { |
457 if (parsed_command_line().HasSwitch(switches::kEnableConnectBackupJobs)) { | 469 if (parsed_command_line().HasSwitch(switches::kEnableConnectBackupJobs)) { |
458 net::internal::ClientSocketPoolBaseHelper::set_connect_backup_jobs_enabled( | 470 net::internal::ClientSocketPoolBaseHelper::set_connect_backup_jobs_enabled( |
459 true); | 471 true); |
460 } else if (parsed_command_line().HasSwitch( | 472 } else if (parsed_command_line().HasSwitch( |
(...skipping 1324 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1785 #if defined(OS_CHROMEOS) | 1797 #if defined(OS_CHROMEOS) |
1786 // To be precise, logout (browser shutdown) is not yet done, but the | 1798 // To be precise, logout (browser shutdown) is not yet done, but the |
1787 // remaining work is negligible, hence we say LogoutDone here. | 1799 // remaining work is negligible, hence we say LogoutDone here. |
1788 chromeos::BootTimesLoader::Get()->AddLogoutTimeMarker("LogoutDone", | 1800 chromeos::BootTimesLoader::Get()->AddLogoutTimeMarker("LogoutDone", |
1789 false); | 1801 false); |
1790 chromeos::BootTimesLoader::Get()->WriteLogoutTimes(); | 1802 chromeos::BootTimesLoader::Get()->WriteLogoutTimes(); |
1791 #endif | 1803 #endif |
1792 TRACE_EVENT_END("BrowserMain", 0, 0); | 1804 TRACE_EVENT_END("BrowserMain", 0, 0); |
1793 return result_code; | 1805 return result_code; |
1794 } | 1806 } |
OLD | NEW |