Chromium Code Reviews| 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 "mojo/shell/application_instance.h" | 5 #include "mojo/shell/application_instance.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/stl_util.h" | 8 #include "base/stl_util.h" |
| 9 #include "mojo/application/public/interfaces/content_handler.mojom.h" | 9 #include "mojo/application/public/interfaces/content_handler.mojom.h" |
| 10 #include "mojo/common/common_type_converters.h" | 10 #include "mojo/common/common_type_converters.h" |
| 11 #include "mojo/common/url_type_converters.h" | 11 #include "mojo/common/url_type_converters.h" |
| 12 #include "mojo/shell/application_manager.h" | 12 #include "mojo/shell/application_manager.h" |
| 13 | 13 |
| 14 namespace mojo { | 14 namespace mojo { |
| 15 namespace shell { | 15 namespace shell { |
| 16 | 16 |
| 17 ApplicationInstance::QueuedClientRequest::QueuedClientRequest() { | 17 ApplicationInstance::QueuedClientRequest::QueuedClientRequest() |
| 18 } | 18 : originator(nullptr) {} |
| 19 | 19 |
| 20 ApplicationInstance::QueuedClientRequest::~QueuedClientRequest() { | 20 ApplicationInstance::QueuedClientRequest::~QueuedClientRequest() { |
| 21 } | 21 } |
| 22 | 22 |
| 23 ApplicationInstance::ApplicationInstance( | 23 ApplicationInstance::ApplicationInstance( |
| 24 ApplicationPtr application, | 24 ApplicationPtr application, |
| 25 ApplicationManager* manager, | 25 ApplicationManager* manager, |
| 26 const Identity& identity, | 26 const Identity& identity, |
| 27 const CapabilityFilter& filter, | 27 const CapabilityFilter& filter, |
| 28 const base::Closure& on_application_end) | 28 const base::Closure& on_application_end) |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 48 } | 48 } |
| 49 | 49 |
| 50 void ApplicationInstance::ConnectToClient( | 50 void ApplicationInstance::ConnectToClient( |
| 51 ApplicationInstance* originator, | 51 ApplicationInstance* originator, |
| 52 const GURL& requested_url, | 52 const GURL& requested_url, |
| 53 const GURL& requestor_url, | 53 const GURL& requestor_url, |
| 54 InterfaceRequest<ServiceProvider> services, | 54 InterfaceRequest<ServiceProvider> services, |
| 55 ServiceProviderPtr exposed_services, | 55 ServiceProviderPtr exposed_services, |
| 56 CapabilityFilterPtr filter) { | 56 CapabilityFilterPtr filter) { |
| 57 if (queue_requests_) { | 57 if (queue_requests_) { |
| 58 QueuedClientRequest* queued_request = new QueuedClientRequest; | 58 QueuedClientRequest* queued_request = new QueuedClientRequest(); |
| 59 queued_request->originator = originator; | 59 queued_request->originator = originator; |
| 60 queued_request->requested_url = requested_url; | 60 queued_request->requested_url = requested_url; |
| 61 queued_request->requestor_url = requestor_url; | 61 queued_request->requestor_url = requestor_url; |
| 62 queued_request->services = services.Pass(); | 62 queued_request->services = services.Pass(); |
| 63 queued_request->exposed_services = exposed_services.Pass(); | 63 queued_request->exposed_services = exposed_services.Pass(); |
| 64 queued_request->filter = filter.Pass(), | 64 queued_request->filter = filter.Pass(); |
| 65 queued_client_requests_.push_back(queued_request); | 65 queued_client_requests_.push_back(queued_request); |
| 66 return; | 66 return; |
| 67 } | 67 } |
| 68 | 68 |
| 69 CallAcceptConnection(originator, requestor_url, services.Pass(), | 69 CallAcceptConnection(originator, requestor_url, services.Pass(), |
| 70 exposed_services.Pass(), requested_url); | 70 exposed_services.Pass(), requested_url); |
| 71 } | 71 } |
| 72 | 72 |
| 73 ApplicationInstance::AllowedInterfaces | 73 ApplicationInstance::AllowedInterfaces |
| 74 ApplicationInstance::GetAllowedInterfaces( | 74 ApplicationInstance::GetAllowedInterfaces( |
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 137 queued_client_requests_.swap(queued_client_requests); | 137 queued_client_requests_.swap(queued_client_requests); |
| 138 auto manager = manager_; | 138 auto manager = manager_; |
| 139 manager_->OnApplicationInstanceError(this); | 139 manager_->OnApplicationInstanceError(this); |
| 140 //|this| is deleted. | 140 //|this| is deleted. |
| 141 | 141 |
| 142 // If any queued requests came to shell during time it was shutting down, | 142 // If any queued requests came to shell during time it was shutting down, |
| 143 // start them now. | 143 // start them now. |
| 144 for (auto request : queued_client_requests) { | 144 for (auto request : queued_client_requests) { |
| 145 mojo::URLRequestPtr url(mojo::URLRequest::New()); | 145 mojo::URLRequestPtr url(mojo::URLRequest::New()); |
| 146 url->url = mojo::String::From(request->requested_url.spec()); | 146 url->url = mojo::String::From(request->requested_url.spec()); |
| 147 manager->ConnectToApplication(this, url.Pass(), std::string(), | 147 manager->ConnectToApplication(nullptr, url.Pass(), std::string(), |
|
xhwang
2015/07/25 08:12:42
This fixes the crash in my test. But I am not sure
| |
| 148 request->requestor_url, | 148 request->requestor_url, |
| 149 request->services.Pass(), | 149 request->services.Pass(), |
| 150 request->exposed_services.Pass(), | 150 request->exposed_services.Pass(), |
| 151 request->filter.Pass(), | 151 request->filter.Pass(), |
| 152 base::Closure()); | 152 base::Closure()); |
| 153 } | 153 } |
| 154 STLDeleteElements(&queued_client_requests); | 154 STLDeleteElements(&queued_client_requests); |
| 155 } | 155 } |
| 156 | 156 |
| 157 void ApplicationInstance::OnQuitRequestedResult(bool can_quit) { | 157 void ApplicationInstance::OnQuitRequestedResult(bool can_quit) { |
| 158 if (can_quit) | 158 if (can_quit) |
| 159 return; | 159 return; |
| 160 | 160 |
| 161 queue_requests_ = false; | 161 queue_requests_ = false; |
| 162 for (auto request : queued_client_requests_) { | 162 for (auto request : queued_client_requests_) { |
| 163 CallAcceptConnection(request->originator, | 163 CallAcceptConnection(request->originator, |
| 164 request->requestor_url, | 164 request->requestor_url, |
| 165 request->services.Pass(), | 165 request->services.Pass(), |
| 166 request->exposed_services.Pass(), | 166 request->exposed_services.Pass(), |
| 167 request->requested_url); | 167 request->requested_url); |
| 168 } | 168 } |
| 169 STLDeleteElements(&queued_client_requests_); | 169 STLDeleteElements(&queued_client_requests_); |
| 170 } | 170 } |
| 171 | 171 |
| 172 } // namespace shell | 172 } // namespace shell |
| 173 } // namespace mojo | 173 } // namespace mojo |
| OLD | NEW |