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

Unified Diff: athena/screen_lock/chrome/screen_lock_manager_impl.cc

Issue 620663005: Lock screen for Chrome-Athena (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: comments resolved Created 6 years, 2 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 side-by-side diff with in-line comments
Download patch
Index: athena/screen_lock/chrome/screen_lock_manager_impl.cc
diff --git a/athena/screen_lock/chrome/screen_lock_manager_impl.cc b/athena/screen_lock/chrome/screen_lock_manager_impl.cc
new file mode 100644
index 0000000000000000000000000000000000000000..ccda7eb8620341f8d3518fd96755eb410c828ac8
--- /dev/null
+++ b/athena/screen_lock/chrome/screen_lock_manager_impl.cc
@@ -0,0 +1,99 @@
+// 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 "athena/screen_lock/public/screen_lock_manager.h"
+
+#include "athena/input/public/accelerator_manager.h"
+#include "base/logging.h"
+#include "chrome/browser/chromeos/login/lock/screen_locker.h"
+
+namespace athena {
+namespace {
+
+enum Command {
+ CMD_LOCK_SCREEN
+};
+
+const AcceleratorData accelerator_data[] = {
+ { TRIGGER_ON_PRESS, ui::VKEY_L, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
+ CMD_LOCK_SCREEN, AF_NONE }};
+
+ScreenLockManager* instance = NULL;
+
+class ScreenLockManagerImpl : public ScreenLockManager,
+ public AcceleratorHandler {
+ public:
+ ScreenLockManagerImpl();
+ virtual ~ScreenLockManagerImpl();
+
+ void Init();
+
+ private:
+ // ScreenLockManager:
+ virtual void LockScreen() override;
+
+ // AcceleratorHandler:
+ virtual bool IsCommandEnabled(int command_id) const override;
+ virtual bool OnAcceleratorFired(int command_id,
+ const ui::Accelerator& accelerator) override;
+
+ DISALLOW_COPY_AND_ASSIGN(ScreenLockManagerImpl);
+};
+
+ScreenLockManagerImpl::ScreenLockManagerImpl() {
+ DCHECK(!instance);
+ instance = this;
+}
+
+ScreenLockManagerImpl::~ScreenLockManagerImpl() {
+ DCHECK_EQ(instance, this);
+ instance = NULL;
+}
+
+void ScreenLockManagerImpl::Init() {
+ AcceleratorManager::Get()->RegisterAccelerators(
+ accelerator_data, arraysize(accelerator_data), this);
+}
+
+void ScreenLockManagerImpl::LockScreen() {
+ chromeos::ScreenLocker::HandleLockScreenRequest();
+}
+
+bool ScreenLockManagerImpl::IsCommandEnabled(int command_id) const {
+ return true;
+}
+
+bool ScreenLockManagerImpl::OnAcceleratorFired(
+ int command_id,
+ const ui::Accelerator& accelerator) {
+ switch (command_id) {
+ case CMD_LOCK_SCREEN:
+ LockScreen();
+ return true;
+ }
+ return false;
+}
+
+} // namespace
+
+// static
+ScreenLockManager* ScreenLockManager::Create() {
+ (new ScreenLockManagerImpl())->Init();
+ DCHECK(instance);
+ return instance;
+}
+
+// static
+ScreenLockManager* ScreenLockManager::Get() {
+ return instance;
+}
+
+// static
+void ScreenLockManager::Shutdown() {
+ DCHECK(instance);
+ delete instance;
+ DCHECK(!instance);
+}
+
+} // namespace athena

Powered by Google App Engine
This is Rietveld 408576698