Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 #ifndef CHROME_BROWSER_EXTENSIONS_GLOBAL_SHORTCUT_LISTENER_MAC_H_ | 5 #ifndef CHROME_BROWSER_EXTENSIONS_GLOBAL_SHORTCUT_LISTENER_MAC_H_ |
| 6 #define CHROME_BROWSER_EXTENSIONS_GLOBAL_SHORTCUT_LISTENER_MAC_H_ | 6 #define CHROME_BROWSER_EXTENSIONS_GLOBAL_SHORTCUT_LISTENER_MAC_H_ |
| 7 | 7 |
| 8 #include "chrome/browser/extensions/global_shortcut_listener.h" | |
| 9 | |
| 10 #include <set> | |
|
Robert Sesek
2013/11/18 15:25:03
#include <map> since you use it.
smus
2013/11/18 23:13:41
Done.
| |
| 11 #include <IOKit/hidsystem/ev_keymap.h> | |
|
Robert Sesek
2013/11/18 15:25:03
IOKit/IOKit.h
Does this need to be in the .h?
smus
2013/11/18 23:13:41
Moved to .mm, but unfortunately IOKit/IOKit.h does
| |
| 12 #include <Carbon/Carbon.h> | |
|
Robert Sesek
2013/11/18 15:25:03
Same. Does this need to be in the .h?
smus
2013/11/18 23:13:41
Yes, this provides EventHotKeyRef
| |
| 13 | |
| 14 #include "ApplicationServices/ApplicationServices.h" | |
|
Robert Sesek
2013/11/18 15:25:03
This is a system header, so it should be in <>. Do
smus
2013/11/18 23:13:41
Moved to .mm and changed to <> syntax.
| |
| 8 #include "base/lazy_instance.h" | 15 #include "base/lazy_instance.h" |
| 9 #include "chrome/browser/extensions/global_shortcut_listener.h" | 16 #include "base/mac/scoped_nsobject.h" |
| 17 | |
| 18 @class GlobalShortcutListenerTap; | |
| 10 | 19 |
| 11 namespace extensions { | 20 namespace extensions { |
| 12 | 21 |
| 13 // Mac-specific implementation of the GlobalShortcutListener class that | 22 // Mac-specific implementation of the GlobalShortcutListener class that |
| 14 // listens for global shortcuts. Handles basic keyboard intercepting and | 23 // listens for global shortcuts. Handles basic keyboard intercepting and |
| 15 // forwards its output to the base class for processing. | 24 // forwards its output to the base class for processing. |
| 16 // TODO(finnur/smus): Implement this class. | 25 // TODO(finnur/smus): Implement this class. |
|
Robert Sesek
2013/11/18 15:25:03
This comment should be revised. It should also det
smus
2013/11/18 23:13:41
Done.
| |
| 17 class GlobalShortcutListenerMac : public GlobalShortcutListener { | 26 class GlobalShortcutListenerMac : public GlobalShortcutListener { |
| 18 public: | 27 public: |
| 19 virtual ~GlobalShortcutListenerMac(); | 28 virtual ~GlobalShortcutListenerMac(); |
| 20 | 29 |
| 21 virtual void StartListening() OVERRIDE; | 30 virtual void StartListening() OVERRIDE; |
| 22 virtual void StopListening() OVERRIDE; | 31 virtual void StopListening() OVERRIDE; |
| 23 | 32 |
| 33 // Keyboard event callbacks. | |
| 34 bool OnKeyEvent(EventHotKeyID hotKeyID); | |
| 35 bool OnMediaKeyEvent(ui::KeyboardCode keyCode); | |
| 36 | |
| 37 | |
|
Finnur
2013/11/18 11:55:57
nit: Remove line break.
smus
2013/11/18 23:13:41
Done.
| |
| 24 private: | 38 private: |
| 25 friend struct base::DefaultLazyInstanceTraits<GlobalShortcutListenerMac>; | 39 friend struct base::DefaultLazyInstanceTraits<GlobalShortcutListenerMac>; |
| 26 | 40 |
| 27 GlobalShortcutListenerMac(); | 41 GlobalShortcutListenerMac(); |
| 28 | 42 |
| 29 // Register an |accelerator| with the particular |observer|. | 43 // Register an |accelerator| with the particular |observer|. |
| 30 virtual void RegisterAccelerator( | 44 virtual void RegisterAccelerator( |
| 31 const ui::Accelerator& accelerator, | 45 const ui::Accelerator& accelerator, |
| 32 GlobalShortcutListener::Observer* observer) OVERRIDE; | 46 GlobalShortcutListener::Observer* observer) OVERRIDE; |
| 33 // Unregister an |accelerator| with the particular |observer|. | 47 // Unregister an |accelerator| with the particular |observer|. |
| 34 virtual void UnregisterAccelerator( | 48 virtual void UnregisterAccelerator( |
| 35 const ui::Accelerator& accelerator, | 49 const ui::Accelerator& accelerator, |
| 36 GlobalShortcutListener::Observer* observer) OVERRIDE; | 50 GlobalShortcutListener::Observer* observer) OVERRIDE; |
| 37 | 51 |
| 52 // Mac-specific function for registering a hotkey. | |
| 53 void RegisterHotKey(ui::Accelerator accelerator); | |
|
Robert Sesek
2013/11/18 15:25:03
Make these be const& parameters.
smus
2013/11/18 23:13:41
Done.
| |
| 54 void UnregisterHotKey(ui::Accelerator accelerator); | |
| 55 | |
| 38 // Whether this object is listening for global shortcuts. | 56 // Whether this object is listening for global shortcuts. |
| 39 bool is_listening_; | 57 bool is_listening_; |
| 58 int hotkey_id = 0; | |
|
Finnur
2013/11/18 11:55:57
nit: Add line break and comment.
Also, why not tra
smus
2013/11/18 23:13:41
Done.
| |
| 59 | |
| 60 // A map of registered accelerators and their registration ids. | |
| 61 // TODO: Consider using a bimap structure instead. | |
|
Finnur
2013/11/18 11:55:57
style: All TODOs need an actor, e.g.:
// TODO(smus
smus
2013/11/18 23:13:41
Done.
| |
| 62 typedef std::map< ui::Accelerator, int > HotkeyIdMap; | |
| 63 HotkeyIdMap hotkey_ids_; | |
| 64 typedef std::map< int, ui::Accelerator > IdHotkeyMap; | |
| 65 IdHotkeyMap id_hotkeys_; | |
| 66 | |
| 67 // A map of hot key refs so they can be unregistered later. | |
|
Finnur
2013/11/18 11:55:57
nit: hot key? or hotkey? :)
smus
2013/11/18 23:13:41
hotkey!!!
| |
| 68 typedef std::map< int, EventHotKeyRef > IdHotkeyRefMap; | |
| 69 IdHotkeyRefMap id_hotkey_refs_; | |
|
Finnur
2013/11/18 11:55:57
That's a lot of maps, Mr. Magellan. It would be go
smus
2013/11/18 23:13:41
Ok, documented. I could have used one fewer map bu
| |
| 70 | |
| 71 | |
|
Finnur
2013/11/18 11:55:57
nit: Remove line break.
smus
2013/11/18 23:13:41
Done.
| |
| 72 // A pointer to the global shortcut listener tap. | |
|
Finnur
2013/11/18 11:55:57
This is kind of self-evident from the code. It wou
smus
2013/11/18 23:13:41
Done.
| |
| 73 base::scoped_nsobject<GlobalShortcutListenerTap> tap_; | |
| 40 | 74 |
| 41 DISALLOW_COPY_AND_ASSIGN(GlobalShortcutListenerMac); | 75 DISALLOW_COPY_AND_ASSIGN(GlobalShortcutListenerMac); |
| 42 }; | 76 }; |
| 43 | 77 |
| 44 } // namespace extensions | 78 } // namespace extensions |
| 45 | 79 |
| 46 #endif // CHROME_BROWSER_EXTENSIONS_GLOBAL_SHORTCUT_LISTENER_MAC_H_ | 80 #endif // CHROME_BROWSER_EXTENSIONS_GLOBAL_SHORTCUT_LISTENER_MAC_H_ |
| OLD | NEW |