| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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_UI_COCOA_EXTENSIONS_EXTENSION_KEYBINDING_REGISTRY_COCOA_H
_ | 5 #ifndef CHROME_BROWSER_UI_COCOA_EXTENSIONS_EXTENSION_KEYBINDING_REGISTRY_COCOA_H
_ |
| 6 #define CHROME_BROWSER_UI_COCOA_EXTENSIONS_EXTENSION_KEYBINDING_REGISTRY_COCOA_H
_ | 6 #define CHROME_BROWSER_UI_COCOA_EXTENSIONS_EXTENSION_KEYBINDING_REGISTRY_COCOA_H
_ |
| 7 | 7 |
| 8 #include <map> | |
| 9 #include <string> | 8 #include <string> |
| 10 #include <utility> | 9 #include <utility> |
| 11 | 10 |
| 12 #include "chrome/browser/extensions/extension_keybinding_registry.h" | 11 #include "chrome/browser/extensions/extension_keybinding_registry.h" |
| 13 #include "ui/base/accelerators/accelerator.h" | 12 #include "ui/base/accelerators/accelerator.h" |
| 14 #include "ui/gfx/native_widget_types.h" | 13 #include "ui/gfx/native_widget_types.h" |
| 15 | 14 |
| 16 class Profile; | 15 class Profile; |
| 17 | 16 |
| 18 namespace content { | 17 namespace content { |
| (...skipping 30 matching lines...) Expand all Loading... |
| 49 // For a given keyboard |event|, see if a known Extension Command registration | 48 // For a given keyboard |event|, see if a known Extension Command registration |
| 50 // exists and route the event to it. Returns true if the event was handled, | 49 // exists and route the event to it. Returns true if the event was handled, |
| 51 // false otherwise. | 50 // false otherwise. |
| 52 bool ProcessKeyEvent(const content::NativeWebKeyboardEvent& event); | 51 bool ProcessKeyEvent(const content::NativeWebKeyboardEvent& event); |
| 53 | 52 |
| 54 protected: | 53 protected: |
| 55 // Overridden from ExtensionKeybindingRegistry: | 54 // Overridden from ExtensionKeybindingRegistry: |
| 56 virtual void AddExtensionKeybinding( | 55 virtual void AddExtensionKeybinding( |
| 57 const extensions::Extension* extension, | 56 const extensions::Extension* extension, |
| 58 const std::string& command_name) OVERRIDE; | 57 const std::string& command_name) OVERRIDE; |
| 59 virtual void RemoveExtensionKeybinding( | 58 virtual void RemoveExtensionKeybindingImpl( |
| 60 const extensions::Extension* extension, | 59 const ui::Accelerator& accelerator, |
| 61 const std::string& command_name) OVERRIDE; | 60 const std::string& command_name) OVERRIDE; |
| 62 | 61 |
| 63 private: | 62 private: |
| 64 // Keeps track of whether shortcut handling is currently suspended. Shortcuts | 63 // Keeps track of whether shortcut handling is currently suspended. Shortcuts |
| 65 // are suspended briefly while capturing which shortcut to assign to an | 64 // are suspended briefly while capturing which shortcut to assign to an |
| 66 // extension command in the Config UI. If handling isn't suspended while | 65 // extension command in the Config UI. If handling isn't suspended while |
| 67 // capturing then trying to assign Ctrl+F to a command would instead result | 66 // capturing then trying to assign Ctrl+F to a command would instead result |
| 68 // in the Find box opening. | 67 // in the Find box opening. |
| 69 static bool shortcut_handling_suspended_; | 68 static bool shortcut_handling_suspended_; |
| 70 | 69 |
| 71 // Weak pointer to the our profile. Not owned by us. | 70 // Weak pointer to the our profile. Not owned by us. |
| 72 Profile* profile_; | 71 Profile* profile_; |
| 73 | 72 |
| 74 // The window we are associated with. | 73 // The window we are associated with. |
| 75 gfx::NativeWindow window_; | 74 gfx::NativeWindow window_; |
| 76 | 75 |
| 77 // Maps an accelerator to a string pair (extension id, command name) for | |
| 78 // commands that have been registered. Unlike its Views counterpart, this map | |
| 79 // contains browserAction and pageAction commands (but does not route those | |
| 80 // events), so that we can query priority handlers in HasPriorityHandler(...). | |
| 81 typedef std::map< ui::Accelerator, | |
| 82 std::pair<std::string, std::string> > EventTargets; | |
| 83 EventTargets event_targets_; | |
| 84 | |
| 85 // The content notification registrar for listening to extension events. | 76 // The content notification registrar for listening to extension events. |
| 86 content::NotificationRegistrar registrar_; | 77 content::NotificationRegistrar registrar_; |
| 87 | 78 |
| 88 DISALLOW_COPY_AND_ASSIGN(ExtensionKeybindingRegistryCocoa); | 79 DISALLOW_COPY_AND_ASSIGN(ExtensionKeybindingRegistryCocoa); |
| 89 }; | 80 }; |
| 90 | 81 |
| 91 #endif // CHROME_BROWSER_UI_COCOA_EXTENSIONS_EXTENSION_KEYBINDING_REGISTRY_COCO
A_H_ | 82 #endif // CHROME_BROWSER_UI_COCOA_EXTENSIONS_EXTENSION_KEYBINDING_REGISTRY_COCO
A_H_ |
| OLD | NEW |