blob: ec1dc6e1725631537d7b110bf5e7a445d945885b [file] [log] [blame]
[email protected]3b63f8f42011-03-28 01:54:151// Copyright (c) 2011 The Chromium Authors. All rights reserved.
[email protected]1152b7e2009-09-14 03:26:032// 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_BROWSER_MAIN_H_
6#define CHROME_BROWSER_BROWSER_MAIN_H_
[email protected]32b76ef2010-07-26 23:08:247#pragma once
[email protected]1152b7e2009-09-14 03:26:038
[email protected]f8abf722010-07-07 19:46:249#include "base/basictypes.h"
[email protected]5e6efa52011-06-27 17:26:4110#include "base/gtest_prod_util.h"
[email protected]3b63f8f42011-03-28 01:54:1511#include "base/memory/scoped_ptr.h"
[email protected]835d7c82010-10-14 04:38:3812#include "base/metrics/field_trial.h"
[email protected]f8abf722010-07-07 19:46:2413#include "base/tracked_objects.h"
14
[email protected]092b04e2010-10-12 23:23:4415class BrowserThread;
[email protected]f8abf722010-07-07 19:46:2416class CommandLine;
[email protected]0f247aea82011-09-03 03:05:5117class HistogramSynchronizer;
[email protected]edafd4c2011-05-10 17:18:5318class FieldTrialSynchronizer;
[email protected]1fec64352010-07-27 13:55:2119class HighResolutionTimerManager;
[email protected]1152b7e2009-09-14 03:26:0320struct MainFunctionParams;
[email protected]1fec64352010-07-27 13:55:2121class MessageLoop;
[email protected]1152b7e2009-09-14 03:26:0322class MetricsService;
[email protected]edafd4c2011-05-10 17:18:5323class PrefService;
[email protected]1fec64352010-07-27 13:55:2124
[email protected]e41d7dd2011-05-18 07:29:5625namespace base {
26class SystemMonitor;
[email protected]4ae61df2011-01-19 15:29:4727}
28
[email protected]e41d7dd2011-05-18 07:29:5629namespace net {
30class NetworkChangeNotifier;
[email protected]5f988b92011-05-18 07:14:0831}
32
[email protected]cbce47242011-08-12 21:40:5933namespace chrome_browser {
34// For use by ShowMissingLocaleMessageBox.
35extern const char kMissingLocaleDataTitle[];
36extern const char kMissingLocaleDataMessage[];
37}
38
[email protected]f8abf722010-07-07 19:46:2439// BrowserMainParts:
40// This class contains different "stages" to be executed in |BrowserMain()|,
41// mostly initialization. This is made into a class rather than just functions
42// so each stage can create and maintain state. Each part is represented by a
43// single method (e.g., "EarlyInitialization()"), which does the following:
44// - calls a method (e.g., "PreEarlyInitialization()") which individual
45// platforms can override to provide platform-specific code which is to be
46// executed before the common code;
47// - calls various methods for things common to all platforms (for that given
48// stage); and
49// - calls a method (e.g., "PostEarlyInitialization()") for platform-specific
50// code to be called after the common code.
51// As indicated above, platforms should override the default "Pre...()" and
52// "Post...()" methods when necessary; they need not call the superclass's
53// implementation (which is empty).
54//
55// Parts:
56// - EarlyInitialization: things which should be done as soon as possible on
57// program start (such as setting up signal handlers) and things to be done
58// at some generic time before the start of the main message loop.
[email protected]1fec64352010-07-27 13:55:2159// - MainMessageLoopStart: things beginning with the start of the main message
60// loop and ending with initialization of the main thread; platform-specific
61// things which should be done immediately before the start of the main
62// message loop should go in |PreMainMessageLoopStart()|.
[email protected]f8abf722010-07-07 19:46:2463// - (more to come)
[email protected]d7dbe28c2010-07-29 04:33:4764//
65// How to add stuff (to existing parts):
66// - Figure out when your new code should be executed. What must happen
67// before/after your code is executed? Are there performance reasons for
68// running your code at a particular time? Document these things!
69// - Split out any platform-specific bits. Please avoid #ifdefs it at all
70// possible. You have two choices for platform-specific code: (1) Execute it
71// from one of the platform-specific |Pre/Post...()| methods; do this if the
72// code is unique to a platform type. Or (2) execute it from one of the
73// "parts" (e.g., |EarlyInitialization()|) and provide platform-specific
74// implementations of your code (in a virtual method); do this if you need to
75// provide different implementations across most/all platforms.
76// - Unless your new code is just one or two lines, put it into a separate
77// method with a well-defined purpose. (Likewise, if you're adding to an
78// existing chunk which makes it longer than one or two lines, please move
79// the code out into a separate method.)
[email protected]f8abf722010-07-07 19:46:2480class BrowserMainParts {
81 public:
82 // This static method is to be implemented by each platform and should
83 // instantiate the appropriate subclass.
84 static BrowserMainParts* CreateBrowserMainParts(
85 const MainFunctionParams& parameters);
86
[email protected]1fec64352010-07-27 13:55:2187 virtual ~BrowserMainParts();
88
[email protected]f8abf722010-07-07 19:46:2489 // Parts to be called by |BrowserMain()|.
90 void EarlyInitialization();
[email protected]1fec64352010-07-27 13:55:2191 void MainMessageLoopStart();
[email protected]f8abf722010-07-07 19:46:2492
[email protected]0f247aea82011-09-03 03:05:5193 // Constructs HistogramSynchronizer which gets released early (before
94 // main_message_loop_).
95 void SetupHistogramSynchronizer();
96
[email protected]edafd4c2011-05-10 17:18:5397 // Constructs metrics service and does related initialization, including
98 // creation of field trials. Call only after labs have been converted to
99 // switches.
100 MetricsService* SetupMetricsAndFieldTrials(
101 const CommandLine& parsed_command_line,
102 PrefService* local_state);
[email protected]68adccab2011-01-26 21:18:13103
[email protected]f8abf722010-07-07 19:46:24104 protected:
105 explicit BrowserMainParts(const MainFunctionParams& parameters);
106
[email protected]f8abf722010-07-07 19:46:24107 // Accessors for data members (below) ----------------------------------------
108 const MainFunctionParams& parameters() const {
109 return parameters_;
110 }
111 const CommandLine& parsed_command_line() const {
112 return parsed_command_line_;
113 }
[email protected]1fec64352010-07-27 13:55:21114 MessageLoop& main_message_loop() const {
115 return *main_message_loop_;
116 }
[email protected]f8abf722010-07-07 19:46:24117
[email protected]c1275ae2010-07-12 17:40:49118 // Methods to be overridden to provide platform-specific code; these
119 // correspond to the "parts" above.
120 virtual void PreEarlyInitialization() {}
121 virtual void PostEarlyInitialization() {}
[email protected]1fec64352010-07-27 13:55:21122 virtual void PreMainMessageLoopStart() {}
123 virtual void PostMainMessageLoopStart() {}
[email protected]c1275ae2010-07-12 17:40:49124
[email protected]1fec64352010-07-27 13:55:21125 private:
[email protected]f8abf722010-07-07 19:46:24126 // Methods for |EarlyInitialization()| ---------------------------------------
127
128 // A/B test for the maximum number of persistent connections per host.
129 void ConnectionFieldTrial();
130
131 // A/B test for determining a value for unused socket timeout.
132 void SocketTimeoutFieldTrial();
133
[email protected]78a258a2010-08-02 16:34:26134 // A/B test for the maximum number of connections per proxy server.
135 void ProxyConnectionsFieldTrial();
136
[email protected]f8abf722010-07-07 19:46:24137 // A/B test for spdy when --use-spdy not set.
138 void SpdyFieldTrial();
139
[email protected]6930c522011-07-28 22:15:19140 // A/B test for warmest socket vs. most recently used socket.
141 void WarmConnectionFieldTrial();
142
[email protected]06d94042010-08-25 01:45:22143 // A/B test for automatically establishing a backup TCP connection when a
144 // specified timeout value is reached.
145 void ConnectBackupJobsFieldTrial();
146
[email protected]6930c522011-07-28 22:15:19147 // A/B test for using a different host prefix in Google search suggest.
148 void SuggestPrefixFieldTrial();
[email protected]5e6efa52011-06-27 17:26:41149
[email protected]f8abf722010-07-07 19:46:24150 // Used to initialize NSPR where appropriate.
[email protected]d7dbe28c2010-07-29 04:33:47151 virtual void InitializeSSL() = 0;
[email protected]f8abf722010-07-07 19:46:24152
[email protected]1fec64352010-07-27 13:55:21153 // Methods for |MainMessageLoopStart()| --------------------------------------
154
155 void InitializeMainThread();
156
[email protected]edafd4c2011-05-10 17:18:53157 // Methods for |SetupMetricsAndFieldTrials()| --------------------------------
158
159 static MetricsService* InitializeMetrics(
160 const CommandLine& parsed_command_line,
161 const PrefService* local_state);
162
163 // Add an invocation of your field trial init function to this method.
[email protected]12c84e22011-07-11 09:35:45164 void SetupFieldTrials(bool metrics_recording_enabled,
165 bool proxy_policy_is_set);
[email protected]edafd4c2011-05-10 17:18:53166
[email protected]f8abf722010-07-07 19:46:24167 // Members initialized on construction ---------------------------------------
168
169 const MainFunctionParams& parameters_;
170 const CommandLine& parsed_command_line_;
171
172#if defined(TRACK_ALL_TASK_OBJECTS)
173 // Creating this object starts tracking the creation and deletion of Task
174 // instance. This MUST be done before main_message_loop, so that it is
175 // destroyed after the main_message_loop.
176 tracked_objects::AutoTracking tracking_objects_;
177#endif
178
[email protected]edafd4c2011-05-10 17:18:53179 // Statistical testing infrastructure for the entire browser. NULL until
180 // SetupMetricsAndFieldTrials is called.
181 scoped_ptr<base::FieldTrialList> field_trial_list_;
[email protected]f8abf722010-07-07 19:46:24182
[email protected]1fec64352010-07-27 13:55:21183 // Members initialized in |MainMessageLoopStart()| ---------------------------
184 scoped_ptr<MessageLoop> main_message_loop_;
[email protected]e41d7dd2011-05-18 07:29:56185 scoped_ptr<base::SystemMonitor> system_monitor_;
[email protected]1fec64352010-07-27 13:55:21186 scoped_ptr<HighResolutionTimerManager> hi_res_timer_manager_;
187 scoped_ptr<net::NetworkChangeNotifier> network_change_notifier_;
[email protected]092b04e2010-10-12 23:23:44188 scoped_ptr<BrowserThread> main_thread_;
[email protected]1fec64352010-07-27 13:55:21189
[email protected]0f247aea82011-09-03 03:05:51190 // Members initialized after / released before main_message_loop_ ------------
191
192 // Initialized in SetupHistogramSynchronizer.
193 scoped_refptr<HistogramSynchronizer> histogram_synchronizer_;
194
[email protected]edafd4c2011-05-10 17:18:53195 // Initialized in SetupMetricsAndFieldTrials.
196 scoped_refptr<FieldTrialSynchronizer> field_trial_synchronizer_;
197
[email protected]5e6efa52011-06-27 17:26:41198 FRIEND_TEST(BrowserMainTest, WarmConnectionFieldTrial_WarmestSocket);
199 FRIEND_TEST(BrowserMainTest, WarmConnectionFieldTrial_Random);
200 FRIEND_TEST(BrowserMainTest, WarmConnectionFieldTrial_Invalid);
[email protected]f8abf722010-07-07 19:46:24201 DISALLOW_COPY_AND_ASSIGN(BrowserMainParts);
202};
203
204
[email protected]1152b7e2009-09-14 03:26:03205// Perform platform-specific work that needs to be done after the main event
206// loop has ended.
[email protected]3b6aa8b62009-09-15 21:36:11207void DidEndMainMessageLoop();
[email protected]1152b7e2009-09-14 03:26:03208
209// Records the conditions that can prevent Breakpad from generating and
210// sending crash reports. The presence of a Breakpad handler (after
211// attempting to initialize crash reporting) and the presence of a debugger
212// are registered with the UMA metrics service.
213void RecordBreakpadStatusUMA(MetricsService* metrics);
214
[email protected]34f73fb2010-03-24 20:50:34215// Displays a warning message if some minimum level of OS support is not
216// present on the current platform.
217void WarnAboutMinimumSystemRequirements();
[email protected]1152b7e2009-09-14 03:26:03218
[email protected]cbce47242011-08-12 21:40:59219// Displays a warning message that we can't find any locale data files.
220void ShowMissingLocaleMessageBox();
221
[email protected]45d72762011-04-15 18:58:20222// Records the time from our process' startup to the present time in
223// the UMA histogram |metric_name|.
224void RecordBrowserStartupTime();
225
[email protected]28f576f2011-08-26 20:46:55226// Records a time value to an UMA histogram in the context of the
227// PreReadExperiment field-trial. This also reports to the appropriate
228// sub-histogram (_PreRead(Enabled|Disabled)).
229void RecordPreReadExperimentTime(const char* name, base::TimeDelta time);
230
[email protected]1152b7e2009-09-14 03:26:03231#endif // CHROME_BROWSER_BROWSER_MAIN_H_