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

Side by Side Diff: services/asset_bundle/main.cc

Issue 1979723002: ApplicationConnection devolution, part 3. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 4 years, 7 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 "base/macros.h" 5 #include "base/macros.h"
6 #include "base/threading/sequenced_worker_pool.h" 6 #include "base/threading/sequenced_worker_pool.h"
7 #include "mojo/application/application_runner_chromium.h" 7 #include "mojo/application/application_runner_chromium.h"
8 #include "mojo/public/c/system/main.h" 8 #include "mojo/public/c/system/main.h"
9 #include "mojo/public/cpp/application/application_connection.h" 9 #include "mojo/public/cpp/application/application_connection.h"
10 #include "mojo/public/cpp/application/application_delegate.h" 10 #include "mojo/public/cpp/application/application_delegate.h"
11 #include "services/asset_bundle/asset_unpacker_impl.h" 11 #include "services/asset_bundle/asset_unpacker_impl.h"
12 12
13 namespace mojo { 13 namespace mojo {
14 namespace asset_bundle { 14 namespace asset_bundle {
15 15
16 class AssetBundleApp : public ApplicationDelegate { 16 class AssetBundleApp : public ApplicationDelegate {
17 public: 17 public:
18 AssetBundleApp() {} 18 AssetBundleApp() {}
19 ~AssetBundleApp() override {} 19 ~AssetBundleApp() override {}
20 20
21 private: 21 private:
22 // |ApplicationDelegate| override: 22 // |ApplicationDelegate| override:
23 bool ConfigureIncomingConnection(ApplicationConnection* connection) override { 23 bool ConfigureIncomingConnection(
24 connection->GetServiceProviderImpl().AddService<AssetUnpacker>( 24 ServiceProviderImpl* service_provider_impl) override {
25 service_provider_impl->AddService<AssetUnpacker>(
25 [this](const ConnectionContext& connection_context, 26 [this](const ConnectionContext& connection_context,
26 InterfaceRequest<AssetUnpacker> asset_unpacker_request) { 27 InterfaceRequest<AssetUnpacker> asset_unpacker_request) {
27 // Lazily initialize |sequenced_worker_pool_|. (We can't create it in 28 // Lazily initialize |sequenced_worker_pool_|. (We can't create it in
28 // the constructor, since AtExitManager is only created in 29 // the constructor, since AtExitManager is only created in
29 // ApplicationRunnerChromium::Run().) 30 // ApplicationRunnerChromium::Run().)
30 if (!sequenced_worker_pool_) { 31 if (!sequenced_worker_pool_) {
31 // TODO(vtl): What's the "right" way to choose the maximum number of 32 // TODO(vtl): What's the "right" way to choose the maximum number of
32 // threads? 33 // threads?
33 sequenced_worker_pool_ = 34 sequenced_worker_pool_ =
34 new base::SequencedWorkerPool(4, "AssetBundleWorker"); 35 new base::SequencedWorkerPool(4, "AssetBundleWorker");
(...skipping 15 matching lines...) Expand all
50 }; 51 };
51 52
52 } // namespace asset_bundle 53 } // namespace asset_bundle
53 } // namespace mojo 54 } // namespace mojo
54 55
55 MojoResult MojoMain(MojoHandle application_request) { 56 MojoResult MojoMain(MojoHandle application_request) {
56 mojo::ApplicationRunnerChromium runner( 57 mojo::ApplicationRunnerChromium runner(
57 new mojo::asset_bundle::AssetBundleApp()); 58 new mojo::asset_bundle::AssetBundleApp());
58 return runner.Run(application_request); 59 return runner.Run(application_request);
59 } 60 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698