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

Unified Diff: mojo/public/cpp/application/lib/application_impl.cc

Issue 1435153003: Add an ApplicationConnector interface, etc. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: grrr Created 5 years, 1 month 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 side-by-side diff with in-line comments
Download patch
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() {

Powered by Google App Engine
This is Rietveld 408576698