summaryrefslogtreecommitdiff
path: root/src/plugins
diff options
context:
space:
mode:
authorSébastien Helleu <flashcode@flashtux.org>2022-05-27 17:48:13 +0200
committerSébastien Helleu <flashcode@flashtux.org>2022-05-27 22:16:58 +0200
commita1a9303b14ed2a823f7558322e5af0664b17ca4a (patch)
tree99654959691a35a902e6c568af51307013724b63 /src/plugins
parent5ef4731c621c1fb1ed933ad4f83837c00cea84a8 (diff)
downloadweechat-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.c5
-rw-r--r--src/plugins/trigger/trigger-completion.c76
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);
}