| 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 "mojo/application/application_runner_chromium.h" | 6 #include "mojo/application/application_runner_chromium.h" |
| 7 #include "mojo/public/c/system/main.h" | 7 #include "mojo/public/c/system/main.h" |
| 8 #include "mojo/public/cpp/application/application_connection.h" | 8 #include "mojo/public/cpp/application/application_connection.h" |
| 9 #include "mojo/public/cpp/application/application_delegate.h" | 9 #include "mojo/public/cpp/application/application_delegate.h" |
| 10 #include "mojo/public/cpp/application/interface_factory.h" | |
| 11 #include "mojo/services/files/interfaces/files.mojom.h" | 10 #include "mojo/services/files/interfaces/files.mojom.h" |
| 12 #include "services/files/files_impl.h" | 11 #include "services/files/files_impl.h" |
| 13 | 12 |
| 14 namespace mojo { | 13 namespace mojo { |
| 15 namespace files { | 14 namespace files { |
| 16 | 15 |
| 17 class FilesApp : public ApplicationDelegate, public InterfaceFactory<Files> { | 16 class FilesApp : public ApplicationDelegate { |
| 18 public: | 17 public: |
| 19 FilesApp() {} | 18 FilesApp() {} |
| 20 ~FilesApp() override {} | 19 ~FilesApp() override {} |
| 21 | 20 |
| 22 private: | 21 private: |
| 23 // |ApplicationDelegate| override: | 22 // |ApplicationDelegate| override: |
| 24 bool ConfigureIncomingConnection(ApplicationConnection* connection) override { | 23 bool ConfigureIncomingConnection(ApplicationConnection* connection) override { |
| 25 connection->AddService<Files>(this); | 24 connection->GetServiceProviderImpl().AddService<Files>( |
| 25 [](const ConnectionContext& connection_context, |
| 26 InterfaceRequest<Files> files_request) { |
| 27 new FilesImpl(connection_context, files_request.Pass()); |
| 28 }); |
| 26 return true; | 29 return true; |
| 27 } | 30 } |
| 28 | 31 |
| 29 // |InterfaceFactory<Files>| implementation: | |
| 30 void Create(const ConnectionContext& connection_context, | |
| 31 InterfaceRequest<Files> request) override { | |
| 32 new FilesImpl(connection_context, request.Pass()); | |
| 33 } | |
| 34 | |
| 35 DISALLOW_COPY_AND_ASSIGN(FilesApp); | 32 DISALLOW_COPY_AND_ASSIGN(FilesApp); |
| 36 }; | 33 }; |
| 37 | 34 |
| 38 } // namespace files | 35 } // namespace files |
| 39 } // namespace mojo | 36 } // namespace mojo |
| 40 | 37 |
| 41 MojoResult MojoMain(MojoHandle application_request) { | 38 MojoResult MojoMain(MojoHandle application_request) { |
| 42 mojo::ApplicationRunnerChromium runner(new mojo::files::FilesApp()); | 39 mojo::ApplicationRunnerChromium runner(new mojo::files::FilesApp()); |
| 43 return runner.Run(application_request); | 40 return runner.Run(application_request); |
| 44 } | 41 } |
| OLD | NEW |