diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/nvim/CMakeLists.txt | 1 | ||||
| -rw-r--r-- | src/nvim/buffer.c | 68 | ||||
| -rw-r--r-- | src/nvim/edit.c | 6 | ||||
| -rw-r--r-- | src/nvim/eval.c | 103 | ||||
| -rw-r--r-- | src/nvim/ex_cmds2.c | 8 | ||||
| -rw-r--r-- | src/nvim/ex_docmd.c | 34 | ||||
| -rw-r--r-- | src/nvim/globals.h | 13 | ||||
| -rw-r--r-- | src/nvim/message.c | 87 | ||||
| -rw-r--r-- | src/nvim/misc1.c | 13 | ||||
| -rw-r--r-- | src/nvim/normal.c | 9 | ||||
| -rw-r--r-- | src/nvim/ops.c | 472 | ||||
| -rw-r--r-- | src/nvim/ops.h | 2 | ||||
| -rw-r--r-- | src/nvim/option.c | 24 | ||||
| -rw-r--r-- | src/nvim/option_defs.h | 4 | ||||
| -rw-r--r-- | src/nvim/shada.c | 4 | ||||
| -rw-r--r-- | src/nvim/syntax.c | 17 | ||||
| -rw-r--r-- | src/nvim/testdir/runtest.vim | 3 | ||||
| -rw-r--r-- | src/nvim/tui/input.c | 3 | ||||
| -rw-r--r-- | src/nvim/version.c | 18 | 
19 files changed, 497 insertions, 392 deletions
| diff --git a/src/nvim/CMakeLists.txt b/src/nvim/CMakeLists.txt index 4aaae5172f..feb17e070e 100644 --- a/src/nvim/CMakeLists.txt +++ b/src/nvim/CMakeLists.txt @@ -98,7 +98,6 @@ set(CONV_SOURCES    mbyte.c    memline.c    message.c -  ops.c    regexp.c    screen.c    search.c diff --git a/src/nvim/buffer.c b/src/nvim/buffer.c index 71ec20c788..72724b0ffd 100644 --- a/src/nvim/buffer.c +++ b/src/nvim/buffer.c @@ -2849,7 +2849,7 @@ typedef enum {  /// is "curwin".  ///  /// Items are drawn interspersed with the text that surrounds it -/// Specials: %-<wid>(xxx%) => group, %= => middle marker, %< => truncation +/// Specials: %-<wid>(xxx%) => group, %= => separation marker, %< => truncation  /// Item: %-<minwid>.<maxwid><itemch> All but <itemch> are optional  ///  /// If maxwidth is not zero, the string will be filled at any middle marker @@ -2893,7 +2893,7 @@ int build_stl_str_hl(        Normal,        Empty,        Group, -      Middle, +      Separate,        Highlight,        TabPage,        ClickFunc, @@ -2994,14 +2994,14 @@ int build_stl_str_hl(        continue;      } -    // STL_MIDDLEMARK: Separation place between left and right aligned items. -    if (*fmt_p == STL_MIDDLEMARK) { +    // STL_SEPARATE: Separation place between left and right aligned items. +    if (*fmt_p == STL_SEPARATE) {        fmt_p++;        // Ignored when we are inside of a grouping        if (groupdepth > 0) {          continue;        } -      item[curitem].type = Middle; +      item[curitem].type = Separate;        item[curitem++].start = out_p;        continue;      } @@ -3840,27 +3840,53 @@ int build_stl_str_hl(      width = maxwidth;    // If there is room left in our statusline, and room left in our buffer, -  // add characters at the middle marker (if there is one) to +  // add characters at the separate marker (if there is one) to    // fill up the available space.    } else if (width < maxwidth -               && STRLEN(out) + maxwidth - width + 1 < outlen) { -    for (int item_idx = 0; item_idx < itemcnt; item_idx++) { -      if (item[item_idx].type == Middle) { -        // Move the statusline to make room for the middle characters -        char_u *middle_end = item[item_idx].start + (maxwidth - width); -        STRMOVE(middle_end, item[item_idx].start); - -        // Fill the middle section with our fill character -        for (char_u *s = item[item_idx].start; s < middle_end; s++) -          *s = fillchar; +             && STRLEN(out) + maxwidth - width + 1 < outlen) { +    // Find how many separators there are, which we will use when +    // figuring out how many groups there are. +    int num_separators = 0; +    for (int i = 0; i < itemcnt; i++) { +      if (item[i].type == Separate) { +        num_separators++; +      } +    } -        // Adjust the offset of any items after the middle -        for (item_idx++; item_idx < itemcnt; item_idx++) -          item[item_idx].start += maxwidth - width; +    // If we have separated groups, then we deal with it now +    if (num_separators) { +      // Create an array of the start location for each +      // separator mark. +      int separator_locations[STL_MAX_ITEM]; +      int index = 0; +      for (int i = 0; i < itemcnt; i++) { +        if (item[i].type == Separate) { +          separator_locations[index] = i; +          index++; +        } +      } -        width = maxwidth; -        break; +      int standard_spaces = (maxwidth - width) / num_separators; +      int final_spaces = (maxwidth - width) - +        standard_spaces * (num_separators - 1); + +      for (int i = 0; i < num_separators; i++) { +        int dislocation = (i == (num_separators - 1)) ? +          final_spaces : standard_spaces; +        char_u *sep_loc = item[separator_locations[i]].start + dislocation; +        STRMOVE(sep_loc, item[separator_locations[i]].start); +        for (char_u *s = item[separator_locations[i]].start; s < sep_loc; s++) { +          *s = fillchar; +        } + +        for (int item_idx = separator_locations[i] + 1; +             item_idx < itemcnt; +             item_idx++) { +          item[item_idx].start += dislocation; +        }        } + +      width = maxwidth;      }    } diff --git a/src/nvim/edit.c b/src/nvim/edit.c index 44aaedb9b4..03ef41f849 100644 --- a/src/nvim/edit.c +++ b/src/nvim/edit.c @@ -6952,8 +6952,8 @@ static void ins_reg(void)        AppendCharToRedobuff(literally);        AppendCharToRedobuff(regname); -      do_put(regname, NULL, BACKWARD, 1L, -          (literally == Ctrl_P ? PUT_FIXINDENT : 0) | PUT_CURSEND); +      do_put(regname, NULL, BACKWARD, 1, +             (literally == Ctrl_P ? PUT_FIXINDENT : 0) | PUT_CURSEND);      } else if (insert_reg(regname, literally) == FAIL) {        vim_beep(BO_REG);        need_redraw = true;  // remove the '"' @@ -7701,7 +7701,7 @@ static void ins_mouse(int c)    undisplay_dollar();    tpos = curwin->w_cursor; -  if (do_mouse(NULL, c, BACKWARD, 1L, 0)) { +  if (do_mouse(NULL, c, BACKWARD, 1, 0)) {      win_T   *new_curwin = curwin;      if (curwin != old_curwin && win_valid(old_curwin)) { diff --git a/src/nvim/eval.c b/src/nvim/eval.c index 93816d3ee6..aa5cd676af 100644 --- a/src/nvim/eval.c +++ b/src/nvim/eval.c @@ -1891,7 +1891,7 @@ ex_let_one (          }        }        if (p != NULL) { -        write_reg_contents(*arg == '@' ? '"' : *arg, p, -1, FALSE); +        write_reg_contents(*arg == '@' ? '"' : *arg, p, STRLEN(p), false);          arg_end = arg + 1;        }        xfree(ptofree); @@ -6684,6 +6684,7 @@ static struct fst {    { "acos",              1, 1, f_acos },  // WJMc    { "add",               2, 2, f_add },    { "and",               2, 2, f_and }, +  { "api_info",          0, 0, f_api_info },    { "append",            2, 2, f_append },    { "argc",              0, 0, f_argc },    { "argidx",            0, 0, f_argidx }, @@ -6712,6 +6713,7 @@ static struct fst {    { "byteidx",           2, 2, f_byteidx },    { "byteidxcomp",       2, 2, f_byteidxcomp },    { "call",              2, 3, f_call }, +  { "capture",           1, 1, f_capture },    { "ceil",              1, 1, f_ceil },    { "changenr",          0, 0, f_changenr },    { "char2nr",           1, 2, f_char2nr }, @@ -7466,6 +7468,15 @@ static void f_and(typval_T *argvars, typval_T *rettv)                           & get_tv_number_chk(&argvars[1], NULL);  } + +/// "api_info()" function +static void f_api_info(typval_T *argvars, typval_T *rettv) +{ +  Dictionary metadata = api_metadata(); +  (void)object_to_vim(DICTIONARY_OBJ(metadata), rettv, NULL); +  api_free_dictionary(metadata); +} +  /*   * "append(lnum, string/list)" function   */ @@ -7541,25 +7552,9 @@ static void f_argidx(typval_T *argvars, typval_T *rettv)  static void f_arglistid(typval_T *argvars, typval_T *rettv)  {    rettv->vval.v_number = -1; -  if (argvars[0].v_type != VAR_UNKNOWN) { -    tabpage_T *tp = NULL; -    if (argvars[1].v_type != VAR_UNKNOWN) { -      long n = get_tv_number(&argvars[1]); -      if (n >= 0) { -        tp = find_tabpage(n); -      } -    } else { -      tp = curtab; -    } - -    if (tp != NULL) { -      win_T *wp = find_win_by_nr(&argvars[0], tp); -      if (wp != NULL) { -        rettv->vval.v_number = wp->w_alist->id; -      } -    } -  } else { -    rettv->vval.v_number = curwin->w_alist->id; +  win_T *wp = find_tabwin(&argvars[0], &argvars[1]); +  if (wp != NULL) { +    rettv->vval.v_number = wp->w_alist->id;    }  } @@ -8089,6 +8084,38 @@ static void f_call(typval_T *argvars, typval_T *rettv)    (void)func_call(func, &argvars[1], selfdict, rettv);  } +// "capture(command)" function +static void f_capture(typval_T *argvars, typval_T *rettv) +{ +    int save_msg_silent = msg_silent; +    garray_T *save_capture_ga = capture_ga; + +    if (check_secure()) { +      return; +    } + +    garray_T capture_local; +    capture_ga = &capture_local; +    ga_init(capture_ga, (int)sizeof(char), 80); + +    msg_silent++; +    if (argvars[0].v_type != VAR_LIST) { +      do_cmdline_cmd((char *)get_tv_string(&argvars[0])); +    } else if (argvars[0].vval.v_list != NULL) { +      for (listitem_T *li = argvars[0].vval.v_list->lv_first; +           li != NULL; li = li->li_next) { +        do_cmdline_cmd((char *)get_tv_string(&li->li_tv)); +      } +    } +    msg_silent = save_msg_silent; + +    ga_append(capture_ga, NUL); +    rettv->v_type = VAR_STRING; +    rettv->vval.v_string = capture_ga->ga_data; + +    capture_ga = save_capture_ga; +} +  /*   * "ceil({float})" function   */ @@ -10473,9 +10500,33 @@ find_win_by_nr (    return NULL;  } -/* - * "getwinvar()" function - */ +/// Find window specified by "wvp" in tabpage "tvp". +static win_T *find_tabwin(typval_T *wvp, typval_T *tvp) +{ +  win_T *wp = NULL; +  tabpage_T *tp = NULL; + +  if (wvp->v_type != VAR_UNKNOWN) { +    if (tvp->v_type != VAR_UNKNOWN) { +      long n = get_tv_number(tvp); +      if (n >= 0) { +        tp = find_tabpage(n); +      } +    } else { +      tp = curtab; +    } + +    if (tp != NULL) { +      wp = find_win_by_nr(wvp, tp); +    } +  } else { +    wp = curwin; +  } + +  return wp; +} + +/// "getwinvar()" function  static void f_getwinvar(typval_T *argvars, typval_T *rettv)  {    getwinvar(argvars, rettv, 0); @@ -14920,7 +14971,8 @@ static void f_setreg(typval_T *argvars, typval_T *rettv)      }      *curval++ = NULL; -    write_reg_contents_lst(regname, lstval, -1, append, yank_type, block_len); +    write_reg_contents_lst(regname, lstval, STRLEN(lstval), +                           append, yank_type, block_len);  free_lstval:      while (curallocval > allocval) @@ -14931,7 +14983,8 @@ free_lstval:      if (strval == NULL) {        return;      } -    write_reg_contents_ex(regname, strval, -1, append, yank_type, block_len); +    write_reg_contents_ex(regname, strval, STRLEN(strval), +                          append, yank_type, block_len);    }    rettv->vval.v_number = 0;  } diff --git a/src/nvim/ex_cmds2.c b/src/nvim/ex_cmds2.c index df4a6d52c4..247f86679f 100644 --- a/src/nvim/ex_cmds2.c +++ b/src/nvim/ex_cmds2.c @@ -2010,9 +2010,7 @@ void ex_argdelete(exarg_T *eap)    maketitle();  } -/* - * ":argdo", ":windo", ":bufdo", ":tabdo", ":cdo", ":ldo", ":cfdo" and ":lfdo" - */ +/// ":argdo", ":windo", ":bufdo", ":tabdo", ":cdo", ":ldo", ":cfdo" and ":lfdo"  void ex_listdo(exarg_T *eap)  {    int i; @@ -2060,9 +2058,9 @@ void ex_listdo(exarg_T *eap)      buf_T *buf = curbuf;      size_t qf_size = 0; -    /* set pcmark now */ +    // set pcmark now      if (eap->cmdidx == CMD_bufdo) { -      /* Advance to the first listed buffer after "eap->line1". */ +      // Advance to the first listed buffer after "eap->line1".        for (buf = firstbuf;             buf != NULL && (buf->b_fnum < eap->line1 || !buf->b_p_bl);             buf = buf->b_next) { diff --git a/src/nvim/ex_docmd.c b/src/nvim/ex_docmd.c index b66b5cf3a9..6864e2b914 100644 --- a/src/nvim/ex_docmd.c +++ b/src/nvim/ex_docmd.c @@ -1536,8 +1536,9 @@ static char_u * do_one_cmd(char_u **cmdlinep,      }      ea.cmd = skipwhite(ea.cmd);      lnum = get_address(&ea, &ea.cmd, ea.addr_type, ea.skip, ea.addr_count == 0); -    if (ea.cmd == NULL)                     /* error detected */ +    if (ea.cmd == NULL) {  // error detected        goto doend; +    }      if (lnum == MAXLNUM) {        if (*ea.cmd == '%') {                 /* '%' - all lines */          ++ea.cmd; @@ -4640,14 +4641,14 @@ static struct {    char *name;  } addr_type_complete[] =  { -  {ADDR_ARGUMENTS, "arguments"}, -  {ADDR_LINES, "lines"}, -  {ADDR_LOADED_BUFFERS, "loaded_buffers"}, -  {ADDR_TABS, "tabs"}, -  {ADDR_BUFFERS, "buffers"}, -  {ADDR_WINDOWS, "windows"}, -  {ADDR_QUICKFIX, "quickfix"}, -  {-1, NULL} +  { ADDR_ARGUMENTS, "arguments" }, +  { ADDR_LINES, "lines" }, +  { ADDR_LOADED_BUFFERS, "loaded_buffers" }, +  { ADDR_TABS, "tabs" }, +  { ADDR_BUFFERS, "buffers" }, +  { ADDR_WINDOWS, "windows" }, +  { ADDR_QUICKFIX, "quickfix" }, +  { -1, NULL }  };  /* @@ -7125,8 +7126,8 @@ static void ex_put(exarg_T *eap)      eap->forceit = TRUE;    }    curwin->w_cursor.lnum = eap->line2; -  do_put(eap->regname, NULL, eap->forceit ? BACKWARD : FORWARD, 1L, -      PUT_LINE|PUT_CURSLINE); +  do_put(eap->regname, NULL, eap->forceit ? BACKWARD : FORWARD, 1, +         PUT_LINE|PUT_CURSLINE);  }  /* @@ -7135,7 +7136,7 @@ static void ex_put(exarg_T *eap)  static void ex_copymove(exarg_T *eap)  {    long n = get_address(eap, &eap->arg, eap->addr_type, false, false); -  if (eap->arg == NULL) {           /* error detected */ +  if (eap->arg == NULL) {  // error detected      eap->nextcmd = NULL;      return;    } @@ -7354,10 +7355,11 @@ static void ex_redir(exarg_T *eap)            /* Can use both "@a" and "@a>". */            if (*arg == '>')              arg++; -          /* Make register empty when not using @A-@Z and the -           * command is valid. */ -          if (*arg == NUL && !isupper(redir_reg)) -            write_reg_contents(redir_reg, (char_u *)"", -1, FALSE); +          // Make register empty when not using @A-@Z and the +          // command is valid. +          if (*arg == NUL && !isupper(redir_reg)) { +            write_reg_contents(redir_reg, (char_u *)"", 0, false); +          }          }        }        if (*arg != NUL) { diff --git a/src/nvim/globals.h b/src/nvim/globals.h index f618e5ffc4..42fde50bee 100644 --- a/src/nvim/globals.h +++ b/src/nvim/globals.h @@ -836,8 +836,8 @@ EXTERN int* (*iconv_errno)(void);  EXTERN int State INIT(= NORMAL);        /* This is the current state of the                                           * command interpreter. */ -EXTERN int finish_op INIT(= FALSE);     /* TRUE while an operator is pending */ -EXTERN long opcount INIT(= 0);          /* count for pending operator */ +EXTERN bool finish_op INIT(= false);    // true while an operator is pending +EXTERN long opcount INIT(= 0);          // count for pending operator  /*   * ex mode (Q) state @@ -985,10 +985,11 @@ EXTERN int keep_help_flag INIT(= FALSE);      /* doing :ta from help file */   */  EXTERN char_u   *empty_option INIT(= (char_u *)""); -EXTERN int redir_off INIT(= FALSE);     /* no redirection for a moment */ -EXTERN FILE *redir_fd INIT(= NULL);     /* message redirection file */ -EXTERN int redir_reg INIT(= 0);         /* message redirection register */ -EXTERN int redir_vname INIT(= 0);       /* message redirection variable */ +EXTERN int redir_off INIT(= false);         // no redirection for a moment +EXTERN FILE *redir_fd INIT(= NULL);         // message redirection file +EXTERN int redir_reg INIT(= 0);             // message redirection register +EXTERN int redir_vname INIT(= 0);           // message redirection variable +EXTERN garray_T *capture_ga INIT(= NULL);   // capture() buffer  EXTERN char_u langmap_mapchar[256];     /* mapping for language keys */ diff --git a/src/nvim/message.c b/src/nvim/message.c index 521db85cf0..77e8f0e4f2 100644 --- a/src/nvim/message.c +++ b/src/nvim/message.c @@ -493,10 +493,11 @@ int emsg(char_u *s)       * when the message should be ignored completely (used for the       * interrupt message).       */ -    if (cause_errthrow(s, severe, &ignore) == TRUE) { -      if (!ignore) -        did_emsg = TRUE; -      return TRUE; +    if (cause_errthrow(s, severe, &ignore) == true) { +      if (!ignore) { +        did_emsg = true; +      } +      return true;      }      // set "v:errmsg", also when using ":silent! cmd" @@ -511,41 +512,43 @@ int emsg(char_u *s)        p = get_emsg_source();        if (p != NULL) {          STRCAT(p, "\n"); -        redir_write(p, -1); +        redir_write(p, STRLEN(p));          xfree(p);        }        p = get_emsg_lnum();        if (p != NULL) {          STRCAT(p, "\n"); -        redir_write(p, -1); +        redir_write(p, STRLEN(p));          xfree(p);        } -      redir_write(s, -1); -      return TRUE; +      redir_write(s, STRLEN(s)); +      return true;      } -    /* Reset msg_silent, an error causes messages to be switched back on. */ +    // Reset msg_silent, an error causes messages to be switched back on.      msg_silent = 0;      cmd_silent = FALSE; -    if (global_busy)                    /* break :global command */ -      ++global_busy; +    if (global_busy) {        // break :global command +      global_busy++; +    } -    if (p_eb) -      beep_flush();                     /* also includes flush_buffers() */ -    else -      flush_buffers(FALSE);             /* flush internal buffers */ -    did_emsg = TRUE;                    /* flag for DoOneCmd() */ +    if (p_eb) { +      beep_flush();           // also includes flush_buffers() +    } else { +      flush_buffers(false);   // flush internal buffers +    } +    did_emsg = true;          // flag for DoOneCmd()    } -  emsg_on_display = TRUE;       /* remember there is an error message */ -  ++msg_scroll;                 /* don't overwrite a previous message */ -  attr = hl_attr(HLF_E);        /* set highlight mode for error messages */ -  if (msg_scrolled != 0) -    need_wait_return = TRUE;        /* needed in case emsg() is called after -                                     * wait_return has reset need_wait_return -                                     * and a redraw is expected because -                                     * msg_scrolled is non-zero */ +  emsg_on_display = true;     // remember there is an error message +  msg_scroll++;               // don't overwrite a previous message +  attr = hl_attr(HLF_E);      // set highlight mode for error messages +  if (msg_scrolled != 0) { +    need_wait_return = true;  // needed in case emsg() is called after +  }                           // wait_return has reset need_wait_return +                              // and a redraw is expected because +                              // msg_scrolled is non-zero    /*     * Display name and line number for the source of the error. @@ -2389,6 +2392,19 @@ static void redir_write(char_u *str, int maxlen)    char_u      *s = str;    static int cur_col = 0; +  if (maxlen == 0) { +    return; +  } + +  // Append output to capture(). +  if (capture_ga) { +    size_t len = 0; +    while (str[len] && (maxlen < 0 ? 1 : (len < (size_t)maxlen))) { +      len++; +    } +    ga_concat_len(capture_ga, (const char *)str, len); +  } +    /* Don't do anything for displaying prompts and the like. */    if (redir_off)      return; @@ -2401,22 +2417,27 @@ static void redir_write(char_u *str, int maxlen)      /* If the string doesn't start with CR or NL, go to msg_col */      if (*s != '\n' && *s != '\r') {        while (cur_col < msg_col) { -        if (redir_reg) -          write_reg_contents(redir_reg, (char_u *)" ", -1, TRUE); -        else if (redir_vname) +        if (redir_reg) { +          write_reg_contents(redir_reg, (char_u *)" ", 1, true); +        } else if (redir_vname) {            var_redir_str((char_u *)" ", -1); -        else if (redir_fd != NULL) +        } else if (redir_fd != NULL) {            fputs(" ", redir_fd); -        if (verbose_fd != NULL) +        } +        if (verbose_fd != NULL) {            fputs(" ", verbose_fd); -        ++cur_col; +        } +        cur_col++;        }      } -    if (redir_reg) -      write_reg_contents(redir_reg, s, maxlen, TRUE); -    if (redir_vname) +    if (redir_reg) { +      size_t len = maxlen == -1 ? STRLEN(s) : (size_t)maxlen; +      write_reg_contents(redir_reg, s, len, true); +    } +    if (redir_vname) {        var_redir_str(s, maxlen); +    }      /* Write and adjust the current column. */      while (*s != NUL && (maxlen < 0 || (int)(s - str) < maxlen)) { diff --git a/src/nvim/misc1.c b/src/nvim/misc1.c index 48791384a6..d72d8e8513 100644 --- a/src/nvim/misc1.c +++ b/src/nvim/misc1.c @@ -178,12 +178,11 @@ open_line (    if (curbuf->b_p_ai        || do_si        ) { -    /* -     * count white space on current line -     */ -    newindent = get_indent_str(saved_line, (int)curbuf->b_p_ts, FALSE); -    if (newindent == 0 && !(flags & OPENLINE_COM_LIST)) -      newindent = second_line_indent;       /* for ^^D command in insert mode */ +    // count white space on current line +    newindent = get_indent_str(saved_line, (int)curbuf->b_p_ts, false); +    if (newindent == 0 && !(flags & OPENLINE_COM_LIST)) { +      newindent = second_line_indent;  // for ^^D command in insert mode +    }      /*       * Do smart indenting. @@ -612,7 +611,7 @@ open_line (          if (curbuf->b_p_ai              || do_si              ) -          newindent = get_indent_str(leader, (int)curbuf->b_p_ts, FALSE); +          newindent = get_indent_str(leader, (int)curbuf->b_p_ts, false);          /* Add the indent offset */          if (newindent + off < 0) { diff --git a/src/nvim/normal.c b/src/nvim/normal.c index d4055ac1ef..c95e5e1a15 100644 --- a/src/nvim/normal.c +++ b/src/nvim/normal.c @@ -1795,10 +1795,11 @@ void do_pending_operator(cmdarg_T *cap, int old_col, bool gui_yank)        if (oap->line_count < 2)          oap->line_count = 2;        if (curwin->w_cursor.lnum + oap->line_count - 1 > -          curbuf->b_ml.ml_line_count) +          curbuf->b_ml.ml_line_count) {          beep_flush(); -      else { -        do_join(oap->line_count, oap->op_type == OP_JOIN, true, true, true); +      } else { +        do_join((size_t)oap->line_count, oap->op_type == OP_JOIN, +                true, true, true);          auto_format(false, true);        }        break; @@ -7666,7 +7667,7 @@ static void nv_join(cmdarg_T *cap)      prep_redo(cap->oap->regname, cap->count0,                NUL, cap->cmdchar, NUL, NUL, cap->nchar); -    do_join(cap->count0, cap->nchar == NUL, true, true, true); +    do_join((size_t)cap->count0, cap->nchar == NUL, true, true, true);    }  } diff --git a/src/nvim/ops.c b/src/nvim/ops.c index adfd0424f0..cb068aa37f 100644 --- a/src/nvim/ops.c +++ b/src/nvim/ops.c @@ -1,6 +1,6 @@  /*   * ops.c: implementation of various operators: op_shift, op_delete, op_tilde, - *	  op_change, op_yank, do_put, do_join + *        op_change, op_yank, do_put, do_join   */  #include <assert.h> @@ -257,8 +257,7 @@ void op_shift(oparg_T *oap, int curs_top, int amount)   * shift the current line one shiftwidth left (if left != 0) or right   * leaves cursor on first blank in the line   */ -void  -shift_line ( +void shift_line(      int left,      int round,      int amount, @@ -369,18 +368,18 @@ static void shift_block(oparg_T *oap, int amount)      memset(newp + bd.textcol + i, ' ', (size_t)j);      /* the end */      memmove(newp + bd.textcol + i + j, bd.textstart, (size_t)len); -  } else { /* left */ -    colnr_T destination_col;            /* column to which text in block will -                                           be shifted */ -    char_u      *verbatim_copy_end;     /* end of the part of the line which is -                                           copied verbatim */ -    colnr_T verbatim_copy_width;        /* the (displayed) width of this part -                                           of line */ -    unsigned fill;                      /* nr of spaces that replace a TAB */ -    unsigned new_line_len;              /* the length of the line after the -                                           block shift */ -    size_t block_space_width; -    size_t shift_amount; +  } else {  // left +    colnr_T destination_col;      // column to which text in block will +                                  // be shifted +    char_u *verbatim_copy_end;    // end of the part of the line which is +                                  // copied verbatim +    colnr_T verbatim_copy_width;  // the (displayed) width of this part +                                  // of line +    size_t fill;                  // nr of spaces that replace a TAB +    size_t new_line_len;          // the length of the line after the +                                  // block shift +    colnr_T block_space_width; +    colnr_T shift_amount;      char_u      *non_white = bd.textstart;      colnr_T non_white_col; @@ -409,11 +408,10 @@ static void shift_block(oparg_T *oap, int amount)      block_space_width = non_white_col - oap->start_vcol;      /* We will shift by "total" or "block_space_width", whichever is less.       */ -    shift_amount = (block_space_width < (size_t)total -                    ? block_space_width : (size_t)total); +    shift_amount = (block_space_width < total ? block_space_width : total); -    /* The column to which we will shift the text.  */ -    destination_col = (colnr_T)(non_white_col - shift_amount); +    // The column to which we will shift the text. +    destination_col = non_white_col - shift_amount;      /* Now let's find out how much of the beginning of the line we can       * reuse without modification.  */ @@ -439,20 +437,21 @@ static void shift_block(oparg_T *oap, int amount)      /* If "destination_col" is different from the width of the initial      * part of the line that will be copied, it means we encountered a tab      * character, which we will have to partly replace with spaces.  */ -    fill = destination_col - verbatim_copy_width; - -    /* The replacement line will consist of: -     * - the beginning of the original line up to "verbatim_copy_end", -     * - "fill" number of spaces, -     * - the rest of the line, pointed to by non_white.  */ -    new_line_len = (unsigned)(verbatim_copy_end - oldp) -                   + fill -                   + (unsigned)STRLEN(non_white) + 1; - -    newp = (char_u *) xmalloc((size_t)(new_line_len)); -    memmove(newp, oldp, (size_t)(verbatim_copy_end - oldp)); -    memset(newp + (verbatim_copy_end - oldp), ' ', (size_t)fill); -    STRMOVE(newp + (verbatim_copy_end - oldp) + fill, non_white); +    assert(destination_col - verbatim_copy_width >= 0); +    fill = (size_t)(destination_col - verbatim_copy_width); + +    assert(verbatim_copy_end - oldp >= 0); +    size_t verbatim_diff = (size_t)(verbatim_copy_end - oldp); +    // The replacement line will consist of: +    // - the beginning of the original line up to "verbatim_copy_end", +    // - "fill" number of spaces, +    // - the rest of the line, pointed to by non_white. +    new_line_len = verbatim_diff + fill + STRLEN(non_white) + 1; + +    newp = (char_u *) xmalloc(new_line_len); +    memmove(newp, oldp, verbatim_diff); +    memset(newp + verbatim_diff, ' ', fill); +    STRMOVE(newp + verbatim_diff + fill, non_white);    }    /* replace the line */    ml_replace(curwin->w_cursor.lnum, newp, FALSE); @@ -469,21 +468,20 @@ static void shift_block(oparg_T *oap, int amount)  static void block_insert(oparg_T *oap, char_u *s, int b_insert, struct block_def *bdp)  {    int p_ts; -  int count = 0;                /* extra spaces to replace a cut TAB */ -  int spaces = 0;               /* non-zero if cutting a TAB */ -  colnr_T offset;               /* pointer along new line */ -  unsigned s_len;               /* STRLEN(s) */ -  char_u      *newp, *oldp;     /* new, old lines */ -  linenr_T lnum;                /* loop var */ +  int count = 0;                // extra spaces to replace a cut TAB +  int spaces = 0;               // non-zero if cutting a TAB +  colnr_T offset;               // pointer along new line +  size_t s_len = STRLEN(s); +  char_u      *newp, *oldp;     // new, old lines +  linenr_T lnum;                // loop var    int oldstate = State; - -  State = INSERT;               /* don't want REPLACE for State */ -  s_len = (unsigned)STRLEN(s); +  State = INSERT;               // don't want REPLACE for State    for (lnum = oap->start.lnum + 1; lnum <= oap->end.lnum; lnum++) { -    block_prep(oap, bdp, lnum, TRUE); -    if (bdp->is_short && b_insert) -      continue;         /* OP_INSERT, line ends before block start */ +    block_prep(oap, bdp, lnum, true); +    if (bdp->is_short && b_insert) { +      continue;  // OP_INSERT, line ends before block start +    }      oldp = ml_get(lnum); @@ -523,25 +521,26 @@ static void block_insert(oparg_T *oap, char_u *s, int b_insert, struct block_def        count -= off;      } -    newp = (char_u *) xmalloc((size_t)(STRLEN(oldp) + s_len + count + 1)); +    assert(count >= 0); +    newp = (char_u *)xmalloc(STRLEN(oldp) + s_len + (size_t)count + 1); -    /* copy up to shifted part */ -    memmove(newp, oldp, (size_t)(offset)); +    // copy up to shifted part +    memmove(newp, oldp, (size_t)offset);      oldp += offset; -    /* insert pre-padding */ +    // insert pre-padding      memset(newp + offset, ' ', (size_t)spaces); -    /* copy the new text */ -    memmove(newp + offset + spaces, s, (size_t)s_len); -    offset += s_len; +    // copy the new text +    memmove(newp + offset + spaces, s, s_len); +    offset += (int)s_len;      if (spaces && !bdp->is_short) { -      /* insert post-padding */ +      // insert post-padding        memset(newp + offset + spaces, ' ', (size_t)(p_ts - spaces)); -      /* We're splitting a TAB, don't copy it. */ +      // We're splitting a TAB, don't copy it.        oldp++; -      /* We allowed for that TAB, remember this now */ +      // We allowed for that TAB, remember this now        count++;      } @@ -804,7 +803,7 @@ yankreg_T *copy_register(int name)      copy->y_array = NULL;    } else {      copy->y_array = xcalloc(copy->y_size, sizeof(char_u *)); -    for (linenr_T i = 0; i < copy->y_size; i++) { +    for (size_t i = 0; i < copy->y_size; i++) {        copy->y_array[i] = vim_strsave(reg->y_array[i]);      }    } @@ -888,7 +887,7 @@ static void set_yreg_additional_data(yankreg_T *reg, dict_T *additional_data)  /*   * Stuff string "p" into yank register "regname" as a single line (append if - * uppercase).	"p" must have been alloced. + * uppercase). "p" must have been alloced.   *   * return FAIL for failure, OK otherwise   */ @@ -940,10 +939,8 @@ do_execreg (      int silent                     /* set "silent" flag in typeahead buffer */  )  { -  long i; -  char_u      *p; +  char_u *p;    int retval = OK; -  int remap;    if (regname == '@') {                 /* repeat previous one */      if (execreg_lastc == NUL) { @@ -1001,21 +998,20 @@ do_execreg (      if (reg->y_array == NULL)        return FAIL; -    /* Disallow remaping for ":@r". */ -    remap = colon ? REMAP_NONE : REMAP_YES; +    // Disallow remaping for ":@r". +    int remap = colon ? REMAP_NONE : REMAP_YES;      /*       * Insert lines into typeahead buffer, from last one to first one.       */      put_reedit_in_typebuf(silent); -    for (i = reg->y_size - 1; i >= 0; i--) { -      char_u *escaped; - +    char_u *escaped; +    for (size_t i = reg->y_size; i-- > 0;) {  // from y_size - 1 to 0 included        // insert NL between lines and after last line if type is kMTLineWise -      if (reg->y_type == kMTLineWise || i < reg->y_size - 1 -          || addcr) { -        if (ins_typebuf((char_u *)"\n", remap, 0, TRUE, silent) == FAIL) +      if (reg->y_type == kMTLineWise || i < reg->y_size - 1 || addcr) { +        if (ins_typebuf((char_u *)"\n", remap, 0, true, silent) == FAIL) {            return FAIL; +        }        }        escaped = vim_strsave_escape_csi(reg->y_array[i]);        retval = ins_typebuf(escaped, remap, 0, TRUE, silent); @@ -1045,7 +1041,7 @@ static void put_reedit_in_typebuf(int silent)        buf[1] = 'R';        buf[2] = NUL;      } else { -      buf[0] = restart_edit == 'I' ? 'i' : restart_edit; +      buf[0] = (char_u)(restart_edit == 'I' ? 'i' : restart_edit);        buf[1] = NUL;      }      if (ins_typebuf(buf, REMAP_NONE, 0, TRUE, silent) == OK) @@ -1059,8 +1055,7 @@ static void put_reedit_in_typebuf(int silent)   * When "esc" is TRUE it is to be taken literally: Escape CSI characters and   * no remapping.   */ -static int  -put_in_typebuf ( +static int put_in_typebuf(      char_u *s,      int esc,      int colon,                  /* add ':' before the line */ @@ -1098,13 +1093,11 @@ put_in_typebuf (   *   * return FAIL for failure, OK otherwise   */ -int  -insert_reg ( +int insert_reg(      int regname,      int literally                  /* insert literally, not as if typed */  )  { -  long i;    int retval = OK;    char_u      *arg;    int allocated; @@ -1132,10 +1125,10 @@ insert_reg (        xfree(arg);    } else {                            /* name or number register */      yankreg_T *reg = get_yank_register(regname, YREG_PASTE); -    if (reg->y_array == NULL) +    if (reg->y_array == NULL) {        retval = FAIL; -    else { -      for (i = 0; i < reg->y_size; i++) { +    } else { +      for (size_t i = 0; i < reg->y_size; i++) {          stuffescaped(reg->y_array[i], literally);          // Insert a newline between lines and after last line if          // y_type is kMTLineWise. @@ -1185,8 +1178,7 @@ static void stuffescaped(char_u *arg, int literally)   * If "regname" is a special register, return TRUE and store a pointer to its   * value in "argp".   */ -int  -get_spec_reg ( +int get_spec_reg(      int regname,      char_u **argp,      int *allocated,         /* return: TRUE when value was allocated */ @@ -1273,13 +1265,11 @@ get_spec_reg (  /// @returns FAIL for failure, OK otherwise  bool cmdline_paste_reg(int regname, bool literally, bool remcr)  { -  long i; -    yankreg_T *reg = get_yank_register(regname, YREG_PASTE);    if (reg->y_array == NULL)      return FAIL; -  for (i = 0; i < reg->y_size; i++) { +  for (size_t i = 0; i < reg->y_size; i++) {      cmdline_paste_str(reg->y_array[i], literally);      // Insert ^M between lines and after last line if type is kMTLineWise. @@ -1311,12 +1301,14 @@ int op_delete(oparg_T *oap)    struct block_def bd;    linenr_T old_lcount = curbuf->b_ml.ml_line_count; -  if (curbuf->b_ml.ml_flags & ML_EMPTY)             /* nothing to do */ +  if (curbuf->b_ml.ml_flags & ML_EMPTY) {  // nothing to do      return OK; +  } -  /* Nothing to delete, return here.	Do prepare undo, for op_change(). */ -  if (oap->empty) +  // Nothing to delete, return here. Do prepare undo, for op_change(). +  if (oap->empty) {      return u_save_cursor(); +  }    if (!MODIFIABLE(curbuf)) {      EMSG(_(e_modifiable)); @@ -1431,23 +1423,21 @@ int op_delete(oparg_T *oap)          curwin->w_cursor.coladd = 0;        } -      /* n == number of chars deleted -       * If we delete a TAB, it may be replaced by several characters. -       * Thus the number of characters may increase! -       */ +      // n == number of chars deleted +      // If we delete a TAB, it may be replaced by several characters. +      // Thus the number of characters may increase!        n = bd.textlen - bd.startspaces - bd.endspaces;        oldp = ml_get(lnum); -      newp = (char_u *) xmalloc((size_t)(STRLEN(oldp) + 1 - n)); -      /* copy up to deleted part */ +      newp = (char_u *)xmalloc(STRLEN(oldp) - (size_t)n + 1); +      // copy up to deleted part        memmove(newp, oldp, (size_t)bd.textcol); -      /* insert spaces */ -      memset(newp + bd.textcol, ' ', -          (size_t)(bd.startspaces + bd.endspaces)); -      /* copy the part after the deleted part */ +      // insert spaces +      memset(newp + bd.textcol, ' ', (size_t)(bd.startspaces + bd.endspaces)); +      // copy the part after the deleted part        oldp += bd.textcol + bd.textlen;        STRMOVE(newp + bd.textcol + bd.startspaces + bd.endspaces, oldp); -      /* replace the line */ -      ml_replace(lnum, newp, FALSE); +      // replace the line +      ml_replace(lnum, newp, false);      }      check_cursor_col(); @@ -1552,7 +1542,7 @@ int op_delete(oparg_T *oap)            curwin->w_cursor.coladd = 0;        } -      (void)del_bytes((long)n, !virtual_op, +      (void)del_bytes((colnr_T)n, !virtual_op,                        oap->op_type == OP_DELETE && !oap->is_VIsual);      } else {        // delete characters between lines @@ -1572,7 +1562,7 @@ int op_delete(oparg_T *oap)        // delete from start of line until op_end        n = (oap->end.col + 1 - !oap->inclusive);        curwin->w_cursor.col = 0; -      (void)del_bytes((long)n, !virtual_op, +      (void)del_bytes((colnr_T)n, !virtual_op,                        oap->op_type == OP_DELETE && !oap->is_VIsual);        curwin->w_cursor = curpos;  // restore curwin->w_cursor        (void)do_join(2, false, false, false, false); @@ -1611,7 +1601,8 @@ static void mb_adjust_opend(oparg_T *oap)   */  static inline void pchar(pos_T lp, int c)  { -    *(ml_get_buf(curbuf, lp.lnum, TRUE) + lp.col) = c;; +    assert(c <= UCHAR_MAX); +    *(ml_get_buf(curbuf, lp.lnum, true) + lp.col) = (char_u)c;  }  /* @@ -1695,15 +1686,16 @@ int op_replace(oparg_T *oap, int c)        oldp = get_cursor_line_ptr();        oldlen = STRLEN(oldp); -      newp = (char_u *) xmalloc((size_t)(oldlen + 1 + n)); -      memset(newp, NUL, (size_t)(oldlen + 1 + n)); -      /* copy up to deleted part */ +      assert(n >= 0); +      newp = (char_u *)xmalloc(oldlen + 1 + (size_t)n); +      memset(newp, NUL, oldlen + 1 + (size_t)n); +      // copy up to deleted part        memmove(newp, oldp, (size_t)bd.textcol);        oldp += bd.textcol + bd.textlen; -      /* insert pre-spaces */ +      // insert pre-spaces        memset(newp + bd.textcol, ' ', (size_t)bd.startspaces); -      /* insert replacement chars CHECK FOR ALLOCATED SPACE */ -      /* -1/-2 is used for entering CR literally. */ +      // insert replacement chars CHECK FOR ALLOCATED SPACE +      // -1/-2 is used for entering CR literally.        if (had_ctrl_v_cr || (c != '\r' && c != '\n')) {          if (has_mbyte) {            n = (int)STRLEN(newp); @@ -1718,8 +1710,8 @@ int op_replace(oparg_T *oap, int c)            STRMOVE(newp + STRLEN(newp), oldp);          }        } else { -        /* Replacing with \r or \n means splitting the line. */ -        after_p = (char_u *) xmalloc((size_t)(oldlen + 1 + n - STRLEN(newp))); +        // Replacing with \r or \n means splitting the line. +        after_p = (char_u *)xmalloc(oldlen + 1 + (size_t)n - STRLEN(newp));          STRMOVE(after_p, oldp);        }        /* replace the line */ @@ -1992,7 +1984,7 @@ void op_insert(oparg_T *oap, long count1)      // already disabled, but still need it when calling      // coladvance_force().      if (curwin->w_cursor.coladd > 0) { -      int old_ve_flags = ve_flags; +      unsigned old_ve_flags = ve_flags;        ve_flags = VE_ALL;        if (u_save_cursor() == FAIL) @@ -2066,8 +2058,8 @@ void op_insert(oparg_T *oap, long count1)        if (oap->op_type == OP_INSERT            && oap->start.col + oap->start.coladd            != curbuf->b_op_start_orig.col + curbuf->b_op_start_orig.coladd) { -        size_t t = getviscol2(curbuf->b_op_start_orig.col, -                              curbuf->b_op_start_orig.coladd); +        int t = getviscol2(curbuf->b_op_start_orig.col, +                           curbuf->b_op_start_orig.coladd);          oap->start.col = curbuf->b_op_start_orig.col;          pre_textlen -= t - oap->start_vcol;          oap->start_vcol = t; @@ -2075,8 +2067,8 @@ void op_insert(oparg_T *oap, long count1)                   && oap->end.col + oap->end.coladd                   >= curbuf->b_op_start_orig.col                   + curbuf->b_op_start_orig.coladd) { -        size_t t = getviscol2(curbuf->b_op_start_orig.col, -                              curbuf->b_op_start_orig.coladd); +        int t = getviscol2(curbuf->b_op_start_orig.col, +                           curbuf->b_op_start_orig.coladd);          oap->start.col = curbuf->b_op_start_orig.col;          /* reset pre_textlen to the value of OP_INSERT */          pre_textlen += bd.textlen; @@ -2109,14 +2101,13 @@ void op_insert(oparg_T *oap, long count1)      firstline = ml_get(oap->start.lnum) + bd.textcol;      if (oap->op_type == OP_APPEND)        firstline += bd.textlen; -    if (pre_textlen >= 0 -        && (ins_len = (long)STRLEN(firstline) - pre_textlen) > 0) { -      ins_text = vim_strnsave(firstline, (int)ins_len); -      /* block handled here */ -      if (u_save(oap->start.lnum, -              (linenr_T)(oap->end.lnum + 1)) == OK) -        block_insert(oap, ins_text, (oap->op_type == OP_INSERT), -            &bd); +    ins_len = (long)STRLEN(firstline) - pre_textlen; +    if (pre_textlen >= 0 && ins_len > 0) { +      ins_text = vim_strnsave(firstline, (size_t)ins_len); +      // block handled here +      if (u_save(oap->start.lnum, (linenr_T)(oap->end.lnum + 1)) == OK) { +        block_insert(oap, ins_text, (oap->op_type == OP_INSERT), &bd); +      }        curwin->w_cursor.col = oap->start.col;        check_cursor(); @@ -2139,8 +2130,10 @@ int op_change(oparg_T *oap)    long ins_len;    long pre_textlen = 0;    long pre_indent = 0; -  char_u              *firstline; -  char_u              *ins_text, *newp, *oldp; +  char_u *newp; +  char_u *firstline; +  char_u *ins_text; +  char_u *oldp;    struct block_def bd;    l = oap->start.col; @@ -2198,14 +2191,14 @@ int op_change(oparg_T *oap)        long new_indent = (long)(skipwhite(firstline) - firstline);        pre_textlen += new_indent - pre_indent; -      bd.textcol += new_indent - pre_indent; +      bd.textcol += (colnr_T)(new_indent - pre_indent);      }      ins_len = (long)STRLEN(firstline) - pre_textlen;      if (ins_len > 0) {        /* Subsequent calls to ml_get() flush the firstline data - take a         * copy of the inserted text.  */ -      ins_text = (char_u *) xmalloc((size_t)(ins_len + 1)); +      ins_text = (char_u *)xmalloc((size_t)(ins_len + 1));        STRLCPY(ins_text, firstline + bd.textcol, ins_len + 1);        for (linenr = oap->start.lnum + 1; linenr <= oap->end.lnum;             linenr++) { @@ -2218,11 +2211,13 @@ int op_change(oparg_T *oap)            if (bd.is_short) {              vpos.lnum = linenr;              (void)getvpos(&vpos, oap->start_vcol); -          } else +          } else {              vpos.coladd = 0; +          }            oldp = ml_get(linenr); -          newp = (char_u *) xmalloc((size_t)(STRLEN(oldp) + vpos.coladd + ins_len + 1)); -          /* copy up to block start */ +          newp = xmalloc(STRLEN(oldp) + (size_t)vpos.coladd +                         + (size_t)ins_len + 1); +          // copy up to block start            memmove(newp, oldp, (size_t)bd.textcol);            offset = bd.textcol;            memset(newp + offset, ' ', (size_t)vpos.coladd); @@ -2272,9 +2267,7 @@ void free_register(yankreg_T *reg)  {    set_yreg_additional_data(reg, NULL);    if (reg->y_array != NULL) { -    long i; - -    for (i = reg->y_size - 1; i >= 0; i--) { +    for (size_t i = reg->y_size; i-- > 0;) {  // from y_size - 1 to 0 included        xfree(reg->y_array[i]);      }      xfree(reg->y_array); @@ -2311,30 +2304,27 @@ bool op_yank(oparg_T *oap, bool message)  static void op_yank_reg(oparg_T *oap, bool message, yankreg_T *reg, bool append)  { -  long y_idx;                           /* index in y_array[] */ -  yankreg_T      *curr;            /* copy of current register */ -  yankreg_T newreg;                /* new yank register when appending */ -  char_u              **new_ptr; -  linenr_T lnum;                        /* current line number */ -  long j; +  yankreg_T newreg;  // new yank register when appending +  char_u **new_ptr; +  linenr_T lnum;     // current line number +  size_t j;    MotionType yank_type = oap->motion_type; -  long yanklines = oap->line_count; +  size_t yanklines = (size_t)oap->line_count;    linenr_T yankendlnum = oap->end.lnum; -  char_u              *p; -  char_u              *pnew; +  char_u *p; +  char_u *pnew;    struct block_def bd; -  curr = reg; -  /* append to existing contents */ -  if (append && reg->y_array != NULL) +  yankreg_T *curr = reg;  // copy of current register +  // append to existing contents +  if (append && reg->y_array != NULL) {      reg = &newreg; -  else -    free_register(reg);                /* free previously yanked lines */ +  } else { +    free_register(reg);  // free previously yanked lines +  } -  /* -   * If the cursor was in column 1 before and after the movement, and the -   * operator is not inclusive, the yank is always linewise. -   */ +  // If the cursor was in column 1 before and after the movement, and the +  // operator is not inclusive, the yank is always linewise.    if (oap->motion_type == kMTCharWise        && oap->start.col == 0        && !oap->inclusive @@ -2353,7 +2343,7 @@ static void op_yank_reg(oparg_T *oap, bool message, yankreg_T *reg, bool append)    reg->additional_data = NULL;    reg->timestamp = os_time(); -  y_idx = 0; +  size_t y_idx = 0;  // index in y_array[]    lnum = oap->start.lnum;    if (yank_type == kMTBlockWise) { @@ -2481,7 +2471,7 @@ static void op_yank_reg(oparg_T *oap, bool message, yankreg_T *reg, bool append)        yanklines = 0;      }      // Some versions of Vi use ">=" here, some don't... -    if (yanklines > p_report) { +    if (yanklines > (size_t)p_report) {        // redisplay now, so message is not deleted        update_topline_redraw();        if (yanklines == 1) { @@ -2512,10 +2502,10 @@ static void op_yank_reg(oparg_T *oap, bool message, yankreg_T *reg, bool append)    return;  } -static void yank_copy_line(yankreg_T *reg, struct block_def *bd, long y_idx) +static void yank_copy_line(yankreg_T *reg, struct block_def *bd, size_t y_idx)  { -  char_u *pnew = xmallocz(bd->startspaces + bd->endspaces + bd->textlen); - +  char_u *pnew = xmallocz((size_t)(bd->startspaces + bd->endspaces +                                   + bd->textlen));    reg->y_array[y_idx] = pnew;    memset(pnew, ' ', (size_t)bd->startspaces);    pnew += bd->startspaces; @@ -2548,7 +2538,7 @@ static void yank_do_autocmd(oparg_T *oap, yankreg_T *reg)    // the yanked text    list_T *list = list_alloc(); -  for (linenr_T i = 0; i < reg->y_size; i++) { +  for (size_t i = 0; i < reg->y_size; i++) {      list_append_string(list, reg->y_array[i], -1);    }    list->lv_lock = VAR_FIXED; @@ -2565,7 +2555,7 @@ static void yank_do_autocmd(oparg_T *oap, yankreg_T *reg)    dict_add_nr_str(dict, "regname", 0, (char_u *)buf);    // kind of operation (yank/delete/change) -  buf[0] = get_op_char(oap->op_type); +  buf[0] = (char)get_op_char(oap->op_type);    buf[1] = NUL;    dict_add_nr_str(dict, "operator", 0, (char_u *)buf); @@ -2582,23 +2572,24 @@ static void yank_do_autocmd(oparg_T *oap, yankreg_T *reg)  /*   * Put contents of register "regname" into the text.   * Caller must check "regname" to be valid! - * "flags": PUT_FIXINDENT	make indent look nice - *	    PUT_CURSEND		leave cursor after end of new text - *	    PUT_LINE		force linewise put (":put") + * "flags": PUT_FIXINDENT     make indent look nice + *          PUT_CURSEND       leave cursor after end of new text + *          PUT_LINE          force linewise put (":put")      dir: BACKWARD for 'P', FORWARD for 'p' */  void do_put(int regname, yankreg_T *reg, int dir, long count, int flags)  { -  char_u      *ptr; -  char_u      *newp, *oldp; +  char_u *ptr; +  char_u *newp; +  char_u *oldp;    int yanklen; -  int totlen = 0;                       /* init for gcc */ +  size_t totlen = 0;  // init for gcc    linenr_T lnum;    colnr_T col; -  long i;  // index in y_array[] +  size_t i;  // index in y_array[]    MotionType y_type; -  long y_size; -  int oldlen; -  long y_width = 0; +  size_t y_size; +  size_t oldlen; +  int y_width = 0;    colnr_T vcol;    int delcount;    int incr = 0; @@ -2705,7 +2696,7 @@ void do_put(int regname, yankreg_T *reg, int dir, long count, int flags)    if (curbuf->terminal) {      for (int i = 0; i < count; i++) {        // feed the lines to the terminal -      for (int j = 0; j < y_size; j++) { +      for (size_t j = 0; j < y_size; j++) {          if (j) {            // terminate the previous line            terminal_send(curbuf->terminal, "\n", 1); @@ -2736,7 +2727,7 @@ void do_put(int regname, yankreg_T *reg, int dir, long count, int flags)        if (dir == FORWARD && *p != NUL) {          mb_ptr_adv(p);        } -      ptr = vim_strnsave(oldp, p - oldp); +      ptr = vim_strnsave(oldp, (size_t)(p - oldp));        ml_replace(curwin->w_cursor.lnum, ptr, false);        nr_lines++;        dir = FORWARD; @@ -2761,11 +2752,13 @@ void do_put(int regname, yankreg_T *reg, int dir, long count, int flags)    }    if (y_type == kMTBlockWise) { -    lnum = curwin->w_cursor.lnum + y_size + 1; -    if (lnum > curbuf->b_ml.ml_line_count) +    lnum = curwin->w_cursor.lnum + (linenr_T)y_size + 1; +    if (lnum > curbuf->b_ml.ml_line_count) {        lnum = curbuf->b_ml.ml_line_count + 1; -    if (u_save(curwin->w_cursor.lnum - 1, lnum) == FAIL) +    } +    if (u_save(curwin->w_cursor.lnum - 1, lnum) == FAIL) {        goto end; +    }    } else if (y_type == kMTLineWise) {      lnum = curwin->w_cursor.lnum;      /* Correct line number for closed fold.  Don't move the cursor yet, @@ -2811,7 +2804,7 @@ void do_put(int regname, yankreg_T *reg, int dir, long count, int flags)     * Block mode     */    if (y_type == kMTBlockWise) { -    char c = gchar_cursor(); +    int c = gchar_cursor();      colnr_T endcol2 = 0;      if (dir == FORWARD && c != NUL) { @@ -2864,7 +2857,7 @@ void do_put(int regname, yankreg_T *reg, int dir, long count, int flags)        }        /* get the old line and advance to the position to insert at */        oldp = get_cursor_line_ptr(); -      oldlen = (int)STRLEN(oldp); +      oldlen = STRLEN(oldp);        for (ptr = oldp; vcol < col && *ptr; ) {          /* Count a tab for what it's worth (if list mode not on) */          incr = lbr_chartabsize_adv(oldp, &ptr, (colnr_T)vcol); @@ -2901,10 +2894,11 @@ void do_put(int regname, yankreg_T *reg, int dir, long count, int flags)        if (spaces < 0)          spaces = 0; -      /* insert the new text */ -      totlen = count * (yanklen + spaces) + bd.startspaces + bd.endspaces; -      newp = (char_u *) xmalloc((size_t)(totlen + oldlen + 1)); -      /* copy part up to cursor to new line */ +      // insert the new text +      totlen = (size_t)(count * (yanklen + spaces) +                        + bd.startspaces + bd.endspaces); +      newp = (char_u *) xmalloc(totlen + oldlen + 1); +      // copy part up to cursor to new line        ptr = newp;        memmove(ptr, oldp, (size_t)bd.textcol);        ptr += bd.textcol; @@ -2925,10 +2919,10 @@ void do_put(int regname, yankreg_T *reg, int dir, long count, int flags)        /* may insert some spaces after the new text */        memset(ptr, ' ', (size_t)bd.endspaces);        ptr += bd.endspaces; -      /* move the text after the cursor to the end of the line. */ +      // move the text after the cursor to the end of the line.        memmove(ptr, oldp + bd.textcol + delcount, -          (size_t)(oldlen - bd.textcol - delcount + 1)); -      ml_replace(curwin->w_cursor.lnum, newp, FALSE); +              (size_t)((int)oldlen - bd.textcol - delcount + 1)); +      ml_replace(curwin->w_cursor.lnum, newp, false);        ++curwin->w_cursor.lnum;        if (i == 0) @@ -2943,7 +2937,7 @@ void do_put(int regname, yankreg_T *reg, int dir, long count, int flags)      /* adjust '] mark */      curbuf->b_op_end.lnum = curwin->w_cursor.lnum - 1; -    curbuf->b_op_end.col = bd.textcol + totlen - 1; +    curbuf->b_op_end.col = bd.textcol + (colnr_T)totlen - 1;      curbuf->b_op_end.coladd = 0;      if (flags & PUT_CURSEND) {        colnr_T len; @@ -2994,13 +2988,13 @@ void do_put(int regname, yankreg_T *reg, int dir, long count, int flags)       */      if (y_type == kMTCharWise && y_size == 1) {        do { -        totlen = count * yanklen; +        totlen = (size_t)(count * yanklen);          if (totlen > 0) {            oldp = ml_get(lnum);            newp = (char_u *) xmalloc((size_t)(STRLEN(oldp) + totlen + 1));            memmove(newp, oldp, (size_t)col);            ptr = newp + col; -          for (i = 0; i < count; i++) { +          for (i = 0; i < (size_t)count; i++) {              memmove(ptr, y_array[0], (size_t)yanklen);              ptr += yanklen;            } @@ -3037,7 +3031,7 @@ void do_put(int regname, yankreg_T *reg, int dir, long count, int flags)            // Then append y_array[0] to first line.            lnum = new_cursor.lnum;            ptr = ml_get(lnum) + col; -          totlen = (int)STRLEN(y_array[y_size - 1]); +          totlen = STRLEN(y_array[y_size - 1]);            newp = (char_u *) xmalloc((size_t)(STRLEN(ptr) + totlen + 1));            STRCPY(newp, y_array[y_size - 1]);            STRCAT(newp, ptr); @@ -3217,22 +3211,19 @@ int get_register_name(int num)   */  void ex_display(exarg_T *eap)  { -  int i, n; -  long j; -  char_u              *p; -  yankreg_T      *yb; +  char_u *p; +  yankreg_T *yb;    int name; -  int attr; -  char_u              *arg = eap->arg; +  char_u *arg = eap->arg;    int clen;    if (arg != NULL && *arg == NUL)      arg = NULL; -  attr = hl_attr(HLF_8); +  int attr = hl_attr(HLF_8);    /* Highlight title */    MSG_PUTS_TITLE(_("\n--- Registers ---")); -  for (i = -1; i < NUM_REGISTERS && !got_int; i++) { +  for (int i = -1; i < NUM_REGISTERS && !got_int; i++) {      name = get_register_name(i);      if (arg != NULL && vim_strchr(arg, name) == NULL) { @@ -3261,8 +3252,8 @@ void ex_display(exarg_T *eap)        msg_putchar(name);        MSG_PUTS("   "); -      n = (int)Columns - 6; -      for (j = 0; j < yb->y_size && n > 1; ++j) { +      int n = (int)Columns - 6; +      for (size_t j = 0; j < yb->y_size && n > 1; j++) {          if (j) {            MSG_PUTS_ATTR("^J", attr);            n -= 2; @@ -3438,7 +3429,7 @@ static char_u *skip_comment(char_u *line, int process, int include_space, int *i  // to set those marks.  //  // return FAIL for failure, OK otherwise -int do_join(long count, +int do_join(size_t count,              int insert_space,              int save_undo,              int use_formatoptions, @@ -3461,24 +3452,21 @@ int do_join(long count,                          && has_format_option(FO_REMOVE_COMS);    int prev_was_comment; -  assert(count > 1); -  if (save_undo && u_save((linenr_T)(curwin->w_cursor.lnum - 1), -          (linenr_T)(curwin->w_cursor.lnum + count)) == FAIL) +  if (save_undo && u_save(curwin->w_cursor.lnum - 1, +                          curwin->w_cursor.lnum + (linenr_T)count) == FAIL) {      return FAIL; - -  /* Allocate an array to store the number of spaces inserted before each -   * line.  We will use it to pre-compute the length of the new line and the -   * proper placement of each original line in the new one. */ +  } +  // Allocate an array to store the number of spaces inserted before each +  // line.  We will use it to pre-compute the length of the new line and the +  // proper placement of each original line in the new one.    spaces = xcalloc(count, 1);    if (remove_comments) {      comments = xcalloc(count, sizeof(*comments));    } -  /* -   * Don't move anything, just compute the final line length -   * and setup the array of space strings lengths -   */ -  for (t = 0; t < count; ++t) { +  // Don't move anything, just compute the final line length +  // and setup the array of space strings lengths +  for (t = 0; t < (linenr_T)count; t++) {      curr = curr_start = ml_get((linenr_T)(curwin->w_cursor.lnum + t));      if (t == 0 && setmark) {        // Set the '[ mark. @@ -3558,7 +3546,7 @@ int do_join(long count,     * column.  This is not Vi compatible, but Vi deletes the marks, thus that     * should not really be a problem.     */ -  for (t = count - 1;; --t) { +  for (t = (linenr_T)count - 1;; t--) {      cend -= currsize;      memmove(cend, curr, (size_t)currsize);      if (spaces[t] > 0) { @@ -3595,8 +3583,8 @@ int do_join(long count,     * have moved up (last line deleted), so the current lnum is kept in t.     */    t = curwin->w_cursor.lnum; -  ++curwin->w_cursor.lnum; -  del_lines(count - 1, FALSE); +  curwin->w_cursor.lnum++; +  del_lines((long)count - 1, false);    curwin->w_cursor.lnum = t;    /* @@ -3778,8 +3766,8 @@ fex_format (     * Set v:lnum to the first line number and v:count to the number of lines.     * Set v:char to the character to be inserted (can be NUL).     */ -  set_vim_var_nr(VV_LNUM, lnum); -  set_vim_var_nr(VV_COUNT, count); +  set_vim_var_nr(VV_LNUM, (varnumber_T)lnum); +  set_vim_var_nr(VV_COUNT, (varnumber_T)count);    set_vim_var_char(c);    /* @@ -4473,7 +4461,7 @@ int do_addsub(int op_type, pos_T *pos, int length, linenr_T Prenum1)            firstdigit = 'a';          }        } else { -        firstdigit -= Prenum1; +        firstdigit -= (int)Prenum1;        }      } else {        if (26 - CharOrd(firstdigit) - 1 < Prenum1) { @@ -4483,7 +4471,7 @@ int do_addsub(int op_type, pos_T *pos, int length, linenr_T Prenum1)            firstdigit = 'z';          }        } else { -        firstdigit += Prenum1; +        firstdigit += (int)Prenum1;        }      }      curwin->w_cursor.col = col; @@ -4591,7 +4579,7 @@ int do_addsub(int op_type, pos_T *pos, int length, linenr_T Prenum1)      // Prepare the leading characters in buf1[].      // When there are many leading zeros it could be very long.      // Allocate a bit too much. -    buf1 = xmalloc(length + NUMBUFLEN); +    buf1 = xmalloc((size_t)length + NUMBUFLEN);      if (buf1 == NULL) {        goto theend;      } @@ -4604,7 +4592,7 @@ int do_addsub(int op_type, pos_T *pos, int length, linenr_T Prenum1)        length--;      }      if (pre == 'b' || pre == 'B' || pre == 'x' || pre == 'X') { -      *ptr++ = pre; +      *ptr++ = (char_u)pre;        length--;      } @@ -4767,8 +4755,6 @@ static void *get_reg_wrap_one_line(char_u *s, int flags)  /// @returns NULL for error.  void *get_reg_contents(int regname, int flags)  { -  long i; -    // Don't allow using an expression register inside an expression.    if (regname == '=') {      if (flags & kGRegNoExpr) { @@ -4804,7 +4790,7 @@ void *get_reg_contents(int regname, int flags)    if (flags & kGRegList) {      list_T *list = list_alloc(); -    for (int i = 0; i < reg->y_size; i++) { +    for (size_t i = 0; i < reg->y_size; i++) {        list_append_string(list, reg->y_array[i], -1);      } @@ -4815,7 +4801,7 @@ void *get_reg_contents(int regname, int flags)     * Compute length of resulting string.     */    size_t len = 0; -  for (i = 0; i < reg->y_size; i++) { +  for (size_t i = 0; i < reg->y_size; i++) {      len += STRLEN(reg->y_array[i]);      /*       * Insert a newline between lines and after last line if @@ -4832,7 +4818,7 @@ void *get_reg_contents(int regname, int flags)     * Copy the lines of the yank register into the string.     */    len = 0; -  for (i = 0; i < reg->y_size; i++) { +  for (size_t i = 0; i < reg->y_size; i++) {      STRCPY(retval + len, reg->y_array[i]);      len += STRLEN(retval + len); @@ -4888,7 +4874,7 @@ void write_reg_contents(int name, const char_u *str, ssize_t len,  void write_reg_contents_lst(int name, char_u **strings, int maxlen,                              bool must_append, MotionType yank_type, -                            long block_len) +                            colnr_T block_len)  {    if (name == '/' || name == '=') {      char_u  *s = strings[0]; @@ -4913,7 +4899,8 @@ void write_reg_contents_lst(int name, char_u **strings, int maxlen,      return;    } -  str_to_reg(reg, yank_type, (char_u *) strings, -1, block_len, true); +  str_to_reg(reg, yank_type, (char_u *)strings, STRLEN((char_u *)strings), +             block_len, true);    finish_write_reg(name, reg, old_y_previous);  } @@ -4941,7 +4928,7 @@ void write_reg_contents_ex(int name,                             ssize_t len,                             bool must_append,                             MotionType yank_type, -                           long block_len) +                           colnr_T block_len)  {    if (len < 0) {      len = (ssize_t) STRLEN(str); @@ -4991,7 +4978,7 @@ void write_reg_contents_ex(int name,      // Copy the input string into the adjusted memory at the specified      // offset.      expr_line = xrealloc(expr_line, totlen + 1); -    memcpy(expr_line + offset, str, (size_t) len); +    memcpy(expr_line + offset, str, (size_t)len);      expr_line[totlen] = NUL;      return; @@ -5005,7 +4992,7 @@ void write_reg_contents_ex(int name,    if (!(reg = init_write_reg(name, &old_y_previous, must_append))) {      return;    } -  str_to_reg(reg, yank_type, str, len, block_len, false); +  str_to_reg(reg, yank_type, str, (size_t)len, block_len, false);    finish_write_reg(name, reg, old_y_previous);  } @@ -5061,7 +5048,7 @@ static void str_to_reg(yankreg_T *y_ptr, MotionType yank_type,                           (y_ptr->y_size + newlines) * sizeof(char_u *));    y_ptr->y_array = pp; -  linenr_T lnum = y_ptr->y_size;  // The current line number. +  size_t lnum = y_ptr->y_size;  // The current line number.    // If called with `blocklen < 0`, we have to update the yank reg's width.    size_t maxlen = 0; @@ -5080,7 +5067,9 @@ static void str_to_reg(yankreg_T *y_ptr, MotionType yank_type,      for (const char_u *start = str, *end = str + len;           start < end + extraline;           start += line_len + 1, lnum++) { -      line_len = (const char_u *) xmemscan(start, '\n', end - start) - start; +      assert(end - start >= 0); +      line_len = (size_t)((char_u *)xmemscan(start, '\n', +                                             (size_t)(end - start)) - start);        if (line_len > maxlen) {          maxlen = line_len;        } @@ -5090,7 +5079,7 @@ static void str_to_reg(yankreg_T *y_ptr, MotionType yank_type,        char_u *s = xmallocz(line_len + extra);        memcpy(s, pp[lnum], extra);        memcpy(s + extra, start, line_len); -      ssize_t s_len = extra + line_len; +      size_t s_len = extra + line_len;        if (append) {          xfree(pp[lnum]); @@ -5474,7 +5463,7 @@ static bool get_clipboard(int name, yankreg_T **target, bool quiet)    free_register(reg);    list_T *args = list_alloc(); -  char_u regname = name; +  char_u regname = (char_u)name;    list_append_string(args, ®name, 1);    typval_T result = eval_call_provider("clipboard", "get", args); @@ -5519,8 +5508,8 @@ static bool get_clipboard(int name, yankreg_T **target, bool quiet)      reg->y_type = kMTUnknown;    } -  reg->y_array = xcalloc(lines->lv_len, sizeof(uint8_t *)); -  reg->y_size = lines->lv_len; +  reg->y_array = xcalloc((size_t)lines->lv_len, sizeof(uint8_t *)); +  reg->y_size = (size_t)lines->lv_len;    reg->additional_data = NULL;    reg->timestamp = 0;    // Timestamp is not saved for clipboard registers because clipboard registers @@ -5551,14 +5540,15 @@ static bool get_clipboard(int name, yankreg_T **target, bool quiet)    }    if (reg->y_type == kMTBlockWise) { -    int maxlen = 0; -    for (int i = 0; i < reg->y_size; i++) { -      int rowlen = STRLEN(reg->y_array[i]); +    size_t maxlen = 0; +    for (size_t i = 0; i < reg->y_size; i++) { +      size_t rowlen = STRLEN(reg->y_array[i]);        if (rowlen > maxlen) {          maxlen = rowlen;        }      } -    reg->y_width = maxlen-1; +    assert(maxlen <= INT_MAX); +    reg->y_width = (int)maxlen - 1;    }    *target = reg; @@ -5566,7 +5556,7 @@ static bool get_clipboard(int name, yankreg_T **target, bool quiet)  err:    if (reg->y_array) { -    for (int i = 0; i < reg->y_size; i++) { +    for (size_t i = 0; i < reg->y_size; i++) {        xfree(reg->y_array[i]);      }      xfree(reg->y_array); @@ -5590,7 +5580,7 @@ static void set_clipboard(int name, yankreg_T *reg)    list_T *lines = list_alloc(); -  for (int i = 0; i < reg->y_size; i++) { +  for (size_t i = 0; i < reg->y_size; i++) {      list_append_string(lines, reg->y_array[i], -1);    } @@ -5615,7 +5605,7 @@ static void set_clipboard(int name, yankreg_T *reg)    }    list_append_string(args, ®type, 1); -  char_u regname = name; +  char_u regname = (char_u)name;    list_append_string(args, ®name, 1);    (void)eval_call_provider("clipboard", "set", args); @@ -5678,8 +5668,8 @@ const void *op_register_iter(const void *const iter, char *const name,    if (iter_reg - &(y_regs[0]) == NUM_SAVED_REGISTERS || reg_empty(iter_reg)) {      return NULL;    } -  size_t iter_off = iter_reg - &(y_regs[0]); -  *name = (char) get_register_name(iter_off); +  int iter_off = (int)(iter_reg - &(y_regs[0])); +  *name = (char)get_register_name(iter_off);    *reg = *iter_reg;    while (++iter_reg - &(y_regs[0]) < NUM_SAVED_REGISTERS) {      if (!reg_empty(iter_reg)) { diff --git a/src/nvim/ops.h b/src/nvim/ops.h index 8c8a586957..44df2e9e0c 100644 --- a/src/nvim/ops.h +++ b/src/nvim/ops.h @@ -79,7 +79,7 @@ enum GRegFlags {  /// Definition of one register  typedef struct yankreg {    char_u **y_array;   ///< Pointer to an array of line pointers. -  linenr_T y_size;    ///< Number of lines in y_array. +  size_t y_size;      ///< Number of lines in y_array.    MotionType y_type;  ///< Register type    colnr_T y_width;    ///< Register width (only valid for y_type == kBlockWise).    Timestamp timestamp;  ///< Time when register was last modified. diff --git a/src/nvim/option.c b/src/nvim/option.c index c8a25e8b75..52a1fd8558 100644 --- a/src/nvim/option.c +++ b/src/nvim/option.c @@ -3403,9 +3403,10 @@ char_u *check_stl_option(char_u *s)      if (!*s)        break;      s++; -    if (*s != '%' && *s != ')') -      ++itemcnt; -    if (*s == '%' || *s == STL_TRUNCMARK || *s == STL_MIDDLEMARK) { +    if (*s != '%' && *s != ')') { +      itemcnt++; +    } +    if (*s == '%' || *s == STL_TRUNCMARK || *s == STL_SEPARATE) {        s++;        continue;      } @@ -4030,15 +4031,16 @@ set_num_option (        errmsg = e_invarg;        curwin->w_p_fdc = 12;      } -  } -  /* 'shiftwidth' or 'tabstop' */ -  else if (pp == &curbuf->b_p_sw || pp == &curbuf->b_p_ts) { -    if (foldmethodIsIndent(curwin)) +  // 'shiftwidth' or 'tabstop' +  } else if (pp == &curbuf->b_p_sw || pp == (long *)&curbuf->b_p_ts) { +    if (foldmethodIsIndent(curwin)) {        foldUpdateAll(curwin); -    /* When 'shiftwidth' changes, or it's zero and 'tabstop' changes: -     * parse 'cinoptions'. */ -    if (pp == &curbuf->b_p_sw || curbuf->b_p_sw == 0) +    } +    // When 'shiftwidth' changes, or it's zero and 'tabstop' changes: +    // parse 'cinoptions'. +    if (pp == &curbuf->b_p_sw || curbuf->b_p_sw == 0) {        parse_cino(curbuf); +    }    }    /* 'maxcombine' */    else if (pp == &p_mco) { @@ -5657,7 +5659,7 @@ void buf_copy_options(buf_T *buf, int flags)          buf->b_p_isk = save_p_isk;        else {          buf->b_p_isk = vim_strsave(p_isk); -        did_isk = TRUE; +        did_isk = true;          buf->b_p_ts = p_ts;          buf->b_help = false;          if (buf->b_p_bt[0] == 'h') diff --git a/src/nvim/option_defs.h b/src/nvim/option_defs.h index 904e97f8ca..b1a2b00bdb 100644 --- a/src/nvim/option_defs.h +++ b/src/nvim/option_defs.h @@ -258,7 +258,7 @@ enum {    STL_ARGLISTSTAT     = 'a',  ///< Argument list status as (x of y).    STL_PAGENUM         = 'N',  ///< Page number (when printing).    STL_VIM_EXPR        = '{',  ///< Start of expression to substitute. -  STL_MIDDLEMARK      = '=',  ///< Separation between left and right. +  STL_SEPARATE        = '=',  ///< Separation between alignment sections.    STL_TRUNCMARK       = '<',  ///< Truncation mark if line is too long.    STL_USER_HL         = '*',  ///< Highlight from (User)1..9 or 0.    STL_HIGHLIGHT       = '#',  ///< Highlight name. @@ -274,7 +274,7 @@ enum {    STL_HELPFLAG, STL_HELPFLAG_ALT, STL_FILETYPE, STL_FILETYPE_ALT, \    STL_PREVIEWFLAG, STL_PREVIEWFLAG_ALT, STL_MODIFIED, STL_MODIFIED_ALT, \    STL_QUICKFIX, STL_PERCENTAGE, STL_ALTPERCENT, STL_ARGLISTSTAT, STL_PAGENUM, \ -  STL_VIM_EXPR, STL_MIDDLEMARK, STL_TRUNCMARK, STL_USER_HL, STL_HIGHLIGHT, \ +  STL_VIM_EXPR, STL_SEPARATE, STL_TRUNCMARK, STL_USER_HL, STL_HIGHLIGHT, \    STL_TABPAGENR, STL_TABCLOSENR, STL_CLICK_FUNC, \    0, \  }) diff --git a/src/nvim/shada.c b/src/nvim/shada.c index 51c8597d53..380d955f63 100644 --- a/src/nvim/shada.c +++ b/src/nvim/shada.c @@ -1422,7 +1422,7 @@ static void shada_read(ShaDaReadDef *const sd_reader, const int flags)          }          if (!op_register_set(cur_entry.data.reg.name, (yankreg_T) {            .y_array = (char_u **) cur_entry.data.reg.contents, -          .y_size = (linenr_T) cur_entry.data.reg.contents_size, +          .y_size = cur_entry.data.reg.contents_size,            .y_type = cur_entry.data.reg.type,            .y_width = (colnr_T) cur_entry.data.reg.width,            .timestamp = cur_entry.timestamp, @@ -2745,7 +2745,7 @@ static ShaDaWriteResult shada_write(ShaDaWriteDef *const sd_writer,        if (name == NUL) {          break;        } -      if (limit_reg_lines && reg.y_size > max_reg_lines) { +      if (limit_reg_lines && reg.y_size > (size_t)max_reg_lines) {          continue;        }        wms->registers[op_reg_index(name)] = (PossiblyFreedShadaEntry) { diff --git a/src/nvim/syntax.c b/src/nvim/syntax.c index 9e4dc0204f..05141eaf1e 100644 --- a/src/nvim/syntax.c +++ b/src/nvim/syntax.c @@ -6952,8 +6952,23 @@ highlight_color (    else if (!(TOLOWER_ASC(what[0]) == 'b' && TOLOWER_ASC(what[1]) == 'g'))      return NULL;    if (modec == 'g') { -    if (fg) +    if (what[2] == '#' && ui_rgb_attached()) { +      if (fg) { +          n = HL_TABLE()[id - 1].sg_rgb_fg; +      } else if (sp) { +          n = HL_TABLE()[id - 1].sg_rgb_sp; +      } else { +          n = HL_TABLE()[id - 1].sg_rgb_bg; +      } +      if (n < 0 || n > 0xffffff) { +        return NULL; +      } +      snprintf((char *)name, sizeof(name), "#%06x", n); +      return name; +    } +    if (fg) {        return HL_TABLE()[id - 1].sg_rgb_fg_name; +    }      if (sp) {        return HL_TABLE()[id - 1].sg_rgb_sp_name;      } diff --git a/src/nvim/testdir/runtest.vim b/src/nvim/testdir/runtest.vim index 2712fb9371..578d64efde 100644 --- a/src/nvim/testdir/runtest.vim +++ b/src/nvim/testdir/runtest.vim @@ -61,12 +61,13 @@ endif  " Locate Test_ functions and execute them.  set nomore  redir @q -function /^Test_ +silent function /^Test_  redir END  let tests = split(substitute(@q, 'function \(\k*()\)', '\1', 'g'))  " Execute the tests in alphabetical order.  for test in sort(tests) +  echo 'Executing ' . test    if exists("*SetUp")      call SetUp()    endif diff --git a/src/nvim/tui/input.c b/src/nvim/tui/input.c index 3a136a4b1d..be256f3ebc 100644 --- a/src/nvim/tui/input.c +++ b/src/nvim/tui/input.c @@ -139,6 +139,9 @@ static void forward_modified_utf8(TermInput *input, TermKeyKey *key)    if (key->type == TERMKEY_TYPE_KEYSYM        && key->code.sym == TERMKEY_SYM_ESCAPE) {      len = (size_t)snprintf(buf, sizeof(buf), "<Esc>"); +  } else if (key->type == TERMKEY_TYPE_KEYSYM +      && key->code.sym == TERMKEY_SYM_SUSPEND) { +    len = (size_t)snprintf(buf, sizeof(buf), "<C-Z>");    } else {      len = termkey_strfkey(input->tk, buf, sizeof(buf), key, TERMKEY_FORMAT_VIM);    } diff --git a/src/nvim/version.c b/src/nvim/version.c index 1a66589080..5364fee953 100644 --- a/src/nvim/version.c +++ b/src/nvim/version.c @@ -341,7 +341,7 @@ static int included_patches[] = {    // 1355 NA    // 1354 NA    // 1353 NA -  // 1352, +  1352,    // 1351 NA    // 1350 NA    // 1349 NA @@ -567,7 +567,7 @@ static int included_patches[] = {    // 1129 NA    // 1128 NA    // 1127 NA -  // 1126, +  1126,    // 1125 NA    // 1124 NA    1123, @@ -1904,21 +1904,15 @@ void intro_message(int colon)      N_("by Bram Moolenaar et al."),      N_("Vim is open source and freely distributable"),      "", -    N_("First time using a vi-like editor?"), -    N_("Type :Tutor<Enter> to get started!"), +    N_("Type \":Tutor\" or \":help nvim\" to get started!"),      "", -    N_("Already know your way around Vim?"), -    N_("See :help nvim-intro for an introduction to Neovim."), +    N_("Still have questions? https://neovim.io/community"),      "", -    N_("Still have questions?"), -    N_("Reach out to the Neovim community at neovim.io/community."), +    N_("type  :q<Enter>               to exit         "), +    N_("type  :help<Enter>  or  <F1>  for on-line help"),      "",      N_("Help poor children in Uganda!"),      N_("type  :help iccf<Enter>       for information "), -    "", -    N_("type  :q<Enter>               to exit         "), -    N_("type  :help<Enter>  or  <F1>  for on-line help"), -    N_("type  :help nvim<Enter>       for Neovim help "),    };    // blanklines = screen height - # message lines | 
