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

Unified Diff: chrome/browser/extensions/global_shortcut_listener_mac.h

Issue 60353008: Mac global keybindings (Closed) Base URL: https://src.chromium.org/chrome/trunk/src/
Patch Set: Created 7 years, 1 month 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: chrome/browser/extensions/global_shortcut_listener_mac.h
===================================================================
--- chrome/browser/extensions/global_shortcut_listener_mac.h (revision 235137)
+++ chrome/browser/extensions/global_shortcut_listener_mac.h (working copy)
@@ -5,9 +5,18 @@
#ifndef CHROME_BROWSER_EXTENSIONS_GLOBAL_SHORTCUT_LISTENER_MAC_H_
#define CHROME_BROWSER_EXTENSIONS_GLOBAL_SHORTCUT_LISTENER_MAC_H_
-#include "base/lazy_instance.h"
#include "chrome/browser/extensions/global_shortcut_listener.h"
+#include <set>
Robert Sesek 2013/11/18 15:25:03 #include <map> since you use it.
smus 2013/11/18 23:13:41 Done.
+#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
+#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
+
+#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.
+#include "base/lazy_instance.h"
+#include "base/mac/scoped_nsobject.h"
+
+@class GlobalShortcutListenerTap;
+
namespace extensions {
// Mac-specific implementation of the GlobalShortcutListener class that
@@ -21,6 +30,11 @@
virtual void StartListening() OVERRIDE;
virtual void StopListening() OVERRIDE;
+ // Keyboard event callbacks.
+ bool OnKeyEvent(EventHotKeyID hotKeyID);
+ bool OnMediaKeyEvent(ui::KeyboardCode keyCode);
+
+
Finnur 2013/11/18 11:55:57 nit: Remove line break.
smus 2013/11/18 23:13:41 Done.
private:
friend struct base::DefaultLazyInstanceTraits<GlobalShortcutListenerMac>;
@@ -35,9 +49,29 @@
const ui::Accelerator& accelerator,
GlobalShortcutListener::Observer* observer) OVERRIDE;
+ // Mac-specific function for registering a hotkey.
+ 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.
+ void UnregisterHotKey(ui::Accelerator accelerator);
+
// Whether this object is listening for global shortcuts.
bool is_listening_;
+ 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.
+ // A map of registered accelerators and their registration ids.
+ // 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.
+ typedef std::map< ui::Accelerator, int > HotkeyIdMap;
+ HotkeyIdMap hotkey_ids_;
+ typedef std::map< int, ui::Accelerator > IdHotkeyMap;
+ IdHotkeyMap id_hotkeys_;
+
+ // 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!!!
+ typedef std::map< int, EventHotKeyRef > IdHotkeyRefMap;
+ 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
+
+
Finnur 2013/11/18 11:55:57 nit: Remove line break.
smus 2013/11/18 23:13:41 Done.
+ // 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.
+ base::scoped_nsobject<GlobalShortcutListenerTap> tap_;
+
DISALLOW_COPY_AND_ASSIGN(GlobalShortcutListenerMac);
};

Powered by Google App Engine
This is Rietveld 408576698