| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "content/child/child_thread_impl.h" | 5 #include "content/child/child_thread_impl.h" |
| 6 | 6 |
| 7 #include <signal.h> | 7 #include <signal.h> |
| 8 | 8 |
| 9 #include <string> | 9 #include <string> |
| 10 | 10 |
| (...skipping 192 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 203 return ChildThreadImpl::current(); | 203 return ChildThreadImpl::current(); |
| 204 } | 204 } |
| 205 | 205 |
| 206 ChildThreadImpl::Options::Options() | 206 ChildThreadImpl::Options::Options() |
| 207 : channel_name(base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII( | 207 : channel_name(base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII( |
| 208 switches::kProcessChannelID)), | 208 switches::kProcessChannelID)), |
| 209 use_mojo_channel(false), | 209 use_mojo_channel(false), |
| 210 in_browser_process(false) { | 210 in_browser_process(false) { |
| 211 } | 211 } |
| 212 | 212 |
| 213 ChildThreadImpl::Options::Options(bool mojo) | |
| 214 : channel_name(base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII( | |
| 215 switches::kProcessChannelID)), | |
| 216 use_mojo_channel(mojo), | |
| 217 in_browser_process(true) { | |
| 218 } | |
| 219 | |
| 220 ChildThreadImpl::Options::Options(std::string name, bool mojo) | |
| 221 : channel_name(name), use_mojo_channel(mojo), in_browser_process(true) { | |
| 222 } | |
| 223 | |
| 224 ChildThreadImpl::Options::~Options() { | 213 ChildThreadImpl::Options::~Options() { |
| 225 } | 214 } |
| 226 | 215 |
| 216 ChildThreadImpl::Options::Builder::Builder() { |
| 217 } |
| 218 |
| 219 ChildThreadImpl::Options::Builder& |
| 220 ChildThreadImpl::Options::Builder::InBrowserProcess(bool in_browser_process) { |
| 221 options_.in_browser_process = in_browser_process; |
| 222 return *this; |
| 223 } |
| 224 |
| 225 ChildThreadImpl::Options::Builder& |
| 226 ChildThreadImpl::Options::Builder::UseMojoChannel(bool use_mojo_channel) { |
| 227 options_.use_mojo_channel = use_mojo_channel; |
| 228 return *this; |
| 229 } |
| 230 |
| 231 ChildThreadImpl::Options::Builder& |
| 232 ChildThreadImpl::Options::Builder::WithChannelName( |
| 233 const std::string& channel_name) { |
| 234 options_.channel_name = channel_name; |
| 235 return *this; |
| 236 } |
| 237 |
| 238 ChildThreadImpl::Options::Builder& |
| 239 ChildThreadImpl::Options::Builder::AddStartupFilter( |
| 240 IPC::MessageFilter* filter) { |
| 241 options_.startup_filters.push_back(filter); |
| 242 return *this; |
| 243 } |
| 244 |
| 245 ChildThreadImpl::Options ChildThreadImpl::Options::Builder::Build() { |
| 246 return options_; |
| 247 } |
| 248 |
| 227 ChildThreadImpl::ChildThreadMessageRouter::ChildThreadMessageRouter( | 249 ChildThreadImpl::ChildThreadMessageRouter::ChildThreadMessageRouter( |
| 228 IPC::Sender* sender) | 250 IPC::Sender* sender) |
| 229 : sender_(sender) {} | 251 : sender_(sender) {} |
| 230 | 252 |
| 231 bool ChildThreadImpl::ChildThreadMessageRouter::Send(IPC::Message* msg) { | 253 bool ChildThreadImpl::ChildThreadMessageRouter::Send(IPC::Message* msg) { |
| 232 return sender_->Send(msg); | 254 return sender_->Send(msg); |
| 233 } | 255 } |
| 234 | 256 |
| 235 ChildThreadImpl::ChildThreadImpl() | 257 ChildThreadImpl::ChildThreadImpl() |
| 236 : router_(this), | 258 : router_(this), |
| 237 in_browser_process_(false), | 259 in_browser_process_(false), |
| 238 channel_connected_factory_(this) { | 260 channel_connected_factory_(this) { |
| 239 Init(Options()); | 261 Init(Options::Builder().Build()); |
| 240 } | 262 } |
| 241 | 263 |
| 242 ChildThreadImpl::ChildThreadImpl(const Options& options) | 264 ChildThreadImpl::ChildThreadImpl(const Options& options) |
| 243 : router_(this), | 265 : router_(this), |
| 244 in_browser_process_(options.in_browser_process), | 266 in_browser_process_(options.in_browser_process), |
| 245 channel_connected_factory_(this) { | 267 channel_connected_factory_(this) { |
| 246 Init(options); | 268 Init(options); |
| 247 } | 269 } |
| 248 | 270 |
| 249 void ChildThreadImpl::ConnectChannel(bool use_mojo_channel) { | 271 void ChildThreadImpl::ConnectChannel(bool use_mojo_channel) { |
| (...skipping 413 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 663 // doesn't cause such issues. TODO(gab): Remove this once the experiment is | 685 // doesn't cause such issues. TODO(gab): Remove this once the experiment is |
| 664 // over (http://crbug.com/458594). | 686 // over (http://crbug.com/458594). |
| 665 base::FieldTrial* trial = | 687 base::FieldTrial* trial = |
| 666 base::FieldTrialList::Find("BackgroundRendererProcesses"); | 688 base::FieldTrialList::Find("BackgroundRendererProcesses"); |
| 667 if (trial && trial->group_name() == "AllowBackgroundModeFromRenderer") | 689 if (trial && trial->group_name() == "AllowBackgroundModeFromRenderer") |
| 668 base::Process::Current().SetProcessBackgrounded(background); | 690 base::Process::Current().SetProcessBackgrounded(background); |
| 669 #endif // OS_WIN | 691 #endif // OS_WIN |
| 670 } | 692 } |
| 671 | 693 |
| 672 } // namespace content | 694 } // namespace content |
| OLD | NEW |