Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1110)

Unified Diff: mojo/shell/tests/lifecycle/package.cc

Issue 1877753003: Move mojo\shell to services\shell (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@62scan
Patch Set: . Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: mojo/shell/tests/lifecycle/package.cc
diff --git a/mojo/shell/tests/lifecycle/package.cc b/mojo/shell/tests/lifecycle/package.cc
deleted file mode 100644
index 1314008fa3afd53f60a862f446b0848d372b5569..0000000000000000000000000000000000000000
--- a/mojo/shell/tests/lifecycle/package.cc
+++ /dev/null
@@ -1,152 +0,0 @@
-// Copyright 2016 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 <algorithm>
-
-#include "base/bind.h"
-#include "base/macros.h"
-#include "mojo/public/c/system/main.h"
-#include "mojo/public/cpp/bindings/binding_set.h"
-#include "mojo/shell/public/cpp/application_runner.h"
-#include "mojo/shell/public/cpp/shell_connection.h"
-#include "mojo/shell/public/interfaces/shell_client_factory.mojom.h"
-#include "mojo/shell/tests/lifecycle/app_client.h"
-#include "mojo/shell/tests/lifecycle/lifecycle_unittest.mojom.h"
-
-namespace {
-
-class PackagedApp : public mojo::ShellClient,
- public mojo::InterfaceFactory<LifecycleControl>,
- public LifecycleControl {
- public:
- using DestructCallback = base::Callback<void(PackagedApp*)>;
-
- PackagedApp(mojo::shell::mojom::ShellClientRequest request,
- const DestructCallback& shell_connection_closed_callback,
- const DestructCallback& destruct_callback)
- : connection_(new mojo::ShellConnection(this, std::move(request))),
- shell_connection_closed_callback_(shell_connection_closed_callback),
- destruct_callback_(destruct_callback) {
- bindings_.set_connection_error_handler(base::Bind(&PackagedApp::BindingLost,
- base::Unretained(this)));
- }
- ~PackagedApp() override {
- destruct_callback_.Run(this);
- }
-
- private:
- // mojo::ShellClient:
- bool AcceptConnection(mojo::Connection* connection) override {
- connection->AddInterface<LifecycleControl>(this);
- return true;
- }
-
- // mojo::InterfaceFactory<LifecycleControl>
- void Create(mojo::Connection* connection,
- LifecycleControlRequest request) override {
- bindings_.AddBinding(this, std::move(request));
- }
-
- // LifecycleControl:
- void Ping(const PingCallback& callback) override {
- callback.Run();
- }
- void GracefulQuit() override {
- shell_connection_closed_callback_.Run(this);
- delete this;
- // This will have closed all |bindings_|.
- }
- void Crash() override {
- // When multiple instances are vended from the same package instance, this
- // will cause all instances to be quit.
- exit(1);
- }
- void CloseShellConnection() override {
- shell_connection_closed_callback_.Run(this);
- connection_.reset();
- // This only closed our relationship with the shell, existing |bindings_|
- // remain active.
- }
-
- void BindingLost() {
- if (bindings_.empty())
- delete this;
- }
-
- scoped_ptr<mojo::ShellConnection> connection_;
- mojo::BindingSet<LifecycleControl> bindings_;
- // Run when this object's connection to the shell is closed.
- DestructCallback shell_connection_closed_callback_;
- // Run when this object is destructed.
- DestructCallback destruct_callback_;
-
- DISALLOW_COPY_AND_ASSIGN(PackagedApp);
-};
-
-class Package
- : public mojo::ShellClient,
- public mojo::InterfaceFactory<mojo::shell::mojom::ShellClientFactory>,
- public mojo::shell::mojom::ShellClientFactory {
- public:
- Package() {}
- ~Package() override {}
-
- void set_runner(mojo::ApplicationRunner* runner) {
- app_client_.set_runner(runner);
- }
-
- private:
- // mojo::shell::test::AppClient:
- bool AcceptConnection(mojo::Connection* connection) override {
- connection->AddInterface<mojo::shell::mojom::ShellClientFactory>(this);
- return app_client_.AcceptConnection(connection);
- }
-
- // mojo::InterfaceFactory<mojo::shell::mojom::ShellClientFactory>:
- void Create(mojo::Connection* connection,
- mojo::shell::mojom::ShellClientFactoryRequest request) override {
- bindings_.AddBinding(this, std::move(request));
- }
-
- // mojo::shell::mojom::ShellClientFactory:
- void CreateShellClient(mojo::shell::mojom::ShellClientRequest request,
- const mojo::String& name) override {
- ++shell_connection_refcount_;
- apps_.push_back(
- new PackagedApp(std::move(request),
- base::Bind(&Package::AppShellConnectionClosed,
- base::Unretained(this)),
- base::Bind(&Package::AppDestructed,
- base::Unretained(this))));
- }
-
- void AppShellConnectionClosed(PackagedApp* app) {
- if (!--shell_connection_refcount_)
- app_client_.CloseShellConnection();
- }
-
- void AppDestructed(PackagedApp* app) {
- auto it = std::find(apps_.begin(), apps_.end(), app);
- DCHECK(it != apps_.end());
- apps_.erase(it);
- if (apps_.empty() && base::MessageLoop::current()->is_running())
- base::MessageLoop::current()->QuitWhenIdle();
- }
-
- mojo::shell::test::AppClient app_client_;
- int shell_connection_refcount_ = 0;
- mojo::BindingSet<mojo::shell::mojom::ShellClientFactory> bindings_;
- std::vector<PackagedApp*> apps_;
-
- DISALLOW_COPY_AND_ASSIGN(Package);
-};
-
-} // namespace
-
-MojoResult MojoMain(MojoHandle shell_handle) {
- Package* package = new Package;
- mojo::ApplicationRunner runner(package);
- package->set_runner(&runner);
- return runner.Run(shell_handle);
-}
« no previous file with comments | « mojo/shell/tests/lifecycle/lifecycle_unittest_manifest.json ('k') | mojo/shell/tests/lifecycle/package_app_a_manifest.json » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698