diff options
Diffstat (limited to 'src/nvim/buffer.c')
| -rw-r--r-- | src/nvim/buffer.c | 21 | 
1 files changed, 3 insertions, 18 deletions
diff --git a/src/nvim/buffer.c b/src/nvim/buffer.c index 628e398fd4..30bd37fe7f 100644 --- a/src/nvim/buffer.c +++ b/src/nvim/buffer.c @@ -1748,21 +1748,14 @@ buf_T *buflist_new(char_u *ffname_arg, char_u *sfname_arg, linenr_T lnum, int fl      buf = curbuf;      // It's like this buffer is deleted.  Watch out for autocommands that      // change curbuf!  If that happens, allocate a new buffer anyway. -    if (curbuf->b_p_bl) { -      apply_autocmds(EVENT_BUFDELETE, NULL, NULL, false, curbuf); -    } -    if (buf == curbuf) { -      apply_autocmds(EVENT_BUFWIPEOUT, NULL, NULL, false, curbuf); +    buf_freeall(buf, BFA_WIPE | BFA_DEL); +    if (buf != curbuf) {  // autocommands deleted the buffer! +      return NULL;      }      if (aborting()) {           // autocmds may abort script processing        xfree(ffname);        return NULL;      } -    if (buf == curbuf) { -      // Make sure 'bufhidden' and 'buftype' are empty -      clear_string_option(&buf->b_p_bh); -      clear_string_option(&buf->b_p_bt); -    }    }    if (buf != curbuf || curbuf == NULL) {      buf = xcalloc(1, sizeof(buf_T)); @@ -1782,14 +1775,6 @@ buf_T *buflist_new(char_u *ffname_arg, char_u *sfname_arg, linenr_T lnum, int fl    buf->b_wininfo = xcalloc(1, sizeof(wininfo_T));    if (buf == curbuf) { -    // free all things allocated for this buffer -    buf_freeall(buf, 0); -    if (buf != curbuf) {         // autocommands deleted the buffer! -      return NULL; -    } -    if (aborting()) {           // autocmds may abort script processing -      return NULL; -    }      free_buffer_stuff(buf, kBffInitChangedtick);  // delete local vars et al.      // Init the options.  | 
