summaryrefslogtreecommitdiff
path: root/src/option.c
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2018-09-21 11:59:32 +0200
committerBram Moolenaar <Bram@vim.org>2018-09-21 11:59:32 +0200
commit3f3fb0b14734272e7c817020c847aaa0fba5cea5 (patch)
tree3b8e280f2ab81d97c5391da1baee228b5138baae /src/option.c
parent933bef779a4da4180f9212039363236ff68a33bc (diff)
downloadvim-git-3f3fb0b14734272e7c817020c847aaa0fba5cea5.tar.gz
patch 8.1.0414: v:option_old is cleared when using :set in OptionSet autocmdv8.1.0414
Problem: v:option_old and v:option_new are cleared when using :set in OptionSet autocmd. (Gary Johnson) Solution: Don't trigger OptionSet recursively.
Diffstat (limited to 'src/option.c')
-rw-r--r--src/option.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/src/option.c b/src/option.c
index 818e6911c..763aab07a 100644
--- a/src/option.c
+++ b/src/option.c
@@ -4359,7 +4359,9 @@ trigger_optionsset_string(
char_u *oldval,
char_u *newval)
{
- if (oldval != NULL && newval != NULL)
+ // Don't do this recursively.
+ if (oldval != NULL && newval != NULL
+ && *get_vim_var_str(VV_OPTION_TYPE) == NUL)
{
char_u buf_type[7];
@@ -8858,9 +8860,11 @@ set_bool_option(
options[opt_idx].flags |= P_WAS_SET;
#if defined(FEAT_EVAL)
- if (!starting)
+ // Don't do this while starting up or recursively.
+ if (!starting && *get_vim_var_str(VV_OPTION_TYPE) == NUL)
{
char_u buf_old[2], buf_new[2], buf_type[7];
+
vim_snprintf((char *)buf_old, 2, "%d", old_value ? TRUE: FALSE);
vim_snprintf((char *)buf_new, 2, "%d", value ? TRUE: FALSE);
vim_snprintf((char *)buf_type, 7, "%s", (opt_flags & OPT_LOCAL) ? "local" : "global");
@@ -9415,7 +9419,8 @@ set_num_option(
options[opt_idx].flags |= P_WAS_SET;
#if defined(FEAT_EVAL)
- if (!starting && errmsg == NULL)
+ // Don't do this while starting up, failure or recursively.
+ if (!starting && errmsg == NULL && *get_vim_var_str(VV_OPTION_TYPE) == NUL)
{
char_u buf_old[11], buf_new[11], buf_type[7];
vim_snprintf((char *)buf_old, 10, "%ld", old_value);