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

Side by Side Diff: shell/application_manager/shell_impl.cc

Issue 979203002: Index application by URL and identity for multiprocess. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 5 years, 9 months 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 unified diff | Download patch
OLDNEW
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 "shell/application_manager/shell_impl.h" 5 #include "shell/application_manager/shell_impl.h"
6 6
7 #include "mojo/common/common_type_converters.h" 7 #include "mojo/common/common_type_converters.h"
8 #include "mojo/services/content_handler/public/interfaces/content_handler.mojom. h" 8 #include "mojo/services/content_handler/public/interfaces/content_handler.mojom. h"
9 #include "shell/application_manager/application_manager.h" 9 #include "shell/application_manager/application_manager.h"
10 10
11 namespace mojo { 11 namespace mojo {
12 namespace shell { 12 namespace shell {
13 13
14 ShellImpl::ShellImpl(ApplicationPtr application, 14 ShellImpl::ShellImpl(ApplicationPtr application,
15 ApplicationManager* manager, 15 ApplicationManager* manager,
16 const GURL& requested_url, 16 const GURL& requested_url,
17 const GURL& url) 17 const URLAndIdentity& url_and_identity)
18 : manager_(manager), 18 : manager_(manager),
19 requested_url_(requested_url), 19 requested_url_(requested_url),
20 url_(url), 20 url_and_identity_(url_and_identity),
21 application_(application.Pass()), 21 application_(application.Pass()),
22 binding_(this) { 22 binding_(this) {
23 binding_.set_error_handler(this); 23 binding_.set_error_handler(this);
24 } 24 }
25 25
26 ShellImpl::~ShellImpl() { 26 ShellImpl::~ShellImpl() {
27 } 27 }
28 28
29 void ShellImpl::InitializeApplication(Array<String> args) { 29 void ShellImpl::InitializeApplication(Array<String> args) {
30 ShellPtr shell; 30 ShellPtr shell;
31 binding_.Bind(GetProxy(&shell)); 31 binding_.Bind(GetProxy(&shell));
32 application_->Initialize(shell.Pass(), args.Pass(), url_.spec()); 32 application_->Initialize(shell.Pass(), args.Pass(),
33 url_and_identity_.url.spec());
33 } 34 }
34 35
35 void ShellImpl::ConnectToClient(const GURL& requested_url, 36 void ShellImpl::ConnectToClient(const GURL& requested_url,
36 const GURL& requestor_url, 37 const GURL& requestor_url,
37 InterfaceRequest<ServiceProvider> services, 38 InterfaceRequest<ServiceProvider> services,
38 ServiceProviderPtr exposed_services) { 39 ServiceProviderPtr exposed_services) {
39 application_->AcceptConnection(String::From(requestor_url), services.Pass(), 40 application_->AcceptConnection(String::From(requestor_url), services.Pass(),
40 exposed_services.Pass(), requested_url.spec()); 41 exposed_services.Pass(), requested_url.spec());
41 } 42 }
42 43
43 // Shell implementation: 44 // Shell implementation:
44 void ShellImpl::ConnectToApplication(const String& app_url, 45 void ShellImpl::ConnectToApplication(const String& app_url,
45 InterfaceRequest<ServiceProvider> services, 46 InterfaceRequest<ServiceProvider> services,
46 ServiceProviderPtr exposed_services) { 47 ServiceProviderPtr exposed_services) {
47 GURL app_gurl(app_url); 48 GURL app_gurl(app_url);
48 if (!app_gurl.is_valid()) { 49 if (!app_gurl.is_valid()) {
49 LOG(ERROR) << "Error: invalid URL: " << app_url; 50 LOG(ERROR) << "Error: invalid URL: " << app_url;
50 return; 51 return;
51 } 52 }
52 manager_->ConnectToApplication(app_gurl, url_, services.Pass(), 53 manager_->ConnectToApplication(app_gurl, url_and_identity_.url,
53 exposed_services.Pass()); 54 services.Pass(), exposed_services.Pass());
54 } 55 }
55 56
56 void ShellImpl::OnConnectionError() { 57 void ShellImpl::OnConnectionError() {
57 manager_->OnShellImplError(this); 58 manager_->OnShellImplError(this);
58 } 59 }
59 60
60 } // namespace shell 61 } // namespace shell
61 } // namespace mojo 62 } // namespace mojo
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698