From 4b6abfaedf05a232e4737d85c62e0c01e7550203 Mon Sep 17 00:00:00 2001 From: Johannes Altmanninger Date: Tue, 19 Jul 2022 12:02:55 +0200 Subject: [PATCH 1/2] Remove redundant handling of "-add" from set-option completer Switches are removed before invoking a command's completer (look for "std::not_fn(is_switch)". Remove completer code that attempts to handle switches. --- src/commands.cc | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/src/commands.cc b/src/commands.cc index f07c768b..f08acb34 100644 --- a/src/commands.cc +++ b/src/commands.cc @@ -1666,9 +1666,6 @@ const CommandDesc set_option_cmd = { CommandParameters params, size_t token_to_complete, ByteCount pos_in_token) -> Completions { - const bool add = params.size() > 1 and params[0] == "-add"; - const int start = add ? 1 : 0; - static constexpr auto scopes = { "global", "buffer", "window", "current" }; if (token_to_complete == 0) @@ -1680,7 +1677,7 @@ const CommandDesc set_option_cmd = { else if (token_to_complete == 2 and params[2].empty() and GlobalScope::instance().option_registry().option_exists(params[1])) { - OptionManager& options = get_scope(params[start], context).options(); + OptionManager& options = get_scope(params[0], context).options(); return {0_byte, params[2].length(), {options[params[1]].get_as_string(Quoting::Kakoune)}, Completions::Flags::Quoted}; From 23fcf771608fe48d548930fe0097286fbace1ef4 Mon Sep 17 00:00:00 2001 From: Johannes Altmanninger Date: Tue, 19 Jul 2022 23:07:59 +0200 Subject: [PATCH 2/2] Fix autoinfo for "set-option -remove" not showing option-specific info On a command prompt like "set-option -remove buffer aligntab " we fail to show the aligntab-specific info . Fix this by skipping a leading -remove, just like we skip -add. Add an explicit specialization of contains() because otherwise I'd need to write something like contains(Array{"-add", "remove"}, param) --- src/commands.cc | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/commands.cc b/src/commands.cc index f08acb34..f8b9f9f9 100644 --- a/src/commands.cc +++ b/src/commands.cc @@ -1631,11 +1631,11 @@ const CommandDesc source_cmd = { static String option_doc_helper(const Context& context, CommandParameters params) { - const bool add = params.size() > 1 and params[0] == "-add"; - if (params.size() < 2 + (add ? 1 : 0)) + const bool is_switch = params.size() > 1 and (params[0] == "-add" or params[0] == "-remove"); + if (params.size() < 2 + (is_switch ? 1 : 0)) return ""; - auto desc = GlobalScope::instance().option_registry().option_desc(params[1 + (add ? 1 : 0)]); + auto desc = GlobalScope::instance().option_registry().option_desc(params[1 + (is_switch ? 1 : 0)]); if (not desc or desc->docstring().empty()) return "";