| 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 #include "chrome/browser/extensions/api/commands/command_service.h" | 5 #include "chrome/browser/extensions/api/commands/command_service.h" |
| 6 | 6 |
| 7 #include <vector> | 7 #include <vector> |
| 8 | 8 |
| 9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
| 10 #include "base/prefs/scoped_user_pref_update.h" | 10 #include "base/prefs/scoped_user_pref_update.h" |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 47 | 47 |
| 48 std::string GetPlatformKeybindingKeyForAccelerator( | 48 std::string GetPlatformKeybindingKeyForAccelerator( |
| 49 const ui::Accelerator& accelerator, const std::string extension_id) { | 49 const ui::Accelerator& accelerator, const std::string extension_id) { |
| 50 std::string key = extensions::Command::CommandPlatform() + ":" + | 50 std::string key = extensions::Command::CommandPlatform() + ":" + |
| 51 extensions::Command::AcceleratorToString(accelerator); | 51 extensions::Command::AcceleratorToString(accelerator); |
| 52 | 52 |
| 53 // Media keys have a 1-to-many relationship with targets, unlike regular | 53 // Media keys have a 1-to-many relationship with targets, unlike regular |
| 54 // shortcut (1-to-1 relationship). That means two or more extensions can | 54 // shortcut (1-to-1 relationship). That means two or more extensions can |
| 55 // register for the same media key so the extension ID needs to be added to | 55 // register for the same media key so the extension ID needs to be added to |
| 56 // the key to make sure the key is unique. | 56 // the key to make sure the key is unique. |
| 57 if (extensions::CommandService::IsMediaKey(accelerator)) | 57 if (extensions::Command::IsMediaKey(accelerator)) |
| 58 key += ":" + extension_id; | 58 key += ":" + extension_id; |
| 59 | 59 |
| 60 return key; | 60 return key; |
| 61 } | 61 } |
| 62 | 62 |
| 63 bool IsForCurrentPlatform(const std::string& key) { | 63 bool IsForCurrentPlatform(const std::string& key) { |
| 64 return StartsWithASCII( | 64 return StartsWithASCII( |
| 65 key, extensions::Command::CommandPlatform() + ":", true); | 65 key, extensions::Command::CommandPlatform() + ":", true); |
| 66 } | 66 } |
| 67 | 67 |
| (...skipping 15 matching lines...) Expand all Loading... |
| 83 } | 83 } |
| 84 | 84 |
| 85 // Checks if |extension| is permitted to automatically assign the |accelerator| | 85 // Checks if |extension| is permitted to automatically assign the |accelerator| |
| 86 // key. | 86 // key. |
| 87 bool CanAutoAssign(const ui::Accelerator& accelerator, | 87 bool CanAutoAssign(const ui::Accelerator& accelerator, |
| 88 const Extension* extension, | 88 const Extension* extension, |
| 89 Profile* profile, | 89 Profile* profile, |
| 90 bool is_named_command, | 90 bool is_named_command, |
| 91 bool is_global) { | 91 bool is_global) { |
| 92 // Media Keys are non-exclusive, so allow auto-assigning them. | 92 // Media Keys are non-exclusive, so allow auto-assigning them. |
| 93 if (extensions::CommandService::IsMediaKey(accelerator)) | 93 if (extensions::Command::IsMediaKey(accelerator)) |
| 94 return true; | 94 return true; |
| 95 | 95 |
| 96 if (is_global) { | 96 if (is_global) { |
| 97 if (!is_named_command) | 97 if (!is_named_command) |
| 98 return false; // Browser and page actions are not global in nature. | 98 return false; // Browser and page actions are not global in nature. |
| 99 | 99 |
| 100 // Global shortcuts are restricted to (Ctrl|Command)+Shift+[0-9]. | 100 // Global shortcuts are restricted to (Ctrl|Command)+Shift+[0-9]. |
| 101 #if defined OS_MACOSX | 101 #if defined OS_MACOSX |
| 102 if (!accelerator.IsCmdDown()) | 102 if (!accelerator.IsCmdDown()) |
| 103 return false; | 103 return false; |
| (...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 162 ProfileKeyedAPIFactory<CommandService>* CommandService::GetFactoryInstance() { | 162 ProfileKeyedAPIFactory<CommandService>* CommandService::GetFactoryInstance() { |
| 163 return g_factory.Pointer(); | 163 return g_factory.Pointer(); |
| 164 } | 164 } |
| 165 | 165 |
| 166 // static | 166 // static |
| 167 CommandService* CommandService::Get(content::BrowserContext* context) { | 167 CommandService* CommandService::Get(content::BrowserContext* context) { |
| 168 return ProfileKeyedAPIFactory<CommandService>::GetForProfile(context); | 168 return ProfileKeyedAPIFactory<CommandService>::GetForProfile(context); |
| 169 } | 169 } |
| 170 | 170 |
| 171 // static | 171 // static |
| 172 bool CommandService::IsMediaKey(const ui::Accelerator& accelerator) { | |
| 173 if (accelerator.modifiers() != 0) | |
| 174 return false; | |
| 175 | |
| 176 return (accelerator.key_code() == ui::VKEY_MEDIA_NEXT_TRACK || | |
| 177 accelerator.key_code() == ui::VKEY_MEDIA_PREV_TRACK || | |
| 178 accelerator.key_code() == ui::VKEY_MEDIA_PLAY_PAUSE || | |
| 179 accelerator.key_code() == ui::VKEY_MEDIA_STOP); | |
| 180 } | |
| 181 | |
| 182 // static | |
| 183 bool CommandService::RemovesBookmarkShortcut( | 172 bool CommandService::RemovesBookmarkShortcut( |
| 184 const extensions::Extension* extension) { | 173 const extensions::Extension* extension) { |
| 185 using extensions::SettingsOverrides; | 174 using extensions::SettingsOverrides; |
| 186 const SettingsOverrides* settings_overrides = | 175 const SettingsOverrides* settings_overrides = |
| 187 SettingsOverrides::Get(extension); | 176 SettingsOverrides::Get(extension); |
| 188 | 177 |
| 189 return settings_overrides && | 178 return settings_overrides && |
| 190 SettingsOverrides::RemovesBookmarkShortcut(*settings_overrides) && | 179 SettingsOverrides::RemovesBookmarkShortcut(*settings_overrides) && |
| 191 (extensions::PermissionsData::HasAPIPermission( | 180 (extensions::PermissionsData::HasAPIPermission( |
| 192 extension, | 181 extension, |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 254 bool CommandService::AddKeybindingPref( | 243 bool CommandService::AddKeybindingPref( |
| 255 const ui::Accelerator& accelerator, | 244 const ui::Accelerator& accelerator, |
| 256 std::string extension_id, | 245 std::string extension_id, |
| 257 std::string command_name, | 246 std::string command_name, |
| 258 bool allow_overrides, | 247 bool allow_overrides, |
| 259 bool global) { | 248 bool global) { |
| 260 if (accelerator.key_code() == ui::VKEY_UNKNOWN) | 249 if (accelerator.key_code() == ui::VKEY_UNKNOWN) |
| 261 return false; | 250 return false; |
| 262 | 251 |
| 263 // Media Keys are allowed to be used by named command only. | 252 // Media Keys are allowed to be used by named command only. |
| 264 DCHECK(!IsMediaKey(accelerator) || | 253 DCHECK(!Command::IsMediaKey(accelerator) || |
| 265 (command_name != manifest_values::kPageActionCommandEvent && | 254 (command_name != manifest_values::kPageActionCommandEvent && |
| 266 command_name != manifest_values::kBrowserActionCommandEvent)); | 255 command_name != manifest_values::kBrowserActionCommandEvent)); |
| 267 | 256 |
| 268 DictionaryPrefUpdate updater(profile_->GetPrefs(), | 257 DictionaryPrefUpdate updater(profile_->GetPrefs(), |
| 269 prefs::kExtensionCommands); | 258 prefs::kExtensionCommands); |
| 270 base::DictionaryValue* bindings = updater.Get(); | 259 base::DictionaryValue* bindings = updater.Get(); |
| 271 | 260 |
| 272 std::string key = GetPlatformKeybindingKeyForAccelerator(accelerator, | 261 std::string key = GetPlatformKeybindingKeyForAccelerator(accelerator, |
| 273 extension_id); | 262 extension_id); |
| 274 | 263 |
| (...skipping 332 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 607 | 596 |
| 608 return true; | 597 return true; |
| 609 } | 598 } |
| 610 | 599 |
| 611 template <> | 600 template <> |
| 612 void ProfileKeyedAPIFactory<CommandService>::DeclareFactoryDependencies() { | 601 void ProfileKeyedAPIFactory<CommandService>::DeclareFactoryDependencies() { |
| 613 DependsOn(ExtensionCommandsGlobalRegistry::GetFactoryInstance()); | 602 DependsOn(ExtensionCommandsGlobalRegistry::GetFactoryInstance()); |
| 614 } | 603 } |
| 615 | 604 |
| 616 } // namespace extensions | 605 } // namespace extensions |
| OLD | NEW |