diff options
| author | Maxime Coste <frrrwww@gmail.com> | 2012-01-15 03:02:08 +0000 |
|---|---|---|
| committer | Maxime Coste <frrrwww@gmail.com> | 2012-01-15 03:02:08 +0000 |
| commit | f259af9326b4e2140f856f1651eaeb0d74537621 (patch) | |
| tree | 14dd4064c0562500c25c4b3e58f49ed92f292ed7 /src | |
| parent | be5cf9236750eb1fd38f0dd3ebc4da2af1fd87ab (diff) | |
CommandManager: add flags support and IgnoreSemiColons flag
commands are now registred with flags, and the IgnoreSemiColons
flag permit to specify a command which needs all the parameters
on the line, bypassing the command sequence operator ';'.
the hook command is tagged as such.
Diffstat (limited to 'src')
| -rw-r--r-- | src/command_manager.cc | 9 | ||||
| -rw-r--r-- | src/command_manager.hh | 13 | ||||
| -rw-r--r-- | src/main.cc | 10 |
3 files changed, 27 insertions, 5 deletions
diff --git a/src/command_manager.cc b/src/command_manager.cc index 973e95de..33815be4 100644 --- a/src/command_manager.cc +++ b/src/command_manager.cc @@ -9,16 +9,18 @@ namespace Kakoune { void CommandManager::register_command(const std::string& command_name, Command command, + unsigned flags, const CommandCompleter& completer) { - m_commands[command_name] = CommandAndCompleter { command, completer }; + m_commands[command_name] = CommandDescriptor { command, flags, completer }; } void CommandManager::register_command(const std::vector<std::string>& command_names, Command command, + unsigned flags, const CommandCompleter& completer) { for (auto command_name : command_names) - register_command(command_name, command, completer); + register_command(command_name, command, flags, completer); } typedef std::vector<std::pair<size_t, size_t>> TokenList; @@ -97,6 +99,9 @@ void CommandManager::execute(const CommandParameters& params, if (command_it == m_commands.end()) throw command_not_found(*begin); + if (command_it->second.flags & IgnoreSemiColons) + end = params.end(); + command_it->second.command(CommandParameters(begin + 1, end), context); } diff --git a/src/command_manager.hh b/src/command_manager.hh index 6b73b47d..125db6e1 100644 --- a/src/command_manager.hh +++ b/src/command_manager.hh @@ -53,6 +53,12 @@ private: class CommandManager : public Singleton<CommandManager> { public: + enum Flags + { + None = 0, + IgnoreSemiColons = 1, + }; + void execute(const std::string& command_line, const Context& context); void execute(const CommandParameters& params, const Context& context); @@ -60,19 +66,22 @@ public: void register_command(const std::string& command_name, Command command, + unsigned flags = None, const CommandCompleter& completer = CommandCompleter()); void register_command(const std::vector<std::string>& command_names, Command command, + unsigned flags = None, const CommandCompleter& completer = CommandCompleter()); private: - struct CommandAndCompleter + struct CommandDescriptor { Command command; + unsigned flags; CommandCompleter completer; }; - std::unordered_map<std::string, CommandAndCompleter> m_commands; + std::unordered_map<std::string, CommandDescriptor> m_commands; }; } diff --git a/src/main.cc b/src/main.cc index 74cec3ba..6d3c726c 100644 --- a/src/main.cc +++ b/src/main.cc @@ -895,38 +895,46 @@ int main(int argc, char* argv[]) HooksManager hooks_manager; command_manager.register_command(std::vector<std::string>{ "e", "edit" }, edit, + CommandManager::None, PerArgumentCommandCompleter{ complete_filename }); command_manager.register_command(std::vector<std::string>{ "q", "quit" }, quit<false>); command_manager.register_command(std::vector<std::string>{ "q!", "quit!" }, quit<true>); command_manager.register_command(std::vector<std::string>{ "w", "write" }, write_buffer, + CommandManager::None, PerArgumentCommandCompleter{ complete_filename }); command_manager.register_command(std::vector<std::string>{ "wq" }, write_and_quit<false>); command_manager.register_command(std::vector<std::string>{ "wq!" }, write_and_quit<true>); command_manager.register_command(std::vector<std::string>{ "b", "buffer" }, show_buffer, + CommandManager::None, PerArgumentCommandCompleter { std::bind(&BufferManager::complete_buffername, &buffer_manager, _1, _2) }); command_manager.register_command(std::vector<std::string>{ "ah", "addhl" }, add_highlighter, + CommandManager::None, PerArgumentCommandCompleter { std::bind(&HighlighterRegistry::complete_highlighter, &highlighter_registry, _1, _2) }); command_manager.register_command(std::vector<std::string>{ "rh", "rmhl" }, rm_highlighter, + CommandManager::None, PerArgumentCommandCompleter { [&](const std::string& prefix, size_t cursor_pos) { return main_context.window->complete_highlighterid(prefix, cursor_pos); } }); command_manager.register_command(std::vector<std::string>{ "af", "addfilter" }, add_filter, + CommandManager::None, PerArgumentCommandCompleter { std::bind(&FilterRegistry::complete_filter, &filter_registry, _1, _2) }); command_manager.register_command(std::vector<std::string>{ "rf", "rmfilter" }, rm_filter, + CommandManager::None, PerArgumentCommandCompleter { [&](const std::string& prefix, size_t cursor_pos) { return main_context.window->complete_filterid(prefix, cursor_pos); } }); - command_manager.register_command(std::vector<std::string>{ "hook" }, add_hook); + command_manager.register_command(std::vector<std::string>{ "hook" }, add_hook, CommandManager::IgnoreSemiColons); command_manager.register_command(std::vector<std::string>{ "source" }, exec_commands_in_file, + CommandManager::None, PerArgumentCommandCompleter{ complete_filename }); command_manager.register_command(std::vector<std::string>{ "exec" }, exec_string); |
