Chromium Code Reviews| Index: mojo/services/public/js/application.js |
| diff --git a/mojo/services/public/js/application.js b/mojo/services/public/js/application.js |
| index a75c848da00509e5ffbb386708f47b8573343253..fcd56e840f1f6630c10f0d1b423684a70718fb89 100644 |
| --- a/mojo/services/public/js/application.js |
| +++ b/mojo/services/public/js/application.js |
| @@ -3,29 +3,43 @@ |
| // found in the LICENSE file. |
| define("mojo/services/public/js/application", [ |
| + "mojo/public/js/bindings", |
| + "mojo/public/js/core", |
| + "mojo/public/js/connection", |
| "mojo/public/js/threading", |
| + "mojo/public/interfaces/application/application.mojom", |
| "mojo/services/public/js/service_provider", |
| "mojo/services/public/js/shell", |
| -], function(threading, serviceProvider, shell) { |
| +], function(bindings, core, connection, threading, applicationMojom, |
| + serviceProvider, shell) { |
|
jamesr
2015/01/26 23:19:49
hah! line wrapping this (to make the 80col presubm
|
| + const ApplicationInterface = applicationMojom.Application; |
| + const ProxyBindings = bindings.ProxyBindings; |
| const ServiceProvider = serviceProvider.ServiceProvider; |
| const Shell = shell.Shell; |
| class Application { |
| - constructor(shellHandle, url) { |
| + constructor(appRequestHandle, url) { |
| this.url = url; |
| this.serviceProviders = []; |
| this.exposedServiceProviders = []; |
| - this.shellHandle_ = shellHandle; |
| - this.shell = new Shell(shellHandle, { |
| - initialize: this.initialize.bind(this), |
| - acceptConnection: this.doAcceptConnection.bind(this), |
| - }); |
| + this.appRequestHandle_ = appRequestHandle; |
| + this.appStub_ = |
| + connection.bindHandleToStub(appRequestHandle, ApplicationInterface); |
| + bindings.StubBindings(this.appStub_).delegate = { |
| + initialize: this.doInitialize.bind(this), |
| + acceptConnection: this.doAcceptConnection.bind(this), |
| + }; |
| } |
| - initialize(args) { |
| + doInitialize(shellProxy, args) { |
| + this.shellProxy_ = shellProxy; |
| + this.shell = new Shell(shellProxy); |
| + this.initialize(args); |
| } |
| + initialize(args) {} |
| + |
| // The mojom signature of this function is: |
| // AcceptConnection(string requestor_url, |
| // ServiceProvider&? services, |
| @@ -43,14 +57,14 @@ define("mojo/services/public/js/application", [ |
| this.acceptConnection(requestorUrl, serviceProvider); |
| } |
| - acceptConnection(requestorUrl, serviceProvider) { |
| - } |
| + acceptConnection(requestorUrl, serviceProvider) {} |
| quit() { |
| this.serviceProviders.forEach(function(sp) { |
| sp.close(); |
| }); |
| this.shell.close(); |
| + core.close(this.appRequestHandle_); |
| threading.quit(); |
| } |
| } |