diff options
author | zeertzjq <zeertzjq@outlook.com> | 2024-08-17 06:33:13 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-08-17 06:33:13 +0800 |
commit | 4afd4061a23c60de26818bc3847e50c791a8f26c (patch) | |
tree | ba39530bb13e1eb48760f76f8ed7a72385eadbc7 /src/nvim/arglist.c | |
parent | 8b8096500d08d771a936d8ceca25ef5716c3874f (diff) | |
parent | 7df6fbb096b4bedef386236213d72daf45d876aa (diff) | |
download | rneovim-4afd4061a23c60de26818bc3847e50c791a8f26c.tar.gz rneovim-4afd4061a23c60de26818bc3847e50c791a8f26c.tar.bz2 rneovim-4afd4061a23c60de26818bc3847e50c791a8f26c.zip |
Merge pull request #30068 from zeertzjq/vim-9.1.0678
vim-patch:9.1.{0678,0679}
Diffstat (limited to 'src/nvim/arglist.c')
-rw-r--r-- | src/nvim/arglist.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/src/nvim/arglist.c b/src/nvim/arglist.c index e3a2db75e5..bb639edc07 100644 --- a/src/nvim/arglist.c +++ b/src/nvim/arglist.c @@ -203,6 +203,8 @@ void alist_set(alist_T *al, int count, char **files, int use_curbuf, int *fnum_l /// Add file "fname" to argument list "al". /// "fname" must have been allocated and "al" must have been checked for room. /// +/// May trigger Buf* autocommands +/// /// @param set_fnum 1: set buffer number; 2: re-use curbuf void alist_add(alist_T *al, char *fname, int set_fnum) { @@ -213,6 +215,7 @@ void alist_add(alist_T *al, char *fname, int set_fnum) return; } arglist_locked = true; + curwin->w_locked = true; #ifdef BACKSLASH_IN_FILENAME slash_adjust(fname); @@ -225,6 +228,7 @@ void alist_add(alist_T *al, char *fname, int set_fnum) al->al_ga.ga_len++; arglist_locked = false; + curwin->w_locked = false; } #if defined(BACKSLASH_IN_FILENAME) @@ -352,12 +356,14 @@ static void alist_add_list(int count, char **files, int after, bool will_edit) (size_t)(ARGCOUNT - after) * sizeof(aentry_T)); } arglist_locked = true; + curwin->w_locked = true; for (int i = 0; i < count; i++) { const int flags = BLN_LISTED | (will_edit ? BLN_CURBUF : 0); ARGLIST[after + i].ae_fname = files[i]; ARGLIST[after + i].ae_fnum = buflist_add(files[i], flags); } arglist_locked = false; + curwin->w_locked = false; ALIST(curwin)->al_ga.ga_len += count; if (old_argcount > 0 && curwin->w_arg_idx >= after) { curwin->w_arg_idx += count; |