| OLD | NEW |
| 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 Loading... |
| 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 } |
| OLD | NEW |