Chromium Code Reviews| Index: chrome/browser/chromeos/dbus/console_service_provider.cc |
| diff --git a/chrome/browser/chromeos/dbus/console_service_provider.cc b/chrome/browser/chromeos/dbus/console_service_provider.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..2428967547e5cbcfa6d68fe69622b97ac915f69e |
| --- /dev/null |
| +++ b/chrome/browser/chromeos/dbus/console_service_provider.cc |
| @@ -0,0 +1,55 @@ |
| +// Copyright 2014 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "ash/shell.h" |
| +#include "chrome/browser/chromeos/dbus/console_service_provider.h" |
| +#include "third_party/cros_system_api/dbus/service_constants.h" |
| +#include "ui/display/chromeos/display_configurator.h" |
| + |
| +namespace chromeos { |
| + |
| +ConsoleServiceProvider::ConsoleServiceProvider() : weak_ptr_factory_(this) { |
| +} |
| + |
| +ConsoleServiceProvider::~ConsoleServiceProvider() { |
| +} |
| + |
| +void ConsoleServiceProvider::Start( |
| + scoped_refptr<dbus::ExportedObject> exported_object) { |
| + exported_object->ExportMethod( |
| + kLibCrosServiceInterface, kActivateConsole, |
| + base::Bind(&ConsoleServiceProvider::ActivateConsole, |
| + weak_ptr_factory_.GetWeakPtr()), |
| + base::Bind(&ConsoleServiceProvider::OnExported, |
| + weak_ptr_factory_.GetWeakPtr())); |
| +} |
| + |
| +void ConsoleServiceProvider::ActivateConsole( |
| + dbus::MethodCall* method_call, |
| + dbus::ExportedObject::ResponseSender response_sender) { |
| + dbus::MessageReader reader(method_call); |
| + bool release_display; |
| + if (reader.PopBool(&release_display)) { |
| + ui::DisplayConfigurator* display_configurator = |
| + ash::Shell::GetInstance()->display_configurator(); |
| + if (release_display) |
| + display_configurator->RelinquishControl(); |
| + else |
|
Daniel Erat
2014/11/02 13:48:34
nit: you need curly brackets for the if/else now t
dsodman
2014/11/04 05:19:40
Done.
|
| + display_configurator->SetDisplayMode( |
| + display_configurator->display_state()); |
|
Daniel Erat
2014/11/02 13:48:34
asking it to set the display to the already-curren
dsodman
2014/11/04 05:19:40
Done.
|
| + } else { |
| + LOG(ERROR) << "Unable to parse " << kActivateConsole << " request"; |
| + } |
| + |
| + response_sender.Run(dbus::Response::FromMethodCall(method_call)); |
| +} |
| + |
| +void ConsoleServiceProvider::OnExported(const std::string& interface_name, |
| + const std::string& method_name, |
| + bool success) { |
| + if (!success) |
| + LOG(ERROR) << "failed to export " << interface_name << "." << method_name; |
| +} |
| + |
| +} // namespace chromeos |