| OLD | NEW |
| (Empty) | |
| 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 |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #ifndef CHROME_COMMON_EXTENSIONS_API_COMMANDS_COMMANDS_HANDLER_H_ |
| 6 #define CHROME_COMMON_EXTENSIONS_API_COMMANDS_COMMANDS_HANDLER_H_ |
| 7 |
| 8 #include <string> |
| 9 |
| 10 #include "base/memory/scoped_ptr.h" |
| 11 #include "chrome/common/extensions/command.h" |
| 12 #include "chrome/common/extensions/extension.h" |
| 13 #include "chrome/common/extensions/manifest_handler.h" |
| 14 |
| 15 namespace extensions { |
| 16 |
| 17 struct CommandsInfo : public Extension::ManifestData { |
| 18 CommandsInfo(); |
| 19 virtual ~CommandsInfo(); |
| 20 |
| 21 // Optional list of commands (keyboard shortcuts). |
| 22 // These commands are the commands which the extension wants to use, which are |
| 23 // not necessarily the ones it can use, as it might be inactive (see also |
| 24 // Get*Command[s] in CommandService). |
| 25 scoped_ptr<Command> browser_action_command; |
| 26 scoped_ptr<Command> page_action_command; |
| 27 scoped_ptr<Command> script_badge_command; |
| 28 CommandMap named_commands; |
| 29 |
| 30 static const Command* GetBrowserActionCommand(const Extension* extension); |
| 31 static const Command* GetPageActionCommand(const Extension* extension); |
| 32 static const Command* GetScriptBadgeCommand(const Extension* extension); |
| 33 static const CommandMap* GetNamedCommands(const Extension* extension); |
| 34 }; |
| 35 |
| 36 // Parses the "commands" manifest key. |
| 37 class CommandsHandler : public ManifestHandler { |
| 38 public: |
| 39 CommandsHandler(); |
| 40 virtual ~CommandsHandler(); |
| 41 |
| 42 virtual bool Parse(const base::Value* value, |
| 43 Extension* extension, |
| 44 string16* error) OVERRIDE; |
| 45 |
| 46 virtual bool HasNoKey(Extension* extension, string16* error) OVERRIDE; |
| 47 |
| 48 private: |
| 49 // If the extension defines a browser action, but no command for it, then |
| 50 // we synthesize a generic one, so the user can configure a shortcut for it. |
| 51 // No keyboard shortcut will be assigned to it, until the user selects one. |
| 52 void MaybeSetBrowserActionDefault(const Extension* extension, |
| 53 CommandsInfo* info); |
| 54 }; |
| 55 |
| 56 } // namespace extensions |
| 57 |
| 58 #endif // CHROME_COMMON_EXTENSIONS_API_COMMANDS_COMMANDS_HANDLER_H_ |
| OLD | NEW |