diff options
author | Sébastien Helleu <flashcode@flashtux.org> | 2022-05-27 17:48:13 +0200 |
---|---|---|
committer | Sébastien Helleu <flashcode@flashtux.org> | 2022-05-27 22:16:58 +0200 |
commit | a1a9303b14ed2a823f7558322e5af0664b17ca4a (patch) | |
tree | 99654959691a35a902e6c568af51307013724b63 /src/plugins | |
parent | 5ef4731c621c1fb1ed933ad4f83837c00cea84a8 (diff) | |
download | weechat-a1a9303b14ed2a823f7558322e5af0664b17ca4a.zip |
trigger: fix completion of command `/trigger add` when there are spaces in the following arguments
Diffstat (limited to 'src/plugins')
-rw-r--r-- | src/plugins/trigger/trigger-command.c | 5 | ||||
-rw-r--r-- | src/plugins/trigger/trigger-completion.c | 76 |
2 files changed, 77 insertions, 4 deletions
diff --git a/src/plugins/trigger/trigger-command.c b/src/plugins/trigger/trigger-command.c index 7c83d58b4..5c6fac3b4 100644 --- a/src/plugins/trigger/trigger-command.c +++ b/src/plugins/trigger/trigger-command.c @@ -1271,10 +1271,7 @@ trigger_command_init () "name starts with \"resize\":\n" " /trigger monitor @modifier,resize*"), "list|listfull|listdefault" - " || add|addoff|addreplace %(trigger_names) %(trigger_hooks) " - "%(trigger_hook_arguments) %(trigger_hook_conditions) " - "%(trigger_hook_regex) %(trigger_hook_command) %(trigger_hook_rc) " - "%(trigger_post_action)" + " || add|addoff|addreplace %(trigger_add_arguments)|%*" " || addinput %(trigger_hooks)" " || input|output|recreate %(trigger_names)" " || set %(trigger_names) %(trigger_options)|name %(trigger_option_value)" diff --git a/src/plugins/trigger/trigger-completion.c b/src/plugins/trigger/trigger-completion.c index f85542064..17ab2284f 100644 --- a/src/plugins/trigger/trigger-completion.c +++ b/src/plugins/trigger/trigger-completion.c @@ -471,6 +471,76 @@ trigger_completion_post_action_cb (const void *pointer, void *data, return WEECHAT_RC_OK; } +/* + * Adds arguments for commands that add a trigger. + */ + +int +trigger_completion_add_arguments_cb (const void *pointer, void *data, + const char *completion_item, + struct t_gui_buffer *buffer, + struct t_gui_completion *completion) +{ + const char *args, *base_word; + char **sargv; + int sargc, arg_complete; + + args = weechat_completion_get_string (completion, "args"); + if (!args) + return WEECHAT_RC_OK; + + base_word = weechat_completion_get_string (completion, "base_word"); + + sargv = weechat_string_split_shell (args, &sargc); + if (!sargv) + return WEECHAT_RC_OK; + + arg_complete = sargc; + if (base_word && base_word[0]) + arg_complete--; + + switch (arg_complete) + { + case 1: + trigger_completion_triggers_cb (pointer, data, completion_item, + buffer, completion); + break; + case 2: + trigger_completion_hooks_cb (pointer, data, completion_item, + buffer, completion); + break; + case 3: + trigger_completion_hook_arguments_cb (pointer, data, + completion_item, buffer, + completion); + break; + case 4: + trigger_completion_hook_conditions_cb (pointer, data, + completion_item, buffer, + completion); + break; + case 5: + trigger_completion_hook_regex_cb (pointer, data, completion_item, + buffer, completion); + break; + case 6: + trigger_completion_hook_command_cb (pointer, data, completion_item, + buffer, completion); + break; + case 7: + trigger_completion_hook_rc_cb (pointer, data, completion_item, + buffer, completion); + break; + case 8: + trigger_completion_post_action_cb (pointer, data, completion_item, + buffer, completion); + break; + } + + weechat_string_free_split (sargv); + + return WEECHAT_RC_OK; +} /* * Hooks completions. @@ -515,4 +585,10 @@ trigger_completion_init () weechat_hook_completion ("trigger_post_action", N_("trigger post actions"), &trigger_completion_post_action_cb, NULL, NULL); + weechat_hook_completion ("trigger_add_arguments", + N_("arguments for command that adds a trigger: " + "trigger name, hooks, hook arguments, " + "hook conditions, hook regex, hook command, " + "hook return code, post actions"), + &trigger_completion_add_arguments_cb, NULL, NULL); } |