summaryrefslogtreecommitdiff
path: root/src/plugins/alias
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2010-03-21 18:30:51 +0100
committerSebastien Helleu <flashcode@flashtux.org>2010-03-21 18:30:51 +0100
commitb40ea94a497b0b6bd76e3b069c49c4f0a7a5f2d2 (patch)
treef57f0c79a2ad31a6b657a62b13a071d86c5d419c /src/plugins/alias
parent7d65014efdd466484867d46a83cee61918d309eb (diff)
downloadweechat-b40ea94a497b0b6bd76e3b069c49c4f0a7a5f2d2.zip
Add custom completion for aliases (task #9479)
Diffstat (limited to 'src/plugins/alias')
-rw-r--r--src/plugins/alias/CMakeLists.txt1
-rw-r--r--src/plugins/alias/Makefile.am2
-rw-r--r--src/plugins/alias/alias-config.c368
-rw-r--r--src/plugins/alias/alias-config.h35
-rw-r--r--src/plugins/alias/alias.c385
-rw-r--r--src/plugins/alias/alias.h9
6 files changed, 552 insertions, 248 deletions
diff --git a/src/plugins/alias/CMakeLists.txt b/src/plugins/alias/CMakeLists.txt
index 04c4ef945..b9b0c0b05 100644
--- a/src/plugins/alias/CMakeLists.txt
+++ b/src/plugins/alias/CMakeLists.txt
@@ -16,6 +16,7 @@
ADD_LIBRARY(alias MODULE
alias.c alias.h
+alias-config.c alias-config.h
alias-info.c alias-info.h)
SET_TARGET_PROPERTIES(alias PROPERTIES PREFIX "")
diff --git a/src/plugins/alias/Makefile.am b/src/plugins/alias/Makefile.am
index 785fa237c..511109f3d 100644
--- a/src/plugins/alias/Makefile.am
+++ b/src/plugins/alias/Makefile.am
@@ -22,6 +22,8 @@ lib_LTLIBRARIES = alias.la
alias_la_SOURCES = alias.c \
alias.h \
+ alias-config.c \
+ alias-config.h \
alias-info.c \
alias-info.h
alias_la_LDFLAGS = -module
diff --git a/src/plugins/alias/alias-config.c b/src/plugins/alias/alias-config.c
new file mode 100644
index 000000000..4657a7d1c
--- /dev/null
+++ b/src/plugins/alias/alias-config.c
@@ -0,0 +1,368 @@
+/*
+ * Copyright (c) 2003-2010 by FlashCode <flashcode@flashtux.org>
+ * See README for License detail, AUTHORS for developers list.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+/* alias-config.c: alias configuration options */
+
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+
+#include "../weechat-plugin.h"
+#include "alias.h"
+
+
+struct t_config_file *alias_config_file = NULL;
+struct t_config_section *alias_config_section_cmd = NULL;
+struct t_config_section *alias_config_section_completion = NULL;
+
+
+/*
+ * alias_config_cmd_change_cb: callback called when alias option is modified
+ * in section "cmd" (command)
+ */
+
+void
+alias_config_cmd_change_cb (void *data, struct t_config_option *option)
+{
+ struct t_config_option *ptr_option_completion;
+
+ /* make C compiler happy */
+ (void) data;
+
+ ptr_option_completion = weechat_config_search_option (alias_config_file,
+ alias_config_section_completion,
+ weechat_config_option_get_pointer (option, "name"));
+
+ alias_new (weechat_config_option_get_pointer (option, "name"),
+ weechat_config_option_get_pointer (option, "value"),
+ (ptr_option_completion) ?
+ weechat_config_option_get_pointer (ptr_option_completion, "value") : NULL);
+}
+
+/*
+ * alias_config_cmd_delete_cb: callback called when alias option is deleted
+ * in section "cmd" (command)
+ */
+
+void
+alias_config_cmd_delete_cb (void *data, struct t_config_option *option)
+{
+ struct t_config_option *ptr_option_completion;
+ struct t_alias *ptr_alias;
+
+ /* make C compiler happy */
+ (void) data;
+
+ ptr_option_completion = weechat_config_search_option (alias_config_file,
+ alias_config_section_completion,
+ weechat_config_option_get_pointer (option, "name"));
+
+ ptr_alias = alias_search (weechat_config_option_get_pointer (option, "name"));
+ if (ptr_alias)
+ alias_free (ptr_alias);
+
+ if (ptr_option_completion)
+ weechat_config_option_free (ptr_option_completion);
+}
+
+/*
+ * alias_config_completion_change_cb: callback called when alias completion is
+ * modified in section "completion"
+ */
+
+void
+alias_config_completion_change_cb (void *data, struct t_config_option *option)
+{
+ struct t_alias *ptr_alias;
+
+ /* make C compiler happy */
+ (void) data;
+
+ ptr_alias = alias_search (weechat_config_option_get_pointer (option, "name"));
+ if (ptr_alias && ptr_alias->hook)
+ {
+ alias_update_completion (ptr_alias,
+ weechat_config_option_get_pointer (option, "value"));
+ }
+}
+
+/*
+ * alias_config_completion_delete_cb: callback called when alias completion is
+ * deleted in section "completion"
+ */
+
+void
+alias_config_completion_delete_cb (void *data, struct t_config_option *option)
+{
+ struct t_alias *ptr_alias;
+
+ /* make C compiler happy */
+ (void) data;
+
+ ptr_alias = alias_search (weechat_config_option_get_pointer (option, "name"));
+ if (ptr_alias && ptr_alias->hook && ptr_alias->completion)
+ {
+ alias_update_completion (ptr_alias, NULL);
+ }
+}
+
+/*
+ * alias_config_reload: reload alias configuration file
+ */
+
+int
+alias_config_reload (void *data, struct t_config_file *config_file)
+{
+ /* make C compiler happy */
+ (void) data;
+
+ weechat_config_section_free_options (alias_config_section_cmd);
+ weechat_config_section_free_options (alias_config_section_completion);
+ alias_free_all ();
+
+ return weechat_config_reload (config_file);
+}
+
+/*
+ * alias_config_cmd_write_default_cb: write default aliases in configuration
+ * file in section "cmd" (command)
+ */
+
+void
+alias_config_cmd_write_default_cb (void *data,
+ struct t_config_file *config_file,
+ const char *section_name)
+{
+ /* make C compiler happy */
+ (void) data;
+
+ weechat_config_write_line (config_file, section_name, NULL);
+
+ weechat_config_write_line (config_file, "AAWAY", "%s", "\"allserv /away\"");
+ weechat_config_write_line (config_file, "AME", "%s", "\"allchan /me\"");
+ weechat_config_write_line (config_file, "AMSG", "%s", "\"allchan /msg *\"");
+ weechat_config_write_line (config_file, "ANICK", "%s", "\"allserv /nick\"");
+ weechat_config_write_line (config_file, "BYE", "%s", "\"quit\"");
+ weechat_config_write_line (config_file, "C", "%s", "\"buffer clear\"");
+ weechat_config_write_line (config_file, "CL", "%s", "\"buffer clear\"");
+ weechat_config_write_line (config_file, "CLOSE", "%s", "\"buffer close\"");
+ weechat_config_write_line (config_file, "CHAT", "%s", "\"dcc chat\"");
+ weechat_config_write_line (config_file, "EXIT", "%s", "\"quit\"");
+ weechat_config_write_line (config_file, "IG", "%s", "\"ignore\"");
+ weechat_config_write_line (config_file, "J", "%s", "\"join\"");
+ weechat_config_write_line (config_file, "K", "%s", "\"kick\"");
+ weechat_config_write_line (config_file, "KB", "%s", "\"kickban\"");
+ weechat_config_write_line (config_file, "LEAVE", "%s", "\"part\"");
+ weechat_config_write_line (config_file, "M", "%s", "\"msg\"");
+ weechat_config_write_line (config_file, "MUB", "%s", "\"unban *\"");
+ weechat_config_write_line (config_file, "N", "%s", "\"names\"");
+ weechat_config_write_line (config_file, "Q", "%s", "\"query\"");
+ weechat_config_write_line (config_file, "REDRAW", "%s", "\"window refresh\"");
+ weechat_config_write_line (config_file, "SAY", "%s", "\"msg *\"");
+ weechat_config_write_line (config_file, "SIGNOFF", "%s", "\"quit\"");
+ weechat_config_write_line (config_file, "T", "%s", "\"topic\"");
+ weechat_config_write_line (config_file, "UB", "%s", "\"unban\"");
+ weechat_config_write_line (config_file, "V", "%s", "\"command core version\"");
+ weechat_config_write_line (config_file, "W", "%s", "\"who\"");
+ weechat_config_write_line (config_file, "WC", "%s", "\"window merge\"");
+ weechat_config_write_line (config_file, "WI", "%s", "\"whois\"");
+ weechat_config_write_line (config_file, "WII", "%s", "\"whois $1 $1\"");
+ weechat_config_write_line (config_file, "WW", "%s", "\"whowas\"");
+}
+
+/*
+ * alias_config_cmd_new_option: create new option in section "cmd" (command)
+ */
+
+void
+alias_config_cmd_new_option (const char *name, const char *command)
+{
+ weechat_config_new_option (alias_config_file, alias_config_section_cmd,
+ name, "string", NULL,
+ NULL, 0, 0, "", command, 0,
+ NULL, NULL,
+ &alias_config_cmd_change_cb, NULL,
+ &alias_config_cmd_delete_cb, NULL);
+}
+
+/*
+ * alias_config_cmd_create_option_cb: create an alias in section "cmd"
+ * (command)
+ */
+
+int
+alias_config_cmd_create_option_cb (void *data,
+ struct t_config_file *config_file,
+ struct t_config_section *section,
+ const char *option_name, const char *value)
+{
+ struct t_alias *ptr_alias;
+ int rc;
+
+ /* make C compiler happy */
+ (void) data;
+ (void) config_file;
+ (void) section;
+
+ rc = WEECHAT_CONFIG_OPTION_SET_ERROR;
+
+ /* create config option */
+ alias_config_cmd_new_option (option_name, value);
+
+ /* create alias */
+ ptr_alias = alias_search (option_name);
+ if (ptr_alias)
+ alias_free (ptr_alias);
+ if (value && value[0])
+ rc = (alias_new (option_name, value, NULL)) ?
+ WEECHAT_CONFIG_OPTION_SET_OK_SAME_VALUE : WEECHAT_CONFIG_OPTION_SET_ERROR;
+ else
+ rc = WEECHAT_CONFIG_OPTION_SET_OK_SAME_VALUE;
+
+ if (rc == WEECHAT_CONFIG_OPTION_SET_ERROR)
+ {
+ weechat_printf (NULL,
+ _("%s%s: error creating alias \"%s\" => \"%s\""),
+ weechat_prefix ("error"), ALIAS_PLUGIN_NAME,
+ option_name, value);
+ }
+
+ return rc;
+}
+
+/*
+ * alias_config_completion_new_option: create new option in section "completion"
+ */
+
+void
+alias_config_completion_new_option (const char *name, const char *completion)
+{
+ weechat_config_new_option (alias_config_file,
+ alias_config_section_completion,
+ name, "string", NULL,
+ NULL, 0, 0, "", completion, 0,
+ NULL, NULL,
+ &alias_config_completion_change_cb, NULL,
+ &alias_config_completion_delete_cb, NULL);
+}
+
+/*
+ * alias_config_completion_create_option_cb: create a completion for an alias
+ * in section "completion"
+ */
+
+int
+alias_config_completion_create_option_cb (void *data,
+ struct t_config_file *config_file,
+ struct t_config_section *section,
+ const char *option_name,
+ const char *value)
+{
+ struct t_alias *ptr_alias;
+
+ /* make C compiler happy */
+ (void) data;
+ (void) config_file;
+ (void) section;
+
+ ptr_alias = alias_search (option_name);
+ if (!ptr_alias)
+ {
+ weechat_printf (NULL,
+ _("%s%s: error creating completion for alias \"%s\": "
+ "alias not found"),
+ weechat_prefix ("error"), ALIAS_PLUGIN_NAME,
+ option_name);
+ return WEECHAT_CONFIG_OPTION_SET_ERROR;
+ }
+
+ /* create config option */
+ alias_config_completion_new_option (option_name, value);
+
+ /* create/update completion in alias */
+ alias_update_completion (ptr_alias, value);
+
+ return WEECHAT_CONFIG_OPTION_SET_OK_SAME_VALUE;
+}
+
+/*
+ * alias_config_init: init alias configuration file
+ * return: 1 if ok, 0 if error
+ */
+
+int
+alias_config_init ()
+{
+ struct t_config_section *ptr_section;
+
+ alias_config_file = weechat_config_new (ALIAS_CONFIG_NAME,
+ &alias_config_reload, NULL);
+ if (!alias_config_file)
+ return 0;
+
+ ptr_section = weechat_config_new_section (alias_config_file, "cmd",
+ 1, 1,
+ NULL, NULL,
+ NULL, NULL,
+ &alias_config_cmd_write_default_cb, NULL,
+ &alias_config_cmd_create_option_cb, NULL,
+ NULL, NULL);
+ if (!ptr_section)
+ {
+ weechat_config_free (alias_config_file);
+ return 0;
+ }
+ alias_config_section_cmd = ptr_section;
+
+ ptr_section = weechat_config_new_section (alias_config_file, "completion",
+ 1, 1,
+ NULL, NULL,
+ NULL, NULL,
+ NULL, NULL,
+ &alias_config_completion_create_option_cb, NULL,
+ NULL, NULL);
+ if (!ptr_section)
+ {
+ weechat_config_free (alias_config_file);
+ return 0;
+ }
+ alias_config_section_completion = ptr_section;
+
+ return 1;
+}
+
+/*
+ * alias_config_read: read alias configuration file
+ */
+
+int
+alias_config_read ()
+{
+ return weechat_config_read (alias_config_file);
+}
+
+/*
+ * alias_config_write: write alias configuration file
+ */
+
+int
+alias_config_write ()
+{
+ return weechat_config_write (alias_config_file);
+}
diff --git a/src/plugins/alias/alias-config.h b/src/plugins/alias/alias-config.h
new file mode 100644
index 000000000..b24427016
--- /dev/null
+++ b/src/plugins/alias/alias-config.h
@@ -0,0 +1,35 @@
+/*
+ * Copyright (c) 2003-2010 by FlashCode <flashcode@flashtux.org>
+ * See README for License detail, AUTHORS for developers list.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+
+#ifndef __WEECHAT_ALIAS_CONFIG_H
+#define __WEECHAT_ALIAS_CONFIG_H 1
+
+extern struct t_config_file *alias_config_file;
+extern struct t_config_section *alias_config_section_cmd;
+extern struct t_config_section *alias_config_section_completion;
+
+extern void alias_config_cmd_new_option (const char *name,
+ const char *command);
+extern void alias_config_completion_new_option (const char *name,
+ const char *completion);
+extern int alias_config_init ();
+extern int alias_config_read ();
+extern int alias_config_write ();
+
+#endif /* alias-config.h */
diff --git a/src/plugins/alias/alias.c b/src/plugins/alias/alias.c
index b59af9f83..9b9492d7e 100644
--- a/src/plugins/alias/alias.c
+++ b/src/plugins/alias/alias.c
@@ -25,6 +25,7 @@
#include "../weechat-plugin.h"
#include "alias.h"
+#include "alias-config.h"
#include "alias-info.h"
@@ -38,9 +39,6 @@ WEECHAT_PLUGIN_LICENSE("GPL3");
struct t_weechat_plugin *weechat_alias_plugin = NULL;
-struct t_config_file *alias_config_file = NULL;
-struct t_config_section *alias_config_section_cmd = NULL;
-
struct t_alias *alias_list = NULL;
struct t_alias *last_alias = NULL;
@@ -331,7 +329,6 @@ alias_cb (void *data, struct t_gui_buffer *buffer, int argc, char **argv,
int some_args_replaced, length1, length2;
/* make C compiler happy */
- (void) argc;
(void) argv;
ptr_alias = (struct t_alias *)data;
@@ -450,6 +447,8 @@ alias_free (struct t_alias *alias)
free (alias->name);
if (alias->command)
free (alias->command);
+ if (alias->completion)
+ free (alias->completion);
free (alias);
alias_list = new_alias_list;
@@ -488,16 +487,70 @@ alias_find_pos (const char *name)
}
/*
+ * alias_hook_command: call weehat_hook_command() for an alias and store result
+ * in variable "hook" of alias
+ */
+
+void
+alias_hook_command (struct t_alias *alias)
+{
+ char *str_completion;
+ int length;
+
+ str_completion = NULL;
+
+ if (!alias->completion)
+ {
+ /*
+ * if alias has no custom completion, then default is to complete with
+ * completion template of target command, for example if alias is
+ * "/alias test /buffer", then str_completion will be "%%buffer"
+ */
+ length = 2 + strlen (alias->command) + 1;
+ str_completion = malloc (length);
+ if (str_completion)
+ {
+ snprintf (str_completion, length, "%%%%%s",
+ (weechat_string_is_command_char (alias->command)) ?
+ weechat_utf8_next_char (alias->command) : alias->command);
+ }
+ }
+
+ alias->hook = weechat_hook_command (alias->name, alias->command,
+ NULL, NULL,
+ (str_completion) ? str_completion : alias->completion,
+ &alias_cb, alias);
+
+ if (str_completion)
+ free (str_completion);
+}
+
+/*
+ * alias_update_completion: update completion for an alias
+ */
+
+void
+alias_update_completion (struct t_alias *alias, const char *completion)
+{
+ /* update completion in alias */
+ if (alias->completion)
+ free (alias->completion);
+ alias->completion = (completion) ? strdup (completion) : NULL;
+
+ /* unhook and hook again command, with new completion */
+ weechat_unhook (alias->hook);
+ alias->hook = NULL;
+ alias_hook_command (alias);
+}
+
+/*
* alias_new: create new alias and add it to alias list
*/
struct t_alias *
-alias_new (const char *name, const char *command)
+alias_new (const char *name, const char *command, const char *completion)
{
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;
@@ -514,30 +567,14 @@ alias_new (const char *name, const char *command)
new_alias = malloc (sizeof (*new_alias));
if (new_alias)
{
- length = 2 + strlen (command) + 1;
- str_completion = malloc (length);
- if (str_completion)
- {
- snprintf (str_completion, length, "%%%%%s",
- (weechat_string_is_command_char (command)) ?
- weechat_utf8_next_char (command) : command);
- }
- new_hook = weechat_hook_command (name, command, NULL, NULL,
- (str_completion) ? str_completion : NULL,
- alias_cb, new_alias);
- if (str_completion)
- free (str_completion);
- if (!new_hook)
- {
- free (new_alias);
- return NULL;
- }
-
- new_alias->hook = new_hook;
+ new_alias->hook = NULL;
new_alias->name = strdup (name);
new_alias->command = strdup (command);
+ new_alias->completion = (completion) ? strdup (completion) : NULL;
new_alias->running = 0;
-
+
+ alias_hook_command (new_alias);
+
if (alias_list)
{
pos_alias = alias_find_pos (name);
@@ -607,199 +644,6 @@ alias_get_final_command (struct t_alias *alias)
}
/*
- * alias_config_change_cb: callback called when alias option is modified
- */
-
-void
-alias_config_change_cb (void *data, struct t_config_option *option)
-{
- /* make C compiler happy */
- (void) data;
-
- alias_new (weechat_config_option_get_pointer (option, "name"),
- weechat_config_option_get_pointer (option, "value"));
-}
-
-/*
- * alias_config_delete_cb: callback called when alias option is deleted
- */
-
-void
-alias_config_delete_cb (void *data, struct t_config_option *option)
-{
- struct t_alias *ptr_alias;
-
- /* make C compiler happy */
- (void) data;
-
- ptr_alias = alias_search (weechat_config_option_get_pointer (option, "name"));
- if (ptr_alias)
- alias_free (ptr_alias);
-}
-
-/*
- * alias_config_reload: reload alias configuration file
- */
-
-int
-alias_config_reload (void *data, struct t_config_file *config_file)
-{
- /* make C compiler happy */
- (void) data;
-
- weechat_config_section_free_options (alias_config_section_cmd);
- alias_free_all ();
-
- return weechat_config_reload (config_file);
-}
-
-/*
- * alias_config_write_default: write default aliases in configuration file
- */
-
-void
-alias_config_write_default (void *data,
- struct t_config_file *config_file,
- const char *section_name)
-{
- /* make C compiler happy */
- (void) data;
-
- weechat_config_write_line (config_file, section_name, NULL);
-
- weechat_config_write_line (config_file, "AAWAY", "%s", "\"allserv /away\"");
- weechat_config_write_line (config_file, "AME", "%s", "\"allchan /me\"");
- weechat_config_write_line (config_file, "AMSG", "%s", "\"allchan /msg *\"");
- weechat_config_write_line (config_file, "ANICK", "%s", "\"allserv /nick\"");
- weechat_config_write_line (config_file, "BYE", "%s", "\"quit\"");
- weechat_config_write_line (config_file, "C", "%s", "\"buffer clear\"");
- weechat_config_write_line (config_file, "CL", "%s", "\"buffer clear\"");
- weechat_config_write_line (config_file, "CLOSE", "%s", "\"buffer close\"");
- weechat_config_write_line (config_file, "CHAT", "%s", "\"dcc chat\"");
- weechat_config_write_line (config_file, "EXIT", "%s", "\"quit\"");
- weechat_config_write_line (config_file, "IG", "%s", "\"ignore\"");
- weechat_config_write_line (config_file, "J", "%s", "\"join\"");
- weechat_config_write_line (config_file, "K", "%s", "\"kick\"");
- weechat_config_write_line (config_file, "KB", "%s", "\"kickban\"");
- weechat_config_write_line (config_file, "LEAVE", "%s", "\"part\"");
- weechat_config_write_line (config_file, "M", "%s", "\"msg\"");
- weechat_config_write_line (config_file, "MUB", "%s", "\"unban *\"");
- weechat_config_write_line (config_file, "N", "%s", "\"names\"");
- weechat_config_write_line (config_file, "Q", "%s", "\"query\"");
- weechat_config_write_line (config_file, "REDRAW", "%s", "\"window refresh\"");
- weechat_config_write_line (config_file, "SAY", "%s", "\"msg *\"");
- weechat_config_write_line (config_file, "SIGNOFF", "%s", "\"quit\"");
- weechat_config_write_line (config_file, "T", "%s", "\"topic\"");
- weechat_config_write_line (config_file, "UB", "%s", "\"unban\"");
- weechat_config_write_line (config_file, "V", "%s", "\"command core version\"");
- weechat_config_write_line (config_file, "W", "%s", "\"who\"");
- weechat_config_write_line (config_file, "WC", "%s", "\"window merge\"");
- weechat_config_write_line (config_file, "WI", "%s", "\"whois\"");
- weechat_config_write_line (config_file, "WII", "%s", "\"whois $1 $1\"");
- weechat_config_write_line (config_file, "WW", "%s", "\"whowas\"");
-}
-
-/*
- * alias_config_create_option: create an alias
- */
-
-int
-alias_config_create_option (void *data, struct t_config_file *config_file,
- struct t_config_section *section,
- const char *option_name, const char *value)
-{
- struct t_alias *ptr_alias;
- int rc;
-
- /* make C compiler happy */
- (void) data;
-
- rc = WEECHAT_CONFIG_OPTION_SET_ERROR;
-
- /* create config option */
- weechat_config_new_option (
- config_file, section,
- option_name, "string", NULL,
- NULL, 0, 0, "", value, 0,
- NULL, NULL,
- &alias_config_change_cb, NULL,
- &alias_config_delete_cb, NULL);
-
- /* create alias */
- ptr_alias = alias_search (option_name);
- if (ptr_alias)
- alias_free (ptr_alias);
- if (value && value[0])
- rc = (alias_new (option_name, value)) ?
- WEECHAT_CONFIG_OPTION_SET_OK_SAME_VALUE : WEECHAT_CONFIG_OPTION_SET_ERROR;
- else
- rc = WEECHAT_CONFIG_OPTION_SET_OK_SAME_VALUE;
-
- if (rc == WEECHAT_CONFIG_OPTION_SET_ERROR)
- {
- weechat_printf (NULL,
- "%s%s: error creating alias \"%s\" => \"%s\"",
- weechat_prefix ("error"), ALIAS_PLUGIN_NAME,
- option_name, value);
- }
-
- return rc;
-}
-
-/*
- * alias_config_init: init alias configuration file
- * return: 1 if ok, 0 if error
- */
-
-int
-alias_config_init ()
-{
- struct t_config_section *ptr_section;
-
- alias_config_file = weechat_config_new (ALIAS_CONFIG_NAME,
- &alias_config_reload, NULL);
- if (!alias_config_file)
- return 0;
-
- ptr_section = weechat_config_new_section (alias_config_file, "cmd",
- 1, 1,
- NULL, NULL,
- NULL, NULL,
- &alias_config_write_default, NULL,
- &alias_config_create_option, NULL,
- NULL, NULL);
- if (!ptr_section)
- {
- weechat_config_free (alias_config_file);
- return 0;
- }
-
- alias_config_section_cmd = ptr_section;
-
- return 1;
-}
-
-/*
- * alias_config_read: read alias configuration file
- */
-
-int
-alias_config_read ()
-{
- return weechat_config_read (alias_config_file);
-}
-
-/*
- * alias_config_write: write alias configuration file
- */
-
-int
-alias_config_write ()
-{
- return weechat_config_write (alias_config_file);
-}
-
-/*
* alias_command_cb: display or create alias
*/
@@ -807,7 +651,7 @@ int
alias_command_cb (void *data, struct t_gui_buffer *buffer, int argc,
char **argv, char **argv_eol)
{
- char *alias_name;
+ char *ptr_completion, *ptr_alias_name, *ptr_command;
struct t_alias *ptr_alias;
struct t_config_option *ptr_option;
int alias_found;
@@ -818,47 +662,71 @@ alias_command_cb (void *data, struct t_gui_buffer *buffer, int argc,
if (argc > 1)
{
- alias_name = (weechat_string_is_command_char (argv[1])) ?
- weechat_utf8_next_char (argv[1]) : argv[1];
if (argc > 2)
{
- /* Define new alias */
- if (!alias_new (alias_name, argv_eol[2]))
+ /* get pointers to completion, alias name and command (+ args) */
+ ptr_completion = NULL;
+ ptr_alias_name = NULL;
+ ptr_command = NULL;
+ if ((argc > 4) && (weechat_strcasecmp (argv[1], "-completion") == 0))
+ {
+ ptr_completion = argv[2];
+ ptr_alias_name = (weechat_string_is_command_char (argv[3])) ?
+ weechat_utf8_next_char (argv[3]) : argv[3];
+ ptr_command = argv_eol[4];
+ }
+ else
+ {
+ ptr_alias_name = (weechat_string_is_command_char (argv[1])) ?
+ weechat_utf8_next_char (argv[1]) : argv[1];
+ ptr_command = argv_eol[2];
+ }
+
+ /* define new alias */
+ if (!alias_new (ptr_alias_name, ptr_command, ptr_completion))
{
weechat_printf (NULL,
_("%s%s: error creating alias \"%s\" "
"=> \"%s\""),
weechat_prefix ("error"), ALIAS_PLUGIN_NAME,
- alias_name, argv_eol[2]);
+ ptr_alias_name, ptr_command);
return WEECHAT_RC_ERROR;
}
- /* create config option */
+ /* create config option for command */
ptr_option = weechat_config_search_option (alias_config_file,
alias_config_section_cmd,
- alias_name);
+ ptr_alias_name);
+ if (ptr_option)
+ weechat_config_option_free (ptr_option);
+ alias_config_cmd_new_option (ptr_alias_name, ptr_command);
+
+ /* create config option for completion */
+ ptr_option = weechat_config_search_option (alias_config_file,
+ alias_config_section_completion,
+ ptr_alias_name);
if (ptr_option)
weechat_config_option_free (ptr_option);
- weechat_config_new_option (
- alias_config_file, alias_config_section_cmd,
- alias_name, "string", NULL,
- NULL, 0, 0, "", argv_eol[2], 0,
- NULL, NULL,
- &alias_config_change_cb, NULL,
- &alias_config_delete_cb, NULL);
+ if (ptr_completion)
+ alias_config_completion_new_option (ptr_alias_name, ptr_completion);
+ /* display message */
weechat_printf (NULL,
_("Alias \"%s\" => \"%s\" created"),
- alias_name, argv_eol[2]);
+ ptr_alias_name, ptr_command);
}
else
{
- /* Display list of aliases */
+ /* get pointer to alias name */
+ ptr_alias_name = (weechat_string_is_command_char (argv[1])) ?
+ weechat_utf8_next_char (argv[1]) : argv[1];
+
+ /* display list of aliases */
alias_found = 0;
for (ptr_alias = alias_list; ptr_alias;
ptr_alias = ptr_alias->next_alias)
{
- if (weechat_string_match (ptr_alias->name, alias_name, 0))
+ if (weechat_string_match (ptr_alias->name, ptr_alias_name, 0))
{
if (!alias_found)
{
@@ -876,7 +744,7 @@ alias_command_cb (void *data, struct t_gui_buffer *buffer, int argc,
if (!alias_found)
{
weechat_printf (NULL, _("No alias found matching \"%s\""),
- alias_name);
+ ptr_alias_name);
}
}
}
@@ -942,12 +810,17 @@ unalias_command_cb (void *data, struct t_gui_buffer *buffer, int argc,
/* remove alias */
alias_free (ptr_alias);
- /* remove option */
+ /* remove options */
ptr_option = weechat_config_search_option (alias_config_file,
alias_config_section_cmd,
alias_name);
if (ptr_option)
weechat_config_option_free (ptr_option);
+ ptr_option = weechat_config_search_option (alias_config_file,
+ alias_config_section_completion,
+ alias_name);
+ if (ptr_option)
+ weechat_config_option_free (ptr_option);
weechat_printf (NULL,
_("Alias \"%s\" removed"),
@@ -1007,6 +880,8 @@ alias_add_to_infolist (struct t_infolist *infolist, struct t_alias *alias)
return 0;
if (!weechat_infolist_new_var_string (ptr_item, "command", alias->command))
return 0;
+ if (!weechat_infolist_new_var_string (ptr_item, "completion", alias->completion))
+ return 0;
if (!weechat_infolist_new_var_integer (ptr_item, "running", alias->running))
return 0;
@@ -1029,7 +904,7 @@ weechat_plugin_init (struct t_weechat_plugin *plugin, int argc, char *argv[])
if (!alias_config_init ())
{
weechat_printf (NULL,
- "%s%s: error creating configuration file",
+ _("%s%s: error creating configuration file"),
weechat_prefix("error"), ALIAS_PLUGIN_NAME);
return WEECHAT_RC_ERROR;
}
@@ -1037,9 +912,13 @@ weechat_plugin_init (struct t_weechat_plugin *plugin, int argc, char *argv[])
weechat_hook_command ("alias",
N_("create an alias for a command"),
- N_("[alias_name [command [arguments]]]"),
- N_("alias_name: name of alias (can start or end with "
- "\"*\" for alias listing)\n"
+ N_("[[-completion completion] alias_name [command "
+ "[arguments]]]"),
+ N_("completion: completion for alias (optional, by "
+ "default completion is done with target "
+ "command)\n"
+ "alias_name: name of alias (can start or end "
+ "with \"*\" for alias listing)\n"
" command: command name (many commands can be "
"separated by semicolons)\n"
" arguments: arguments for command\n\n"
@@ -1055,8 +934,18 @@ weechat_plugin_init (struct t_weechat_plugin *plugin, int argc, char *argv[])
" $~: last argument\n"
" $nick: current nick\n"
" $channel: current channel\n"
- " $server: current server"),
- "%(alias) %(commands)",
+ " $server: current server\n\n"
+ "Examples:\n"
+ " alias /split to split window horizontally:\n"
+ " /alias split /window splith\n"
+ " alias /hello to say \"hello\" on all channels "
+ "but not on #weechat:\n"
+ " /alias hello /allchan -exclude=#weechat msg "
+ "* hello\n"
+ " alias /forcejoin to send IRC command "
+ "\"forcejoin\" with completion of /sajoin:\n"
+ " /alias -completion %%sajoin /quote forcejoin"),
+ "%(alias)|-completion %(commands)",
&alias_command_cb, NULL);
weechat_hook_command ("unalias", N_("remove aliases"),
diff --git a/src/plugins/alias/alias.h b/src/plugins/alias/alias.h
index aa7eb7c3f..57215b6bd 100644
--- a/src/plugins/alias/alias.h
+++ b/src/plugins/alias/alias.h
@@ -30,6 +30,8 @@ struct t_alias
struct t_hook *hook; /* command hook */
char *name; /* alias name */
char *command; /* alias command */
+ char *completion; /* completion for alias (if not set, */
+ /* uses completion of target cmd) */
int running; /* 1 if alias is running */
struct t_alias *prev_alias; /* link to previous alias */
struct t_alias *next_alias; /* link to next alias */
@@ -40,6 +42,13 @@ extern struct t_alias *alias_list;
extern struct t_weechat_plugin *weechat_alias_plugin;
extern int alias_valid (struct t_alias *alias);
+extern struct t_alias *alias_search (const char *alias_name);
+extern void alias_update_completion (struct t_alias *alias,
+ const char *completion);
+extern struct t_alias *alias_new (const char *name, const char *command,
+ const char *completion);
+extern void alias_free (struct t_alias *alias);
+extern void alias_free_all ();
extern int alias_add_to_infolist (struct t_infolist *infolist,
struct t_alias *alias);