| Index: mojo/public/cpp/application/lib/application_impl.cc
|
| diff --git a/mojo/public/cpp/application/lib/application_impl.cc b/mojo/public/cpp/application/lib/application_impl.cc
|
| index 589159c86dc5b3f9765c788c5ad529811602b8a2..a4682628f8c1a9a3cd485fc50772cdc232f916cf 100644
|
| --- a/mojo/public/cpp/application/lib/application_impl.cc
|
| +++ b/mojo/public/cpp/application/lib/application_impl.cc
|
| @@ -4,37 +4,34 @@
|
|
|
| #include "mojo/public/cpp/application/application_impl.h"
|
|
|
| +#include <utility>
|
| +
|
| #include "mojo/public/cpp/application/application_delegate.h"
|
| #include "mojo/public/cpp/application/lib/service_registry.h"
|
| #include "mojo/public/cpp/bindings/interface_ptr.h"
|
| +#include "mojo/public/cpp/bindings/interface_request.h"
|
| #include "mojo/public/cpp/environment/logging.h"
|
| +#include "mojo/public/cpp/system/message_pipe.h"
|
|
|
| namespace mojo {
|
|
|
| ApplicationImpl::ApplicationImpl(ApplicationDelegate* delegate,
|
| InterfaceRequest<Application> request)
|
| - : delegate_(delegate), binding_(this, request.Pass()) {
|
| -}
|
| + : delegate_(delegate), binding_(this, request.Pass()) {}
|
| +
|
| +ApplicationImpl::~ApplicationImpl() {}
|
|
|
| bool ApplicationImpl::HasArg(const std::string& arg) const {
|
| return std::find(args_.begin(), args_.end(), arg) != args_.end();
|
| }
|
|
|
| -void ApplicationImpl::ClearConnections() {
|
| - for (ServiceRegistryList::iterator i(incoming_service_registries_.begin());
|
| - i != incoming_service_registries_.end();
|
| - ++i)
|
| - delete *i;
|
| - for (ServiceRegistryList::iterator i(outgoing_service_registries_.begin());
|
| - i != outgoing_service_registries_.end();
|
| - ++i)
|
| - delete *i;
|
| - incoming_service_registries_.clear();
|
| - outgoing_service_registries_.clear();
|
| -}
|
| -
|
| -ApplicationImpl::~ApplicationImpl() {
|
| - ClearConnections();
|
| +InterfacePtrInfo<ApplicationConnector>
|
| +ApplicationImpl::CreateApplicationConnector() {
|
| + MOJO_CHECK(shell_);
|
| + MessagePipe pipe;
|
| + shell_->CreateApplicationConnector(
|
| + MakeRequest<ApplicationConnector>(pipe.handle1.Pass()));
|
| + return InterfacePtrInfo<ApplicationConnector>(pipe.handle0.Pass(), 0u);
|
| }
|
|
|
| ApplicationConnection* ApplicationImpl::ConnectToApplication(
|
| @@ -48,20 +45,10 @@ ApplicationConnection* ApplicationImpl::ConnectToApplication(
|
| internal::ServiceRegistry* registry = new internal::ServiceRegistry(
|
| this, application_url, application_url, remote_services.Pass(),
|
| local_request.Pass());
|
| - outgoing_service_registries_.push_back(registry);
|
| + outgoing_service_registries_.emplace_back(registry);
|
| return registry;
|
| }
|
|
|
| -void ApplicationImpl::Initialize(ShellPtr shell,
|
| - Array<String> args,
|
| - const mojo::String& url) {
|
| - shell_ = shell.Pass();
|
| - shell_.set_connection_error_handler([this]() { OnShellError(); });
|
| - url_ = url;
|
| - args_ = args.To<std::vector<std::string>>();
|
| - delegate_->Initialize(this);
|
| -}
|
| -
|
| void ApplicationImpl::WaitForInitialize() {
|
| if (!shell_)
|
| binding_.WaitForIncomingMethodCall();
|
| @@ -74,18 +61,32 @@ void ApplicationImpl::UnbindConnections(
|
| shell->Bind(shell_.PassInterface());
|
| }
|
|
|
| +void ApplicationImpl::Initialize(ShellPtr shell,
|
| + Array<String> args,
|
| + const mojo::String& url) {
|
| + shell_ = shell.Pass();
|
| + shell_.set_connection_error_handler([this]() {
|
| + delegate_->Quit();
|
| + incoming_service_registries_.clear();
|
| + outgoing_service_registries_.clear();
|
| + Terminate();
|
| + });
|
| + url_ = url;
|
| + args_ = args.To<std::vector<std::string>>();
|
| + delegate_->Initialize(this);
|
| +}
|
| +
|
| void ApplicationImpl::AcceptConnection(
|
| const String& requestor_url,
|
| InterfaceRequest<ServiceProvider> services,
|
| ServiceProviderPtr exposed_services,
|
| const String& url) {
|
| - internal::ServiceRegistry* registry = new internal::ServiceRegistry(
|
| - this, url, requestor_url, exposed_services.Pass(), services.Pass());
|
| - if (!delegate_->ConfigureIncomingConnection(registry)) {
|
| - delete registry;
|
| + std::unique_ptr<internal::ServiceRegistry> registry(
|
| + new internal::ServiceRegistry(this, url, requestor_url,
|
| + exposed_services.Pass(), services.Pass()));
|
| + if (!delegate_->ConfigureIncomingConnection(registry.get()))
|
| return;
|
| - }
|
| - incoming_service_registries_.push_back(registry);
|
| + incoming_service_registries_.push_back(std::move(registry));
|
| }
|
|
|
| void ApplicationImpl::RequestQuit() {
|
|
|