• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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
3 // found in the LICENSE file.
4 
5 #ifndef CHROME_BROWSER_BROWSER_MAIN_H_
6 #define CHROME_BROWSER_BROWSER_MAIN_H_
7 #pragma once
8 
9 #include "base/basictypes.h"
10 #include "base/memory/scoped_ptr.h"
11 #include "base/metrics/field_trial.h"
12 #include "base/tracked_objects.h"
13 
14 class BrowserThread;
15 class CommandLine;
16 class HighResolutionTimerManager;
17 struct MainFunctionParams;
18 class MessageLoop;
19 class MetricsService;
20 
21 namespace net {
22 class NetworkChangeNotifier;
23 }
24 
25 namespace ui {
26 class SystemMonitor;
27 }
28 
29 // BrowserMainParts:
30 // This class contains different "stages" to be executed in |BrowserMain()|,
31 // mostly initialization. This is made into a class rather than just functions
32 // so each stage can create and maintain state. Each part is represented by a
33 // single method (e.g., "EarlyInitialization()"), which does the following:
34 //  - calls a method (e.g., "PreEarlyInitialization()") which individual
35 //    platforms can override to provide platform-specific code which is to be
36 //    executed before the common code;
37 //  - calls various methods for things common to all platforms (for that given
38 //    stage); and
39 //  - calls a method (e.g., "PostEarlyInitialization()") for platform-specific
40 //    code to be called after the common code.
41 // As indicated above, platforms should override the default "Pre...()" and
42 // "Post...()" methods when necessary; they need not call the superclass's
43 // implementation (which is empty).
44 //
45 // Parts:
46 //  - EarlyInitialization: things which should be done as soon as possible on
47 //    program start (such as setting up signal handlers) and things to be done
48 //    at some generic time before the start of the main message loop.
49 //  - MainMessageLoopStart: things beginning with the start of the main message
50 //    loop and ending with initialization of the main thread; platform-specific
51 //    things which should be done immediately before the start of the main
52 //    message loop should go in |PreMainMessageLoopStart()|.
53 //  - (more to come)
54 //
55 // How to add stuff (to existing parts):
56 //  - Figure out when your new code should be executed. What must happen
57 //    before/after your code is executed? Are there performance reasons for
58 //    running your code at a particular time? Document these things!
59 //  - Split out any platform-specific bits. Please avoid #ifdefs it at all
60 //    possible. You have two choices for platform-specific code: (1) Execute it
61 //    from one of the platform-specific |Pre/Post...()| methods; do this if the
62 //    code is unique to a platform type. Or (2) execute it from one of the
63 //    "parts" (e.g., |EarlyInitialization()|) and provide platform-specific
64 //    implementations of your code (in a virtual method); do this if you need to
65 //    provide different implementations across most/all platforms.
66 //  - Unless your new code is just one or two lines, put it into a separate
67 //    method with a well-defined purpose. (Likewise, if you're adding to an
68 //    existing chunk which makes it longer than one or two lines, please move
69 //    the code out into a separate method.)
70 class BrowserMainParts {
71  public:
72   // This static method is to be implemented by each platform and should
73   // instantiate the appropriate subclass.
74   static BrowserMainParts* CreateBrowserMainParts(
75       const MainFunctionParams& parameters);
76 
77   virtual ~BrowserMainParts();
78 
79   // Parts to be called by |BrowserMain()|.
80   void EarlyInitialization();
81   void MainMessageLoopStart();
82 
83   void SetupFieldTrials();
84 
85  protected:
86   explicit BrowserMainParts(const MainFunctionParams& parameters);
87 
88   // Accessors for data members (below) ----------------------------------------
parameters()89   const MainFunctionParams& parameters() const {
90     return parameters_;
91   }
parsed_command_line()92   const CommandLine& parsed_command_line() const {
93     return parsed_command_line_;
94   }
main_message_loop()95   MessageLoop& main_message_loop() const {
96     return *main_message_loop_;
97   }
98 
99   // Methods to be overridden to provide platform-specific code; these
100   // correspond to the "parts" above.
PreEarlyInitialization()101   virtual void PreEarlyInitialization() {}
PostEarlyInitialization()102   virtual void PostEarlyInitialization() {}
PreMainMessageLoopStart()103   virtual void PreMainMessageLoopStart() {}
PostMainMessageLoopStart()104   virtual void PostMainMessageLoopStart() {}
105 
106  private:
107   // Methods for |EarlyInitialization()| ---------------------------------------
108 
109   // A/B test for the maximum number of persistent connections per host.
110   void ConnectionFieldTrial();
111 
112   // A/B test for determining a value for unused socket timeout.
113   void SocketTimeoutFieldTrial();
114 
115   // A/B test for the maximum number of connections per proxy server.
116   void ProxyConnectionsFieldTrial();
117 
118   // A/B test for spdy when --use-spdy not set.
119   void SpdyFieldTrial();
120 
121   // A/B test for automatically establishing a backup TCP connection when a
122   // specified timeout value is reached.
123   void ConnectBackupJobsFieldTrial();
124 
125   // A/B test for SSL False Start.
126   void SSLFalseStartFieldTrial();
127 
128   // Used to initialize NSPR where appropriate.
129   virtual void InitializeSSL() = 0;
130 
131   // Methods for |MainMessageLoopStart()| --------------------------------------
132 
133   void InitializeMainThread();
134 
135   // Members initialized on construction ---------------------------------------
136 
137   const MainFunctionParams& parameters_;
138   const CommandLine& parsed_command_line_;
139 
140 #if defined(TRACK_ALL_TASK_OBJECTS)
141   // Creating this object starts tracking the creation and deletion of Task
142   // instance. This MUST be done before main_message_loop, so that it is
143   // destroyed after the main_message_loop.
144   tracked_objects::AutoTracking tracking_objects_;
145 #endif
146 
147   // Statistical testing infrastructure for the entire browser.
148   base::FieldTrialList field_trial_;
149 
150   // Members initialized in |MainMessageLoopStart()| ---------------------------
151   scoped_ptr<MessageLoop> main_message_loop_;
152   scoped_ptr<ui::SystemMonitor> system_monitor_;
153   scoped_ptr<HighResolutionTimerManager> hi_res_timer_manager_;
154   scoped_ptr<net::NetworkChangeNotifier> network_change_notifier_;
155   scoped_ptr<BrowserThread> main_thread_;
156 
157   DISALLOW_COPY_AND_ASSIGN(BrowserMainParts);
158 };
159 
160 
161 // Perform platform-specific work that needs to be done after the main event
162 // loop has ended.
163 void DidEndMainMessageLoop();
164 
165 // Records the conditions that can prevent Breakpad from generating and
166 // sending crash reports.  The presence of a Breakpad handler (after
167 // attempting to initialize crash reporting) and the presence of a debugger
168 // are registered with the UMA metrics service.
169 void RecordBreakpadStatusUMA(MetricsService* metrics);
170 
171 // Displays a warning message if some minimum level of OS support is not
172 // present on the current platform.
173 void WarnAboutMinimumSystemRequirements();
174 
175 // Records the time from our process' startup to the present time in
176 // the UMA histogram |metric_name|.
177 void RecordBrowserStartupTime();
178 
179 #endif  // CHROME_BROWSER_BROWSER_MAIN_H_
180