Index: content/browser/cocoa/system_hotkey_map.h |
diff --git a/chrome/browser/ui/cocoa/system_hotkey_map.h b/content/browser/cocoa/system_hotkey_map.h |
similarity index 51% |
rename from chrome/browser/ui/cocoa/system_hotkey_map.h |
rename to content/browser/cocoa/system_hotkey_map.h |
index 1c3f9312d0348789812338b41002250f7b6f963d..ed0ab5c2beb94b6cf40bf6632f7fc6ec54265085 100644 |
--- a/chrome/browser/ui/cocoa/system_hotkey_map.h |
+++ b/content/browser/cocoa/system_hotkey_map.h |
@@ -2,33 +2,49 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#ifndef CHROME_BROWSER_UI_COCOA_SYSTEM_HOTKEY_MAP_H_ |
-#define CHROME_BROWSER_UI_COCOA_SYSTEM_HOTKEY_MAP_H_ |
+#ifndef CONTENT_BROWSER_COCOA_SYSTEM_HOTKEY_MAP_H_ |
+#define CONTENT_BROWSER_COCOA_SYSTEM_HOTKEY_MAP_H_ |
-#import <Foundation/Foundation.h> |
+#import <Cocoa/Cocoa.h> |
#include <vector> |
+#include "base/gtest_prod_util.h" |
#include "base/macros.h" |
+#include "content/common/content_export.h" |
+ |
+namespace content { |
struct SystemHotkey; |
-// Maintains a listing of all OSX user modifiable hotkeys. e.g. (cmd + `) |
-class SystemHotkeyMap { |
+// Maintains a listing of all OSX system hotkeys. e.g. (cmd + `) These hotkeys |
+// should have higher priority than web content, so NSEvents that correspond to |
+// a system hotkey should not be passed to the renderer. |
+class CONTENT_EXPORT SystemHotkeyMap { |
public: |
SystemHotkeyMap(); |
~SystemHotkeyMap(); |
+ // Converts the plist stored in |data| into an NSDictionary. Returns nil on |
+ // error. |
+ static NSDictionary* DictionaryFromData(NSData* data); |
+ |
// Parses the property list data commonly stored at |
// ~/Library/Preferences/com.apple.symbolichotkeys.plist |
// Returns false on encountering an irrecoverable error. |
// Can be called multiple times. Only the results from the most recent |
// invocation are stored. |
- bool ParseData(NSData* data); |
+ bool ParseDictionary(NSDictionary* dictionary); |
- // Whether the hotkey has been reserved by the user. |
- bool IsHotkeyReserved(int key_code, int modifiers); |
+ // Whether the event corresponds to a hotkey that has been reserved by the |
+ // system. |
+ bool IsEventReserved(NSEvent* event) const; |
private: |
+ FRIEND_TEST_ALL_PREFIXES(SystemHotkeyMapTest, Parse); |
+ |
+ // Whether the hotkey has been reserved by the user. |
+ bool IsHotkeyReserved(int key_code, int modifiers) const; |
+ |
// Create at least one record of a hotkey that is reserved by the user. |
// Certain system hotkeys automatically reserve multiple key combinations. |
void ReserveHotkey(int key_code, int modifiers, NSString* system_effect); |
@@ -41,4 +57,6 @@ class SystemHotkeyMap { |
DISALLOW_COPY_AND_ASSIGN(SystemHotkeyMap); |
}; |
-#endif // CHROME_BROWSER_UI_COCOA_SYSTEM_HOTKEY_MAP_H_ |
+} // namespace content |
+ |
+#endif // CONTENT_BROWSER_COCOA_SYSTEM_HOTKEY_MAP_H_ |