summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSébastien Helleu <flashcode@flashtux.org>2014-06-27 07:54:53 +0200
committerSébastien Helleu <flashcode@flashtux.org>2014-06-27 07:54:53 +0200
commit1a1c50cc01a5a91013b86708dc2a8e5ad330619e (patch)
tree41f1db8017db611cab2a9b45393d024775dbb80c /src
parent6cdcb6feca0a7e040298f3a5e3f867fc93dd6bf8 (diff)
downloadweechat-1a1c50cc01a5a91013b86708dc2a8e5ad330619e.zip
core: add option "env" in command /set
Diffstat (limited to 'src')
-rw-r--r--src/core/wee-command.c134
-rw-r--r--src/core/wee-completion.c81
2 files changed, 200 insertions, 15 deletions
diff --git a/src/core/wee-command.c b/src/core/wee-command.c
index 5daa30b9c..76f6a8e9f 100644
--- a/src/core/wee-command.c
+++ b/src/core/wee-command.c
@@ -37,6 +37,7 @@
#include <time.h>
#include <sys/types.h>
#include <sys/stat.h>
+#include <errno.h>
#include "weechat.h"
#include "wee-command.h"
@@ -5678,13 +5679,106 @@ command_set_display_option_lists (char **argv, int arg_start, int arg_end,
COMMAND_CALLBACK(set)
{
char *value;
- int number_found, rc, display_only_changed, arg_option_start, arg_option_end;
+ const char *ptr_string;
+ int i, number_found, rc, display_only_changed, arg_option_start;
+ int arg_option_end, list_size;
struct t_config_option *ptr_option, *ptr_option_before;
+ struct t_weelist *list;
+ struct t_weelist_item *item;
/* make C compiler happy */
(void) data;
(void) buffer;
+ /* display/set environment variables */
+ if ((argc > 1) && (string_strcasecmp (argv[1], "env") == 0))
+ {
+ if (argc == 2)
+ {
+ /* display a sorted list of all environment variables */
+ list = weelist_new ();
+ if (!list)
+ return WEECHAT_RC_ERROR;
+ for (i = 0; environ[i]; i++)
+ {
+ weelist_add (list, environ[i], WEECHAT_LIST_POS_SORT, NULL);
+ }
+ list_size = weelist_size (list);
+ for (i = 0; i < list_size; i++)
+ {
+ item = weelist_get (list, i);
+ if (item)
+ {
+ ptr_string = weelist_string (item);
+ if (ptr_string)
+ gui_chat_printf (NULL, "%s", ptr_string);
+ }
+ }
+ weelist_free (list);
+ return WEECHAT_RC_OK;
+ }
+
+ if (argc == 3)
+ {
+ /* display an environment variable */
+ value = getenv (argv[2]);
+ if (value)
+ {
+ gui_chat_printf (NULL, "%s=%s", argv[2], value);
+ }
+ else
+ {
+ gui_chat_printf (NULL,
+ _("Environment variable \"%s\" is not "
+ "defined"),
+ argv[2]);
+ }
+ return WEECHAT_RC_OK;
+ }
+
+ /* set/unset an environment variable */
+ value = string_remove_quotes (argv_eol[3], "'\"");
+ if (value && value[0])
+ {
+ /* set variable */
+ if (setenv (argv[2], value, 1) == 0)
+ {
+ gui_chat_printf (NULL, "%s=%s", argv[2], value);
+ }
+ else
+ {
+ gui_chat_printf (NULL,
+ _("%sError: failed to set variable "
+ "\"%s\": %s"),
+ gui_chat_prefix[GUI_CHAT_PREFIX_ERROR],
+ argv[2],
+ strerror (errno));
+ }
+ }
+ else
+ {
+ /* unset variable */
+ if (unsetenv (argv[2]) == 0)
+ {
+ gui_chat_printf (NULL,
+ _("Variable \"%s\" unset"),
+ argv[2]);
+ }
+ else
+ {
+ gui_chat_printf (NULL,
+ _("%sError: failed to unset variable "
+ "\"%s\": %s"),
+ gui_chat_prefix[GUI_CHAT_PREFIX_ERROR],
+ argv[2],
+ strerror (errno));
+ }
+ }
+ if (value)
+ free (value);
+ return WEECHAT_RC_OK;
+ }
+
display_only_changed = 0;
arg_option_start = 1;
arg_option_end = argc - 1;
@@ -7618,20 +7712,22 @@ command_init ()
&command_secure, NULL);
hook_command (
NULL, "set",
- N_("set config options"),
- N_("[<option> [<value>]] || diff [<option> [<option>...]]"),
+ N_("set config options and environment variables"),
+ N_("[<option> [<value>]]"
+ " || diff [<option> [<option>...]]"
+ " || env [<variable> [<value>]]"),
N_("option: name of an option (wildcard \"*\" is allowed)\n"
- " value: new value for option\n"
+ " value: new value for option, according to type:\n"
+ " boolean: on, off or toggle\n"
+ " integer: number, ++number or --number\n"
+ " string: any string (\"\" for empty string)\n"
+ " color: color name, ++number or --number\n"
+ " Note: for all types, you can use null to remove option "
+ " value (undefined value). This works only for some special "
+ " plugin variables.\n"
" diff: display only changed options\n"
- "\n"
- "New value can be, according to variable type:\n"
- " boolean: on, off or toggle\n"
- " integer: number, ++number or --number\n"
- " string: any string (\"\" for empty string)\n"
- " color: color name, ++number or --number\n"
- "\n"
- "For all types, you can use null to remove option value (undefined "
- "value). This works only for some special plugin variables.\n"
+ " env: display or set an environment variable (use value \"\" to "
+ "unset a variable)\n"
"\n"
"Examples:\n"
" display options about highlight:\n"
@@ -7641,9 +7737,17 @@ command_init ()
" display changed options:\n"
" /set diff\n"
" display changed options in irc plugin:\n"
- " /set diff irc.*"),
+ " /set diff irc.*\n"
+ " display value of environment variable LANG:\n"
+ " /set env LANG\n"
+ " set environment variable LANG and use it:\n"
+ " /set env LANG fr_FR.UTF-8\n"
+ " /upgrade\n"
+ " unset environment variable ABC:\n"
+ " /set env ABC \"\""),
"%(config_options) %(config_option_values)"
- " || diff %(config_options)|%*",
+ " || diff %(config_options)|%*"
+ " || env %(env_vars) %(env_value)",
&command_set, NULL);
hook_command (
NULL, "unset",
diff --git a/src/core/wee-completion.c b/src/core/wee-completion.c
index 4bb0c37be..732d3e32b 100644
--- a/src/core/wee-completion.c
+++ b/src/core/wee-completion.c
@@ -1447,6 +1447,81 @@ completion_list_add_secured_data_cb (void *data,
}
/*
+ * Adds environment variables to completion list.
+ */
+
+int
+completion_list_add_env_vars_cb (void *data,
+ const char *completion_item,
+ struct t_gui_buffer *buffer,
+ struct t_gui_completion *completion)
+{
+ int i;
+ char *pos, *name;
+
+ /* make C compiler happy */
+ (void) data;
+ (void) completion_item;
+ (void) buffer;
+
+ for (i = 0; environ[i]; i++)
+ {
+ pos = strchr (environ[i], '=');
+ if (pos)
+ {
+ name = string_strndup (environ[i], pos - environ[i]);
+ if (name)
+ {
+ gui_completion_list_add (completion, name,
+ 0, WEECHAT_LIST_POS_SORT);
+ free (name);
+ }
+ }
+ }
+
+ return WEECHAT_RC_OK;
+}
+
+/*
+ * Adds value of an environment variable to completion list.
+ */
+
+int
+completion_list_add_env_value_cb (void *data,
+ const char *completion_item,
+ struct t_gui_buffer *buffer,
+ struct t_gui_completion *completion)
+{
+ char **argv, *value;
+ int argc;
+
+ /* make C compiler happy */
+ (void) data;
+ (void) completion_item;
+ (void) buffer;
+
+ if (completion->args)
+ {
+ argv = string_split (completion->args, " ", 0, 0, &argc);
+ if (!argv)
+ return WEECHAT_RC_OK;
+
+ if (argc > 0)
+ {
+ value = getenv (argv[argc - 1]);
+ if (value)
+ {
+ gui_completion_list_add (completion, value,
+ 0, WEECHAT_LIST_POS_END);
+ }
+ }
+ string_free_split (argv);
+ }
+
+ return WEECHAT_RC_OK;
+}
+
+/*
* Adds hooks for completions done by WeeChat core.
*/
@@ -1547,4 +1622,10 @@ completion_init ()
hook_completion (NULL, "secured_data",
N_("names of secured data (file sec.conf, section data)"),
&completion_list_add_secured_data_cb, NULL);
+ hook_completion (NULL, "env_vars",
+ N_("environment variables"),
+ &completion_list_add_env_vars_cb, NULL);
+ hook_completion (NULL, "env_value",
+ N_("value of an environment variable"),
+ &completion_list_add_env_value_cb, NULL);
}