| 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 <memory> |  | 
| 6 |  | 
| 7 #include "base/logging.h" | 5 #include "base/logging.h" | 
| 8 #include "mojo/nacl/nonsfi/file_util.h" | 6 #include "mojo/nacl/nonsfi/file_util.h" | 
| 9 #include "mojo/nacl/nonsfi/nexe_launcher_nonsfi.h" | 7 #include "mojo/nacl/nonsfi/nexe_launcher_nonsfi.h" | 
| 10 #include "mojo/public/c/system/main.h" | 8 #include "mojo/public/c/system/main.h" | 
| 11 #include "mojo/public/cpp/application/application_delegate.h" | 9 #include "mojo/public/cpp/application/application_impl_base.h" | 
| 12 #include "mojo/public/cpp/application/application_runner.h" | 10 #include "mojo/public/cpp/application/run_application.h" | 
| 13 #include "mojo/public/cpp/application/service_provider_impl.h" | 11 #include "mojo/public/cpp/application/service_provider_impl.h" | 
| 14 #include "mojo/public/cpp/bindings/strong_binding.h" | 12 #include "mojo/public/cpp/bindings/strong_binding.h" | 
| 15 #include "services/nacl/nonsfi/kLdNexe.h" | 13 #include "services/nacl/nonsfi/kLdNexe.h" | 
| 16 #include "services/nacl/nonsfi/pnacl_link.mojom.h" | 14 #include "services/nacl/nonsfi/pnacl_link.mojom.h" | 
| 17 | 15 | 
| 18 namespace mojo { | 16 namespace mojo { | 
| 19 namespace nacl { | 17 namespace nacl { | 
| 20 | 18 | 
| 21 class PexeLinkerImpl : public PexeLinkerInit { | 19 class PexeLinkerImpl : public PexeLinkerInit { | 
| 22  public: | 20  public: | 
| 23   void PexeLinkerStart(InterfaceRequest<PexeLinker> linker_request) override { | 21   void PexeLinkerStart(InterfaceRequest<PexeLinker> linker_request) override { | 
| 24     int nexe_fd = ::nacl::DataToTempFileDescriptor(::nacl::kLdNexe); | 22     int nexe_fd = ::nacl::DataToTempFileDescriptor(::nacl::kLdNexe); | 
| 25     CHECK(nexe_fd >= 0) << "Could not open linker nexe"; | 23     CHECK(nexe_fd >= 0) << "Could not open linker nexe"; | 
| 26     ::nacl::MojoLaunchNexeNonsfi( | 24     ::nacl::MojoLaunchNexeNonsfi( | 
| 27         nexe_fd, linker_request.PassMessagePipe().release().value(), | 25         nexe_fd, linker_request.PassMessagePipe().release().value(), | 
| 28         true /* enable_translate_irt */); | 26         true /* enable_translate_irt */); | 
| 29   } | 27   } | 
| 30 }; | 28 }; | 
| 31 | 29 | 
| 32 class StrongBindingPexeLinkerImpl : public PexeLinkerImpl { | 30 class StrongBindingPexeLinkerImpl : public PexeLinkerImpl { | 
| 33  public: | 31  public: | 
| 34   explicit StrongBindingPexeLinkerImpl(InterfaceRequest<PexeLinkerInit> request) | 32   explicit StrongBindingPexeLinkerImpl(InterfaceRequest<PexeLinkerInit> request) | 
| 35       : strong_binding_(this, request.Pass()) {} | 33       : strong_binding_(this, request.Pass()) {} | 
| 36 | 34 | 
| 37  private: | 35  private: | 
| 38   StrongBinding<PexeLinkerInit> strong_binding_; | 36   StrongBinding<PexeLinkerInit> strong_binding_; | 
| 39 }; | 37 }; | 
| 40 | 38 | 
| 41 class MultiPexeLinker : public ApplicationDelegate { | 39 class MultiPexeLinker : public ApplicationImplBase { | 
| 42  public: | 40  public: | 
| 43   MultiPexeLinker() {} | 41   MultiPexeLinker() {} | 
| 44 | 42 | 
| 45   // From ApplicationDelegate | 43   // From ApplicationImplBase | 
| 46   bool ConfigureIncomingConnection( | 44   bool OnAcceptConnection(ServiceProviderImpl* service_provider_impl) override { | 
| 47       ServiceProviderImpl* service_provider_impl) override { |  | 
| 48     service_provider_impl->AddService<PexeLinkerInit>( | 45     service_provider_impl->AddService<PexeLinkerInit>( | 
| 49         [](const ConnectionContext& connection_context, | 46         [](const ConnectionContext& connection_context, | 
| 50            InterfaceRequest<PexeLinkerInit> request) { | 47            InterfaceRequest<PexeLinkerInit> request) { | 
| 51           new StrongBindingPexeLinkerImpl(request.Pass()); | 48           new StrongBindingPexeLinkerImpl(request.Pass()); | 
| 52         }); | 49         }); | 
| 53     return true; | 50     return true; | 
| 54   } | 51   } | 
| 55 }; | 52 }; | 
| 56 | 53 | 
| 57 }  // namespace nacl | 54 }  // namespace nacl | 
| 58 }  // namespace mojo | 55 }  // namespace mojo | 
| 59 | 56 | 
| 60 MojoResult MojoMain(MojoHandle application_request) { | 57 MojoResult MojoMain(MojoHandle application_request) { | 
| 61   mojo::ApplicationRunner runner(std::unique_ptr<mojo::nacl::MultiPexeLinker>( | 58   mojo::nacl::MultiPexeLinker multi_pexe_linker; | 
| 62       new mojo::nacl::MultiPexeLinker())); | 59   return mojo::RunMainApplication(application_request, &multi_pexe_linker); | 
| 63   return runner.Run(application_request); |  | 
| 64 } | 60 } | 
| OLD | NEW | 
|---|