Chromium Code Reviews| Index: services/ui/launcher/launcher_app.cc |
| diff --git a/services/ui/launcher/launcher_app.cc b/services/ui/launcher/launcher_app.cc |
| index 07e796fdb1df128e0cedfcce0c8a826cff0f095b..55a58bea03c85736a34cafc587521bd2eda43e3a 100644 |
| --- a/services/ui/launcher/launcher_app.cc |
| +++ b/services/ui/launcher/launcher_app.cc |
| @@ -2,15 +2,16 @@ |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| +#include "services/ui/launcher/launcher_app.h" |
| + |
| +#include "base/command_line.h" |
| +#include "base/logging.h" |
| #include "base/trace_event/trace_event.h" |
| #include "mojo/application/application_runner_chromium.h" |
| #include "mojo/common/tracing_impl.h" |
| #include "mojo/public/c/system/main.h" |
| #include "mojo/public/cpp/application/application_connection.h" |
| #include "mojo/public/cpp/application/application_impl.h" |
| -#include "mojo/services/surfaces/cpp/surfaces_utils.h" |
| -#include "mojo/services/surfaces/interfaces/quads.mojom.h" |
| -#include "services/ui/launcher/launcher_app.h" |
| #include "services/ui/launcher/launcher_view_tree.h" |
| namespace launcher { |
| @@ -20,31 +21,55 @@ LauncherApp::LauncherApp() |
| LauncherApp::~LauncherApp() {} |
| -void LauncherApp::Initialize(mojo::ApplicationImpl* app) { |
| - app_impl_ = app; |
| - tracing_.Initialize(app); |
| +void LauncherApp::Initialize(mojo::ApplicationImpl* app_impl) { |
| + app_impl_ = app_impl; |
| + |
| + auto command_line = base::CommandLine::ForCurrentProcess(); |
| + command_line->InitFromArgv(app_impl_->args()); |
|
abarth
2016/01/10 01:42:54
Woah. I guess that works.
jeffbrown
2016/01/26 05:59:12
(Nothing else does.)
|
| + logging::LoggingSettings settings; |
| + settings.logging_dest = logging::LOG_TO_SYSTEM_DEBUG_LOG; |
| + logging::InitLogging(settings); |
| + |
| + tracing_.Initialize(app_impl_); |
| TRACE_EVENT0("launcher", __func__); |
| - if (app->args().size() != 2) { |
| + if (command_line->GetArgs().size() != 1) { |
| LOG(ERROR) << "Invalid arguments.\n\n" |
| "Usage: mojo_shell \"mojo:launcher <app url>\""; |
| - app->Terminate(); |
| + app_impl_->Terminate(); |
| return; |
| } |
| + app_impl_->ConnectToService("mojo:compositor_service", &compositor_); |
| + compositor_.set_connection_error_handler(base::Bind( |
| + &LauncherApp::OnCompositorConnectionError, base::Unretained(this))); |
| + |
| + app_impl_->ConnectToService("mojo:view_manager_service", &view_manager_); |
| + view_manager_.set_connection_error_handler(base::Bind( |
| + &LauncherApp::OnViewManagerConnectionError, base::Unretained(this))); |
| + |
| InitViewport(); |
| - LaunchClient(app->args()[1]); |
| + LaunchClient(command_line->GetArgs()[0]); |
| +} |
| + |
| +void LauncherApp::OnCompositorConnectionError() { |
| + LOG(ERROR) << "Exiting due to compositor connection error."; |
| + Shutdown(); |
| +} |
| + |
| +void LauncherApp::OnViewManagerConnectionError() { |
| + LOG(ERROR) << "Exiting due to view manager connection error."; |
| + Shutdown(); |
| } |
| void LauncherApp::InitViewport() { |
| - app_impl_->ConnectToService("mojo:native_viewport_service", |
| - &viewport_service_); |
| - viewport_service_.set_connection_error_handler(base::Bind( |
| + app_impl_->ConnectToService("mojo:native_viewport_service", &viewport_); |
| + viewport_.set_connection_error_handler(base::Bind( |
| &LauncherApp::OnViewportConnectionError, base::Unretained(this))); |
| mojo::NativeViewportEventDispatcherPtr dispatcher; |
| viewport_event_dispatcher_binding_.Bind(GetProxy(&dispatcher)); |
| - viewport_service_->SetEventDispatcher(dispatcher.Pass()); |
| + viewport_->SetEventDispatcher(dispatcher.Pass()); |
| // Match the Nexus 5 aspect ratio initially. |
| auto size = mojo::Size::New(); |
| @@ -52,29 +77,26 @@ void LauncherApp::InitViewport() { |
| size->height = 640; |
| auto requested_configuration = mojo::SurfaceConfiguration::New(); |
| - viewport_service_->Create( |
| + viewport_->Create( |
| size.Clone(), requested_configuration.Pass(), |
| base::Bind(&LauncherApp::OnViewportCreated, base::Unretained(this))); |
| } |
| void LauncherApp::OnViewportConnectionError() { |
| LOG(ERROR) << "Exiting due to viewport connection error."; |
| - app_impl_->Terminate(); |
| + Shutdown(); |
| } |
| void LauncherApp::OnViewportCreated(mojo::ViewportMetricsPtr metrics) { |
| - viewport_service_->Show(); |
| - mojo::ContextProviderPtr context_provider; |
| - viewport_service_->GetContextProvider(GetProxy(&context_provider)); |
| + viewport_->Show(); |
| - mojo::DisplayFactoryPtr display_factory; |
| - app_impl_->ConnectToService("mojo:surfaces_service", &display_factory); |
| - |
| - mojo::DisplayPtr display; |
| - display_factory->Create(context_provider.Pass(), nullptr, GetProxy(&display)); |
| + mojo::ContextProviderPtr context_provider; |
| + viewport_->GetContextProvider(GetProxy(&context_provider)); |
| - view_tree_.reset( |
| - new LauncherViewTree(app_impl_, display.Pass(), metrics.Pass())); |
| + view_tree_.reset(new LauncherViewTree( |
| + compositor_.get(), view_manager_.get(), context_provider.Pass(), |
| + metrics.Pass(), |
| + base::Bind(&LauncherApp::Shutdown, base::Unretained(this)))); |
| UpdateClientView(); |
| RequestUpdatedViewportMetrics(); |
| } |
| @@ -87,8 +109,8 @@ void LauncherApp::OnViewportMetricsChanged(mojo::ViewportMetricsPtr metrics) { |
| } |
| void LauncherApp::RequestUpdatedViewportMetrics() { |
| - viewport_service_->RequestMetrics(base::Bind( |
| - &LauncherApp::OnViewportMetricsChanged, base::Unretained(this))); |
| + viewport_->RequestMetrics(base::Bind(&LauncherApp::OnViewportMetricsChanged, |
| + base::Unretained(this))); |
| } |
| void LauncherApp::OnEvent(mojo::EventPtr event, |
| @@ -112,7 +134,7 @@ void LauncherApp::LaunchClient(std::string app_url) { |
| void LauncherApp::OnClientConnectionError() { |
| LOG(ERROR) << "Exiting due to client application connection error."; |
| - app_impl_->Terminate(); |
| + Shutdown(); |
| } |
| void LauncherApp::OnClientViewCreated(mojo::ui::ViewTokenPtr view_token) { |
| @@ -125,4 +147,8 @@ void LauncherApp::UpdateClientView() { |
| view_tree_->SetRoot(client_view_token_.Clone()); |
| } |
| +void LauncherApp::Shutdown() { |
| + app_impl_->Terminate(); |
| +} |
| + |
| } // namespace launcher |