diff options
Diffstat (limited to 'src/nvim/ex_cmds.c')
| -rw-r--r-- | src/nvim/ex_cmds.c | 64 | 
1 files changed, 28 insertions, 36 deletions
| diff --git a/src/nvim/ex_cmds.c b/src/nvim/ex_cmds.c index 1b83677807..9a847a4c0a 100644 --- a/src/nvim/ex_cmds.c +++ b/src/nvim/ex_cmds.c @@ -756,14 +756,6 @@ int do_move(linenr_T line1, linenr_T line2, linenr_T dest)    linenr_T num_lines;  // Num lines moved    linenr_T last_line;  // Last line in file after adding new text -  // Moving lines seems to corrupt the folds, delete folding info now -  // and recreate it when finished.  Don't do this for manual folding, it -  // would delete all folds. -  bool isFolded = hasAnyFolding(curwin) && !foldmethodIsManual(curwin); -  if (isFolded) { -    deleteFoldRecurse(&curwin->w_folds); -  } -    if (dest >= line1 && dest < line2) {      EMSG(_("E134: Move lines into themselves"));      return FAIL; @@ -801,21 +793,29 @@ int do_move(linenr_T line1, linenr_T line2, linenr_T dest)     * their final destination at the new text position -- webb     */    last_line = curbuf->b_ml.ml_line_count; -  mark_adjust(line1, line2, last_line - line2, 0L); -  changed_lines(last_line - num_lines + 1, 0, last_line + 1, num_lines); +  mark_adjust_nofold(line1, line2, last_line - line2, 0L);    if (dest >= line2) { -    mark_adjust(line2 + 1, dest, -num_lines, 0L); +    mark_adjust_nofold(line2 + 1, dest, -num_lines, 0L); +    FOR_ALL_TAB_WINDOWS(tab, win) { +      if (win->w_buffer == curbuf) { +        foldMoveRange(&win->w_folds, line1, line2, dest); +      } +    }      curbuf->b_op_start.lnum = dest - num_lines + 1;      curbuf->b_op_end.lnum = dest;    } else { -    mark_adjust(dest + 1, line1 - 1, num_lines, 0L); +    mark_adjust_nofold(dest + 1, line1 - 1, num_lines, 0L); +    FOR_ALL_TAB_WINDOWS(tab, win) { +      if (win->w_buffer == curbuf) { +        foldMoveRange(&win->w_folds, dest + 1, line1 - 1, line2); +      } +    }      curbuf->b_op_start.lnum = dest + 1;      curbuf->b_op_end.lnum = dest + num_lines;    }    curbuf->b_op_start.col = curbuf->b_op_end.col = 0; -  mark_adjust(last_line - num_lines + 1, last_line, -      -(last_line - dest - extra), 0L); -  changed_lines(last_line - num_lines + 1, 0, last_line + 1, -extra); +  mark_adjust_nofold(last_line - num_lines + 1, last_line, +                     -(last_line - dest - extra), 0L);    /*     * Now we delete the original text -- webb @@ -851,11 +851,6 @@ int do_move(linenr_T line1, linenr_T line2, linenr_T dest)      changed_lines(dest + 1, 0, line1 + num_lines, 0L);    } -  // recreate folds -  if (isFolded) { -    foldUpdateAll(curwin); -  } -    return OK;  } @@ -1013,8 +1008,8 @@ void do_bang(int addr_count, exarg_T *eap, int forceit, int do_in, int do_out)      AppendToRedobuffLit(cmd, -1);      xfree(cmd); -    AppendToRedobuff((char_u *)"\n"); -    bangredo = FALSE; +    AppendToRedobuff("\n"); +    bangredo = false;    }    /*     * Add quotes around the command, for shells that need them. @@ -2284,20 +2279,24 @@ int do_ecmd(        } else {          win_T *the_curwin = curwin; -        // Set the w_closing flag to avoid that autocommands close the window. +        // Set w_closing to avoid that autocommands close the window. +        // Set b_locked for the same reason.          the_curwin->w_closing = true; +        buf->b_locked++; +          if (curbuf == old_curbuf.br_buf) {            buf_copy_options(buf, BCO_ENTER);          }          // Close the link to the current buffer. This will set -        // curwin->w_buffer to NULL. +        // oldwin->w_buffer to NULL.          u_sync(false);          close_buffer(oldwin, curbuf,                       (flags & ECMD_HIDE) || curbuf->terminal ? 0 : DOBUF_UNLOAD,                       false);          the_curwin->w_closing = false; +        buf->b_locked--;          // autocmds may abort script processing          if (aborting() && curwin->w_buffer != NULL) { @@ -2445,11 +2444,6 @@ int do_ecmd(    retval = OK;    /* -   * Reset cursor position, could be used by autocommands. -   */ -  check_cursor(); - -  /*     * Check if we are editing the w_arg_idx file in the argument list.     */    check_arg_idx(curwin); @@ -2964,7 +2958,7 @@ void sub_set_replacement(SubReplacementString sub)  {    xfree(old_sub.sub);    if (sub.additional_elements != old_sub.additional_elements) { -    list_unref(old_sub.additional_elements); +    tv_list_unref(old_sub.additional_elements);    }    old_sub = sub;  } @@ -3583,11 +3577,9 @@ static buf_T *do_sub(exarg_T *eap, proftime_T timeout)                ui_cursor_goto(msg_row, msg_col);                RedrawingDisabled = temp; -              ++no_mapping;                     /* don't map this key */ -              ++allow_keys;                     /* allow special keys */ +              no_mapping++;                     // don't map this key                typed = plain_vgetc(); -              --allow_keys; -              --no_mapping; +              no_mapping--;                /* clear the question */                msg_didout = FALSE;               /* don't scroll up */ @@ -4772,8 +4764,8 @@ void fix_help_buffer(void)    char_u      *p;    char_u      *rt; -  /* set filetype to "help". */ -  set_option_value((char_u *)"ft", 0L, (char_u *)"help", OPT_LOCAL); +  // Set filetype to "help". +  set_option_value("ft", 0L, "help", OPT_LOCAL);    if (!syntax_present(curwin)) {      for (lnum = 1; lnum <= curbuf->b_ml.ml_line_count; ++lnum) { | 
