| 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 "mandoline/services/core_services/core_services_application_delegate.h" | 5 #include "mandoline/services/core_services/core_services_application_delegate.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/macros.h" | 10 #include "base/macros.h" |
| (...skipping 15 matching lines...) Expand all Loading... |
| 26 | 26 |
| 27 namespace core_services { | 27 namespace core_services { |
| 28 | 28 |
| 29 // A helper class for hosting a mojo::ApplicationImpl on its own thread. | 29 // A helper class for hosting a mojo::ApplicationImpl on its own thread. |
| 30 class ApplicationThread : public base::SimpleThread { | 30 class ApplicationThread : public base::SimpleThread { |
| 31 public: | 31 public: |
| 32 ApplicationThread(const base::WeakPtr<CoreServicesApplicationDelegate> | 32 ApplicationThread(const base::WeakPtr<CoreServicesApplicationDelegate> |
| 33 core_services_application, | 33 core_services_application, |
| 34 const std::string& url, | 34 const std::string& url, |
| 35 scoped_ptr<mojo::ApplicationDelegate> delegate, | 35 scoped_ptr<mojo::ApplicationDelegate> delegate, |
| 36 mojo::InterfaceRequest<mojo::Application> request, | 36 mojo::ApplicationRequest request, |
| 37 const mojo::Callback<void()>& destruct_callback) | 37 const mojo::Callback<void()>& destruct_callback) |
| 38 : base::SimpleThread(url), | 38 : base::SimpleThread(url), |
| 39 core_services_application_(core_services_application), | 39 core_services_application_(core_services_application), |
| 40 core_services_application_task_runner_(base::MessageLoop::current() | 40 core_services_application_task_runner_(base::MessageLoop::current() |
| 41 ->task_runner()), | 41 ->task_runner()), |
| 42 url_(url), | 42 url_(url), |
| 43 delegate_(std::move(delegate)), | 43 delegate_(std::move(delegate)), |
| 44 request_(std::move(request)), | 44 request_(std::move(request)), |
| 45 destruct_callback_(destruct_callback) {} | 45 destruct_callback_(destruct_callback) {} |
| 46 | 46 |
| (...skipping 19 matching lines...) Expand all Loading... |
| 66 core_services_application_, | 66 core_services_application_, |
| 67 this)); | 67 this)); |
| 68 } | 68 } |
| 69 | 69 |
| 70 private: | 70 private: |
| 71 base::WeakPtr<CoreServicesApplicationDelegate> core_services_application_; | 71 base::WeakPtr<CoreServicesApplicationDelegate> core_services_application_; |
| 72 scoped_refptr<base::SingleThreadTaskRunner> | 72 scoped_refptr<base::SingleThreadTaskRunner> |
| 73 core_services_application_task_runner_; | 73 core_services_application_task_runner_; |
| 74 std::string url_; | 74 std::string url_; |
| 75 scoped_ptr<mojo::ApplicationDelegate> delegate_; | 75 scoped_ptr<mojo::ApplicationDelegate> delegate_; |
| 76 mojo::InterfaceRequest<mojo::Application> request_; | 76 mojo::ApplicationRequest request_; |
| 77 mojo::Callback<void()> destruct_callback_; | 77 mojo::Callback<void()> destruct_callback_; |
| 78 | 78 |
| 79 DISALLOW_COPY_AND_ASSIGN(ApplicationThread); | 79 DISALLOW_COPY_AND_ASSIGN(ApplicationThread); |
| 80 }; | 80 }; |
| 81 | 81 |
| 82 CoreServicesApplicationDelegate::CoreServicesApplicationDelegate() | 82 CoreServicesApplicationDelegate::CoreServicesApplicationDelegate() |
| 83 : weak_factory_(this) { | 83 : weak_factory_(this) { |
| 84 } | 84 } |
| 85 | 85 |
| 86 CoreServicesApplicationDelegate::~CoreServicesApplicationDelegate() { | 86 CoreServicesApplicationDelegate::~CoreServicesApplicationDelegate() { |
| (...skipping 23 matching lines...) Expand all Loading... |
| 110 | 110 |
| 111 void CoreServicesApplicationDelegate::Quit() { | 111 void CoreServicesApplicationDelegate::Quit() { |
| 112 // This will delete all threads. This also performs a blocking join, waiting | 112 // This will delete all threads. This also performs a blocking join, waiting |
| 113 // for the threads to end. | 113 // for the threads to end. |
| 114 application_threads_.clear(); | 114 application_threads_.clear(); |
| 115 weak_factory_.InvalidateWeakPtrs(); | 115 weak_factory_.InvalidateWeakPtrs(); |
| 116 } | 116 } |
| 117 | 117 |
| 118 void CoreServicesApplicationDelegate::Create( | 118 void CoreServicesApplicationDelegate::Create( |
| 119 mojo::ApplicationConnection* connection, | 119 mojo::ApplicationConnection* connection, |
| 120 mojo::InterfaceRequest<mojo::ContentHandler> request) { | 120 mojo::InterfaceRequest<mojo::shell::mojom::ContentHandler> request) { |
| 121 handler_bindings_.AddBinding(this, std::move(request)); | 121 handler_bindings_.AddBinding(this, std::move(request)); |
| 122 } | 122 } |
| 123 | 123 |
| 124 void CoreServicesApplicationDelegate::StartApplication( | 124 void CoreServicesApplicationDelegate::StartApplication( |
| 125 mojo::InterfaceRequest<mojo::Application> request, | 125 mojo::ApplicationRequest request, |
| 126 mojo::URLResponsePtr response, | 126 mojo::URLResponsePtr response, |
| 127 const mojo::Callback<void()>& destruct_callback) { | 127 const mojo::Callback<void()>& destruct_callback) { |
| 128 const std::string url = response->url; | 128 const std::string url = response->url; |
| 129 | 129 |
| 130 scoped_ptr<mojo::ApplicationDelegate> delegate; | 130 scoped_ptr<mojo::ApplicationDelegate> delegate; |
| 131 if (url == "mojo://clipboard/") { | 131 if (url == "mojo://clipboard/") { |
| 132 delegate.reset(new clipboard::ClipboardApplicationDelegate); | 132 delegate.reset(new clipboard::ClipboardApplicationDelegate); |
| 133 } else if (url == "mojo://filesystem/") { | 133 } else if (url == "mojo://filesystem/") { |
| 134 delegate.reset(new filesystem::FileSystemApp); | 134 delegate.reset(new filesystem::FileSystemApp); |
| 135 } else if (url == "mojo://tracing/") { | 135 } else if (url == "mojo://tracing/") { |
| (...skipping 13 matching lines...) Expand all Loading... |
| 149 } | 149 } |
| 150 | 150 |
| 151 scoped_ptr<ApplicationThread> thread(new ApplicationThread( | 151 scoped_ptr<ApplicationThread> thread(new ApplicationThread( |
| 152 weak_factory_.GetWeakPtr(), url, std::move(delegate), std::move(request), | 152 weak_factory_.GetWeakPtr(), url, std::move(delegate), std::move(request), |
| 153 destruct_callback)); | 153 destruct_callback)); |
| 154 thread->Start(); | 154 thread->Start(); |
| 155 application_threads_.push_back(std::move(thread)); | 155 application_threads_.push_back(std::move(thread)); |
| 156 } | 156 } |
| 157 | 157 |
| 158 } // namespace core_services | 158 } // namespace core_services |
| OLD | NEW |