diff options
Diffstat (limited to 'src/nvim/ex_cmds2.c')
| -rw-r--r-- | src/nvim/ex_cmds2.c | 10 | 
1 files changed, 7 insertions, 3 deletions
| diff --git a/src/nvim/ex_cmds2.c b/src/nvim/ex_cmds2.c index 4684a1b31d..15b735dc9e 100644 --- a/src/nvim/ex_cmds2.c +++ b/src/nvim/ex_cmds2.c @@ -1952,14 +1952,17 @@ void ex_next(exarg_T *eap)  void ex_argedit(exarg_T *eap)  {    int i = eap->addr_count ? (int)eap->line2 : curwin->w_arg_idx + 1; +  // Whether curbuf will be reused, curbuf->b_ffname will be set. +  bool curbuf_is_reusable = curbuf_reusable();    if (do_arglist(eap->arg, AL_ADD, i) == FAIL) {      return;    }    maketitle(); -  if (curwin->w_arg_idx == 0 && (curbuf->b_ml.ml_flags & ML_EMPTY) -      && curbuf->b_ffname == NULL) { +  if (curwin->w_arg_idx == 0 +      && (curbuf->b_ml.ml_flags & ML_EMPTY) +      && (curbuf->b_ffname == NULL || curbuf_is_reusable)) {      i = 0;    }    // Edit the argument. @@ -2257,7 +2260,8 @@ static int alist_add_list(int count, char_u **files, int after)      }      for (int i = 0; i < count; i++) {        ARGLIST[after + i].ae_fname = files[i]; -      ARGLIST[after + i].ae_fnum = buflist_add(files[i], BLN_LISTED); +      ARGLIST[after + i].ae_fnum = buflist_add(files[i], +                                               BLN_LISTED | BLN_CURBUF);      }      ALIST(curwin)->al_ga.ga_len += count;      if (old_argcount > 0 && curwin->w_arg_idx >= after) { | 
