| Index: services/shell/public/cpp/lib/service_runner.cc
|
| diff --git a/services/shell/public/cpp/lib/service_runner.cc b/services/shell/public/cpp/lib/service_runner.cc
|
| deleted file mode 100644
|
| index bff97dbe4ec5d31c22417616ec9a4f81656ca532..0000000000000000000000000000000000000000
|
| --- a/services/shell/public/cpp/lib/service_runner.cc
|
| +++ /dev/null
|
| @@ -1,91 +0,0 @@
|
| -// Copyright 2014 The Chromium Authors. All rights reserved.
|
| -// Use of this source code is governed by a BSD-style license that can be
|
| -// found in the LICENSE file.
|
| -
|
| -#include "services/shell/public/cpp/service_runner.h"
|
| -
|
| -#include "base/at_exit.h"
|
| -#include "base/bind.h"
|
| -#include "base/command_line.h"
|
| -#include "base/message_loop/message_loop.h"
|
| -#include "base/process/launch.h"
|
| -#include "base/run_loop.h"
|
| -#include "services/shell/public/cpp/service.h"
|
| -#include "services/shell/public/cpp/service_context.h"
|
| -
|
| -namespace shell {
|
| -
|
| -int g_service_runner_argc;
|
| -const char* const* g_service_runner_argv;
|
| -
|
| -ServiceRunner::ServiceRunner(Service* service)
|
| - : service_(base::WrapUnique(service)),
|
| - message_loop_type_(base::MessageLoop::TYPE_DEFAULT),
|
| - has_run_(false) {}
|
| -
|
| -ServiceRunner::~ServiceRunner() {}
|
| -
|
| -void ServiceRunner::InitBaseCommandLine() {
|
| - base::CommandLine::Init(g_service_runner_argc, g_service_runner_argv);
|
| -}
|
| -
|
| -void ServiceRunner::set_message_loop_type(base::MessageLoop::Type type) {
|
| - DCHECK_NE(base::MessageLoop::TYPE_CUSTOM, type);
|
| - DCHECK(!has_run_);
|
| -
|
| - message_loop_type_ = type;
|
| -}
|
| -
|
| -MojoResult ServiceRunner::Run(MojoHandle service_request_handle,
|
| - bool init_base) {
|
| - DCHECK(!has_run_);
|
| - has_run_ = true;
|
| -
|
| - std::unique_ptr<base::AtExitManager> at_exit;
|
| - if (init_base) {
|
| - InitBaseCommandLine();
|
| - at_exit.reset(new base::AtExitManager);
|
| - }
|
| -
|
| - {
|
| - std::unique_ptr<base::MessageLoop> loop;
|
| - loop.reset(new base::MessageLoop(message_loop_type_));
|
| -
|
| - std::unique_ptr<ServiceContext> context(new ServiceContext(
|
| - service_.get(),
|
| - mojo::MakeRequest<mojom::Service>(mojo::MakeScopedHandle(
|
| - mojo::MessagePipeHandle(service_request_handle)))));
|
| - base::RunLoop run_loop;
|
| - context->SetConnectionLostClosure(run_loop.QuitClosure());
|
| - service_->set_context(std::move(context));
|
| - run_loop.Run();
|
| - // It's very common for the service to cache the app and terminate on
|
| - // errors. If we don't delete the service before the app we run the risk of
|
| - // the service having a stale reference to the app and trying to use it.
|
| - // Note that we destruct the message loop first because that might trigger
|
| - // connection error handlers and they might access objects created by the
|
| - // service.
|
| - loop.reset();
|
| - service_.reset();
|
| - }
|
| - return MOJO_RESULT_OK;
|
| -}
|
| -
|
| -MojoResult ServiceRunner::Run(MojoHandle service_request_handle) {
|
| - bool init_base = true;
|
| - if (base::CommandLine::InitializedForCurrentProcess()) {
|
| - init_base =
|
| - !base::CommandLine::ForCurrentProcess()->HasSwitch("single-process");
|
| - }
|
| - return Run(service_request_handle, init_base);
|
| -}
|
| -
|
| -void ServiceRunner::DestroyServiceContext() {
|
| - service_->set_context(std::unique_ptr<ServiceContext>());
|
| -}
|
| -
|
| -void ServiceRunner::Quit() {
|
| - base::MessageLoop::current()->QuitWhenIdle();
|
| -}
|
| -
|
| -} // namespace shell
|
|
|