summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2009-05-08 10:31:15 +0200
committerSebastien Helleu <flashcode@flashtux.org>2009-05-08 10:31:15 +0200
commit2783b512015e0a42b528042a218d0e3a8843b7e5 (patch)
tree9d5e89652388f3615e7383ea0c913946cf85d1c6 /src
parentd3976c2afe608d70724e2d3d59093b6fbb3d230a (diff)
downloadweechat-2783b512015e0a42b528042a218d0e3a8843b7e5.zip
Improve completion: allow a command to use completion of another command (used by alias plugin)
Diffstat (limited to 'src')
-rw-r--r--src/gui/gui-completion.c23
-rw-r--r--src/plugins/alias/alias.c14
2 files changed, 32 insertions, 5 deletions
diff --git a/src/gui/gui-completion.c b/src/gui/gui-completion.c
index 50e4b5328..f41f93bf4 100644
--- a/src/gui/gui-completion.c
+++ b/src/gui/gui-completion.c
@@ -209,7 +209,7 @@ gui_completion_stop (struct t_gui_completion *completion,
*/
struct t_hook *
-gui_completion_search_command (struct t_gui_completion *completion)
+gui_completion_search_command (const char *command)
{
struct t_hook *ptr_hook;
@@ -220,7 +220,7 @@ gui_completion_search_command (struct t_gui_completion *completion)
&& HOOK_COMMAND(ptr_hook, command)
&& HOOK_COMMAND(ptr_hook, command)[0]
&& (string_strcasecmp (HOOK_COMMAND(ptr_hook, command),
- completion->base_command) == 0))
+ command) == 0))
return ptr_hook;
}
@@ -1397,7 +1397,22 @@ gui_completion_get_template_for_args (struct t_gui_completion *completion,
struct t_hook *hook_command)
{
int matching_template;
-
+
+ /* if template refers to another command, search this command and use its
+ template */
+ if ((HOOK_COMMAND(hook_command, cplt_templates)[0][0] == '%')
+ && (HOOK_COMMAND(hook_command, cplt_templates)[0][1] == '%')
+ && (HOOK_COMMAND(hook_command, cplt_templates)[0][1]))
+ {
+ hook_command = gui_completion_search_command (HOOK_COMMAND(hook_command, cplt_templates)[0] + 2);
+ if (!hook_command
+ || ((HOOK_COMMAND(hook_command, cplt_templates)[0][0] == '%')
+ && (HOOK_COMMAND(hook_command, cplt_templates)[0][1] == '%')))
+ {
+ return strdup ("");
+ }
+ }
+
/* if only one template available, then use it */
if (HOOK_COMMAND(hook_command, cplt_num_templates) == 1)
return strdup (HOOK_COMMAND(hook_command, cplt_templates)[0]);
@@ -1432,7 +1447,7 @@ gui_completion_build_list (struct t_gui_completion *completion)
repeat_last = 0;
- ptr_hook = gui_completion_search_command (completion);
+ ptr_hook = gui_completion_search_command (completion->base_command);
if (!ptr_hook || !HOOK_COMMAND(ptr_hook, completion)
|| (strcmp (HOOK_COMMAND(ptr_hook, completion), "-") == 0))
{
diff --git a/src/plugins/alias/alias.c b/src/plugins/alias/alias.c
index ab0dcdc40..0b51c9bdd 100644
--- a/src/plugins/alias/alias.c
+++ b/src/plugins/alias/alias.c
@@ -378,6 +378,8 @@ alias_new (const char *name, const char *command)
{
struct t_alias *new_alias, *ptr_alias, *pos_alias;
struct t_hook *new_hook;
+ char *str_completion;
+ int length;
if (!name || !name[0] || !command || !command[0])
return NULL;
@@ -399,8 +401,18 @@ alias_new (const char *name, const char *command)
new_alias = malloc (sizeof (*new_alias));
if (new_alias)
{
- new_hook = weechat_hook_command (name, "[alias]", NULL, NULL, NULL,
+ length = 2 + strlen (command) + 1;
+ str_completion = malloc (length);
+ if (str_completion)
+ {
+ snprintf (str_completion, length, "%%%%%s",
+ (command[0] == '/') ? command + 1 : command);
+ }
+ new_hook = weechat_hook_command (name, "[alias]", NULL, NULL,
+ (str_completion) ? str_completion : NULL,
alias_cb, new_alias);
+ if (str_completion)
+ free (str_completion);
if (!new_hook)
{
free (new_alias);