diff options
Diffstat (limited to 'src')
30 files changed, 663 insertions, 839 deletions
| diff --git a/src/nvim/buffer.c b/src/nvim/buffer.c index 9806623433..c05090bbf6 100644 --- a/src/nvim/buffer.c +++ b/src/nvim/buffer.c @@ -1741,12 +1741,15 @@ int buflist_findpat(    int toggledollar;    if (pattern_end == pattern + 1 && (*pattern == '%' || *pattern == '#')) { -    if (*pattern == '%') +    if (*pattern == '%') {        match = curbuf->b_fnum; -    else +    } else {        match = curwin->w_alt_fnum; -    if (diffmode && !diff_mode_buf(buflist_findnr(match))) +    } +    buf_T *found_buf = buflist_findnr(match); +    if (diffmode && !(found_buf && diff_mode_buf(found_buf))) {        match = -1; +    }    }    /*     * Try four ways of matching a listed buffer: diff --git a/src/nvim/buffer_defs.h b/src/nvim/buffer_defs.h index 709ff3dd0d..bdea609820 100644 --- a/src/nvim/buffer_defs.h +++ b/src/nvim/buffer_defs.h @@ -592,71 +592,72 @@ struct file_buffer {    int b_p_scriptID[BV_COUNT];           /* SIDs for buffer-local options */ -  int b_p_ai;                   /* 'autoindent' */ -  int b_p_ai_nopaste;           /* b_p_ai saved for paste mode */ -  char_u      *b_p_bkc;         ///< 'backupcopy' -  unsigned int b_bkc_flags;     ///< flags for 'backupcopy' -  int b_p_ci;                   /* 'copyindent' */ -  int b_p_bin;                  /* 'binary' */ -  int b_p_bomb;                 /* 'bomb' */ -  char_u      *b_p_bh;          /* 'bufhidden' */ -  char_u      *b_p_bt;          /* 'buftype' */ -  int b_p_bl;                   /* 'buflisted' */ -  int b_p_cin;                  /* 'cindent' */ -  char_u      *b_p_cino;        /* 'cinoptions' */ -  char_u      *b_p_cink;        /* 'cinkeys' */ -  char_u      *b_p_cinw;        /* 'cinwords' */ -  char_u      *b_p_com;         /* 'comments' */ -  char_u      *b_p_cms;         /* 'commentstring' */ -  char_u      *b_p_cpt;         /* 'complete' */ -  char_u      *b_p_cfu;         /* 'completefunc' */ -  char_u      *b_p_ofu;         /* 'omnifunc' */ -  int b_p_eol;                  /* 'endofline' */ -  int b_p_fixeol;               /* 'fixendofline' */ -  int b_p_et;                   /* 'expandtab' */ -  int b_p_et_nobin;             /* b_p_et saved for binary mode */ -  char_u      *b_p_fenc;        /* 'fileencoding' */ -  char_u      *b_p_ff;          /* 'fileformat' */ -  char_u      *b_p_ft;          /* 'filetype' */ -  char_u      *b_p_fo;          /* 'formatoptions' */ -  char_u      *b_p_flp;         /* 'formatlistpat' */ -  int b_p_inf;                  /* 'infercase' */ -  char_u      *b_p_isk;         /* 'iskeyword' */ -  char_u      *b_p_def;         /* 'define' local value */ -  char_u      *b_p_inc;         /* 'include' */ -  char_u      *b_p_inex;        /* 'includeexpr' */ -  uint32_t b_p_inex_flags;      /* flags for 'includeexpr' */ -  char_u      *b_p_inde;        /* 'indentexpr' */ -  uint32_t b_p_inde_flags;        /* flags for 'indentexpr' */ -  char_u      *b_p_indk;        /* 'indentkeys' */ -  char_u      *b_p_fex;         /* 'formatexpr' */ -  uint32_t b_p_fex_flags;       /* flags for 'formatexpr' */ -  char_u      *b_p_kp;          /* 'keywordprg' */ -  int b_p_lisp;                 /* 'lisp' */ -  char_u      *b_p_mps;         /* 'matchpairs' */ -  int b_p_ml;                   /* 'modeline' */ -  int b_p_ml_nobin;             /* b_p_ml saved for binary mode */ -  int b_p_ma;                   /* 'modifiable' */ -  char_u      *b_p_nf;          /* 'nrformats' */ -  int b_p_pi;                   /* 'preserveindent' */ -  char_u      *b_p_qe;          /* 'quoteescape' */ -  int b_p_ro;                   /* 'readonly' */ -  long b_p_sw;                  /* 'shiftwidth' */ -  int b_p_si;                   /* 'smartindent' */ -  long b_p_sts;                 /* 'softtabstop' */ -  long b_p_sts_nopaste;         /* b_p_sts saved for paste mode */ -  char_u      *b_p_sua;         /* 'suffixesadd' */ -  bool b_p_swf;                 /* 'swapfile' */ -  long b_p_smc;                 /* 'synmaxcol' */ -  char_u      *b_p_syn;         /* 'syntax' */ -  long b_p_ts;                  /* 'tabstop' */ -  long b_p_tw;                  /* 'textwidth' */ -  long b_p_tw_nobin;            /* b_p_tw saved for binary mode */ -  long b_p_tw_nopaste;          /* b_p_tw saved for paste mode */ -  long b_p_wm;                  /* 'wrapmargin' */ -  long b_p_wm_nobin;            /* b_p_wm saved for binary mode */ -  long b_p_wm_nopaste;          /* b_p_wm saved for paste mode */ -  char_u      *b_p_keymap;      /* 'keymap' */ +  int b_p_ai;                   ///< 'autoindent' +  int b_p_ai_nopaste;           ///< b_p_ai saved for paste mode +  char_u *b_p_bkc;              ///< 'backupco +  unsigned int b_bkc_flags;     ///< flags for 'backupco +  int b_p_ci;                   ///< 'copyindent' +  int b_p_bin;                  ///< 'binary' +  int b_p_bomb;                 ///< 'bomb' +  char_u *b_p_bh;               ///< 'bufhidden' +  char_u *b_p_bt;               ///< 'buftype' +  int b_p_bl;                   ///< 'buflisted' +  int b_p_cin;                  ///< 'cindent' +  char_u *b_p_cino;             ///< 'cinoptions' +  char_u *b_p_cink;             ///< 'cinkeys' +  char_u *b_p_cinw;             ///< 'cinwords' +  char_u *b_p_com;              ///< 'comments' +  char_u *b_p_cms;              ///< 'commentstring' +  char_u *b_p_cpt;              ///< 'complete' +  char_u *b_p_cfu;              ///< 'completefunc' +  char_u *b_p_ofu;              ///< 'omnifunc' +  int b_p_eol;                  ///< 'endofline' +  int b_p_fixeol;               ///< 'fixendofline' +  int b_p_et;                   ///< 'expandtab' +  int b_p_et_nobin;             ///< b_p_et saved for binary mode +  int b_p_et_nopaste;           ///< b_p_et saved for paste mode +  char_u *b_p_fenc;             ///< 'fileencoding' +  char_u *b_p_ff;               ///< 'fileformat' +  char_u *b_p_ft;               ///< 'filetype' +  char_u *b_p_fo;               ///< 'formatoptions' +  char_u *b_p_flp;              ///< 'formatlistpat' +  int b_p_inf;                  ///< 'infercase' +  char_u *b_p_isk;              ///< 'iskeyword' +  char_u *b_p_def;              ///< 'define' local value +  char_u *b_p_inc;              ///< 'include' +  char_u *b_p_inex;             ///< 'includeexpr' +  uint32_t b_p_inex_flags;      ///< flags for 'includeexpr' +  char_u *b_p_inde;             ///< 'indentexpr' +  uint32_t b_p_inde_flags;      ///< flags for 'indentexpr' +  char_u *b_p_indk;             ///< 'indentkeys' +  char_u *b_p_fex;              ///< 'formatexpr' +  uint32_t b_p_fex_flags;       ///< flags for 'formatexpr' +  char_u *b_p_kp;               ///< 'keywordprg' +  int b_p_lisp;                 ///< 'lisp' +  char_u *b_p_mps;              ///< 'matchpairs' +  int b_p_ml;                   ///< 'modeline' +  int b_p_ml_nobin;             ///< b_p_ml saved for binary mode +  int b_p_ma;                   ///< 'modifiable' +  char_u *b_p_nf;               ///< 'nrformats' +  int b_p_pi;                   ///< 'preserveindent' +  char_u *b_p_qe;               ///< 'quoteescape' +  int b_p_ro;                   ///< 'readonly' +  long b_p_sw;                  ///< 'shiftwidth' +  int b_p_si;                   ///< 'smartindent' +  long b_p_sts;                 ///< 'softtabstop' +  long b_p_sts_nopaste;         ///< b_p_sts saved for paste mode +  char_u *b_p_sua;              ///< 'suffixesadd' +  bool b_p_swf;                 ///< 'swapfile' +  long b_p_smc;                 ///< 'synmaxcol' +  char_u *b_p_syn;              ///< 'syntax' +  long b_p_ts;                  ///< 'tabstop' +  long b_p_tw;                  ///< 'textwidth' +  long b_p_tw_nobin;            ///< b_p_tw saved for binary mode +  long b_p_tw_nopaste;          ///< b_p_tw saved for paste mode +  long b_p_wm;                  ///< 'wrapmargin' +  long b_p_wm_nobin;            ///< b_p_wm saved for binary mode +  long b_p_wm_nopaste;          ///< b_p_wm saved for paste mode +  char_u *b_p_keymap;           ///< 'keymap'    /* local values for options which are normally global */    char_u      *b_p_gp;          /* 'grepprg' local value */ diff --git a/src/nvim/diff.c b/src/nvim/diff.c index e06ffd0bbc..0be8b3c514 100644 --- a/src/nvim/diff.c +++ b/src/nvim/diff.c @@ -1531,37 +1531,37 @@ int diff_check(win_T *wp, linenr_T lnum)    return maxcount - dp->df_count[idx];  } -/// Compare two entries in diff "*dp" and return TRUE if they are equal. +/// Compare two entries in diff "dp" and return true if they are equal.  /// -/// @param dp -/// @param idx1 First entry in diff "*dp" -/// @param idx2 Second entry in diff "*dp" +/// @param  dp    diff +/// @param  idx1  first entry in diff "dp" +/// @param  idx2  second entry in diff "dp"  /// -/// @return return TRUE if two entires are equal. -static int diff_equal_entry(diff_T *dp, int idx1, int idx2) +/// @return true if two entires are equal. +static bool diff_equal_entry(diff_T *dp, int idx1, int idx2) +  FUNC_ATTR_PURE FUNC_ATTR_WARN_UNUSED_RESULT FUNC_ATTR_NONNULL_ARG(1)  {    if (dp->df_count[idx1] != dp->df_count[idx2]) { -    return FALSE; +    return false;    }    if (diff_check_sanity(curtab, dp) == FAIL) { -    return FALSE; +    return false;    } -  int i; -  for (i = 0; i < dp->df_count[idx1]; ++i) { +  for (int i = 0; i < dp->df_count[idx1]; i++) {      char_u *line = vim_strsave(ml_get_buf(curtab->tp_diffbuf[idx1], -                                          dp->df_lnum[idx1] + i, FALSE)); +                                          dp->df_lnum[idx1] + i, false));      int cmp = diff_cmp(line, ml_get_buf(curtab->tp_diffbuf[idx2], -                                        dp->df_lnum[idx2] + i, FALSE)); +                                        dp->df_lnum[idx2] + i, false));      xfree(line);      if (cmp != 0) { -      return FALSE; +      return false;      }    } -  return TRUE; +  return true;  }  /// Compare strings "s1" and "s2" according to 'diffopt'. @@ -1830,28 +1830,30 @@ int diffopt_changed(void)    return OK;  } -/// Return TRUE if 'diffopt' contains "horizontal". -/// -/// @return TRUE if 'diffopt' contains "horizontal" -int diffopt_horizontal(void) +/// Check that "diffopt" contains "horizontal". +bool diffopt_horizontal(void) +  FUNC_ATTR_PURE FUNC_ATTR_WARN_UNUSED_RESULT  {    return (diff_flags & DIFF_HORIZONTAL) != 0;  }  /// Find the difference within a changed line.  /// -/// @param startp first char of the change -/// @param endp last char of the change +/// @param  wp      window whose current buffer to check +/// @param  lnum    line number to check within the buffer +/// @param  startp  first char of the change +/// @param  endp    last char of the change  /// -/// @returns TRUE if the line was added, no other buffer has it. -int diff_find_change(win_T *wp, linenr_T lnum, int *startp, int *endp) +/// @return true if the line was added, no other buffer has it. +bool diff_find_change(win_T *wp, linenr_T lnum, int *startp, int *endp) +  FUNC_ATTR_WARN_UNUSED_RESULT FUNC_ATTR_NONNULL_ALL  {    char_u *line_new;    int si_org;    int si_new;    int ei_org;    int ei_new; -  int added = TRUE; +  bool added = true;    // Make a copy of the line, the next ml_get() will invalidate it.    char_u *line_org = vim_strsave(ml_get_buf(wp->w_buffer, lnum, FALSE)); @@ -1860,7 +1862,7 @@ int diff_find_change(win_T *wp, linenr_T lnum, int *startp, int *endp)    if (idx == DB_COUNT) {      // cannot happen      xfree(line_org); -    return FALSE; +    return false;    }    // search for a change that includes "lnum" in the list of diffblocks. @@ -1873,7 +1875,7 @@ int diff_find_change(win_T *wp, linenr_T lnum, int *startp, int *endp)    if ((dp == NULL) || (diff_check_sanity(curtab, dp) == FAIL)) {      xfree(line_org); -    return FALSE; +    return false;    }    int off = lnum - dp->df_lnum[idx]; @@ -1884,7 +1886,7 @@ int diff_find_change(win_T *wp, linenr_T lnum, int *startp, int *endp)        if (off >= dp->df_count[i]) {          continue;        } -      added = FALSE; +      added = false;        line_new = ml_get_buf(curtab->tp_diffbuf[i],                              dp->df_lnum[i] + off, FALSE); @@ -1956,21 +1958,22 @@ int diff_find_change(win_T *wp, linenr_T lnum, int *startp, int *endp)    return added;  } -/// Return TRUE if line "lnum" is not close to a diff block, this line should +/// Check that line "lnum" is not close to a diff block, this line should  /// be in a fold.  /// -/// @param wp -/// @param lnum +/// @param  wp    window containing the buffer to check +/// @param  lnum  line number to check within the buffer  /// -/// @return FALSE if there are no diff blocks at all in this window. -int diff_infold(win_T *wp, linenr_T lnum) +/// @return false if there are no diff blocks at all in this window. +bool diff_infold(win_T *wp, linenr_T lnum) +  FUNC_ATTR_PURE FUNC_ATTR_WARN_UNUSED_RESULT FUNC_ATTR_NONNULL_ARG(1)  { -  int other = FALSE; +  bool other = false;    diff_T *dp;    // Return if 'diff' isn't set.    if (!wp->w_p_diff) { -    return FALSE; +    return false;    }    int idx = -1; @@ -1979,13 +1982,13 @@ int diff_infold(win_T *wp, linenr_T lnum)      if (curtab->tp_diffbuf[i] == wp->w_buffer) {        idx = i;      } else if (curtab->tp_diffbuf[i] != NULL) { -      other = TRUE; +      other = true;      }    }    // return here if there are no diffs in the window    if ((idx == -1) || !other) { -    return FALSE; +    return false;    }    if (curtab->tp_diff_invalid) { @@ -1995,7 +1998,7 @@ int diff_infold(win_T *wp, linenr_T lnum)    // Return if there are no diff blocks.  All lines will be folded.    if (curtab->tp_first_diff == NULL) { -    return TRUE; +    return true;    }    for (dp = curtab->tp_first_diff; dp != NULL; dp = dp->df_next) { @@ -2006,10 +2009,10 @@ int diff_infold(win_T *wp, linenr_T lnum)      // If this change ends before the line we have a match.      if (dp->df_lnum[idx] + dp->df_count[idx] + diff_context > lnum) { -      return FALSE; +      return false;      }    } -  return TRUE; +  return true;  }  /// "dp" and "do" commands. @@ -2372,12 +2375,11 @@ static void diff_fold_update(diff_T *dp, int skip_idx)    }  } -/// Checks if the buffer is in diff-mode. -/// -/// @param buf The buffer to check. +/// Checks that the buffer is in diff-mode.  /// -/// @return TRUE if buffer "buf" is in diff-mode. +/// @param  buf  buffer to check.  bool diff_mode_buf(buf_T *buf) +  FUNC_ATTR_PURE FUNC_ATTR_WARN_UNUSED_RESULT FUNC_ATTR_NONNULL_ARG(1)  {    FOR_ALL_TABS(tp) {      if (diff_buf_idx_tp(buf, tp) != DB_COUNT) { diff --git a/src/nvim/eval.c b/src/nvim/eval.c index 327d0bf637..96fc79504f 100644 --- a/src/nvim/eval.c +++ b/src/nvim/eval.c @@ -3580,9 +3580,10 @@ static int eval4(char_u **arg, typval_T *rettv, int evaluate)        type = TYPE_SEQUAL;      break;    case 'i':   if (p[1] == 's') { -      if (p[2] == 'n' && p[3] == 'o' && p[4] == 't') +      if (p[2] == 'n' && p[3] == 'o' && p[4] == 't') {          len = 5; -      if (!vim_isIDc(p[len])) { +      } +      if (!isalnum(p[len]) && p[len] != '_') {          type = len == 2 ? TYPE_EQUAL : TYPE_NEQUAL;          type_is = TRUE;        } @@ -10697,11 +10698,11 @@ getwinvar (      int off                    /* 1 for gettabwinvar() */  )  { -  win_T       *win, *oldcurwin; -  char_u      *varname; -  dictitem_T  *v; -  tabpage_T   *tp = NULL; -  tabpage_T   *oldtabpage = NULL; +  win_T *win, *oldcurwin; +  char_u *varname; +  dictitem_T *v; +  tabpage_T *tp = NULL; +  tabpage_T *oldtabpage = NULL;    bool done = false;    if (off == 1) @@ -10716,12 +10717,16 @@ getwinvar (    rettv->vval.v_string = NULL;    if (win != NULL && varname != NULL) { -    /* Set curwin to be our win, temporarily.  Also set the tabpage, -     * otherwise the window is not valid. */ -    if (switch_win(&oldcurwin, &oldtabpage, win, tp, TRUE) == OK) { -      if (*varname == '&') {      /* window-local-option */ -        if (get_option_tv(&varname, rettv, 1) == OK) +    // Set curwin to be our win, temporarily.  Also set the tabpage, +    // otherwise the window is not valid. Only do this when needed, +    // autocommands get blocked. +    bool need_switch_win = tp != curtab || win != curwin; +    if (!need_switch_win +        || switch_win(&oldcurwin, &oldtabpage, win, tp, true) == OK) { +      if (*varname == '&') {  // window-local-option +        if (get_option_tv(&varname, rettv, 1) == OK) {            done = true; +        }        } else {          // Look up the variable.          // Let getwinvar({nr}, "") return the "w:" dictionary. @@ -10733,8 +10738,10 @@ getwinvar (        }      } -    /* restore previous notion of curwin */ -    restore_win(oldcurwin, oldtabpage, TRUE); +    if (need_switch_win) { +      // restore previous notion of curwin +      restore_win(oldcurwin, oldtabpage, true); +    }    }    if (!done && argvars[off + 2].v_type != VAR_UNKNOWN) @@ -15559,26 +15566,32 @@ static void setwinvar(typval_T *argvars, typval_T *rettv, int off)    varname = get_tv_string_chk(&argvars[off + 1]);    varp = &argvars[off + 2]; -  if (win != NULL && varname != NULL && varp != NULL -      && switch_win(&save_curwin, &save_curtab, win, tp, TRUE) == OK) { -    if (*varname == '&') { -      long numval; -      char_u      *strval; -      int error = FALSE; - -      ++varname; -      numval = get_tv_number_chk(varp, &error); -      strval = get_tv_string_buf_chk(varp, nbuf); -      if (!error && strval != NULL) -        set_option_value(varname, numval, strval, OPT_LOCAL); -    } else { -      winvarname = xmalloc(STRLEN(varname) + 3); -      STRCPY(winvarname, "w:"); -      STRCPY(winvarname + 2, varname); -      set_var(winvarname, varp, TRUE); -      xfree(winvarname); +  if (win != NULL && varname != NULL && varp != NULL) { +    bool need_switch_win = tp != curtab || win != curwin; +    if (!need_switch_win +        || switch_win(&save_curwin, &save_curtab, win, tp, true) == OK) { +      if (*varname == '&') { +        long numval; +        char_u *strval; +        int error = false; + +        ++varname; +        numval = get_tv_number_chk(varp, &error); +        strval = get_tv_string_buf_chk(varp, nbuf); +        if (!error && strval != NULL) { +          set_option_value(varname, numval, strval, OPT_LOCAL); +        } +      } else { +        winvarname = xmalloc(STRLEN(varname) + 3); +        STRCPY(winvarname, "w:"); +        STRCPY(winvarname + 2, varname); +        set_var(winvarname, varp, true); +        xfree(winvarname); +      } +    } +    if (need_switch_win) { +      restore_win(save_curwin, save_curtab, true);      } -    restore_win(save_curwin, save_curtab, TRUE);    }  } @@ -20913,14 +20926,18 @@ call_user_func (    save_sourcing_name = sourcing_name;    save_sourcing_lnum = sourcing_lnum;    sourcing_lnum = 1; -  sourcing_name = xmalloc((save_sourcing_name == NULL ? 0 : STRLEN(save_sourcing_name)) -                          + STRLEN(fp->uf_name) + 13); +  // need space for function name + ("function " + 3) or "[number]" +  size_t len = (save_sourcing_name == NULL ? 0 : STRLEN(save_sourcing_name)) +               + STRLEN(fp->uf_name) + 20; +  sourcing_name = xmalloc(len);    {      if (save_sourcing_name != NULL -        && STRNCMP(save_sourcing_name, "function ", 9) == 0) -      sprintf((char *)sourcing_name, "%s..", save_sourcing_name); -    else +        && STRNCMP(save_sourcing_name, "function ", 9) == 0) { +      vim_snprintf((char *)sourcing_name, len, "%s[%zu]..", +                   save_sourcing_name, save_sourcing_lnum); +    } else {        STRCPY(sourcing_name, "function "); +    }      cat_func_name(sourcing_name + STRLEN(sourcing_name), fp);      if (p_verbose >= 12) { @@ -22186,7 +22203,6 @@ static void on_process_exit(Process *proc, int status, void *d)      char msg[22];      snprintf(msg, sizeof msg, "\r\n[Process exited %d]", proc->status);      terminal_close(data->term, msg); -    apply_autocmds(EVENT_TERMCLOSE, NULL, NULL, false, curbuf);    }    if (data->status_ptr) { diff --git a/src/nvim/ex_cmds.c b/src/nvim/ex_cmds.c index 4d62dd0ff9..4a423269cc 100644 --- a/src/nvim/ex_cmds.c +++ b/src/nvim/ex_cmds.c @@ -4779,6 +4779,7 @@ void ex_helptags(exarg_T *eap)        WILD_LIST_NOTFOUND|WILD_SILENT, WILD_EXPAND_FREE);    if (dirname == NULL || !os_isdir(dirname)) {      EMSG2(_("E150: Not a directory: %s"), eap->arg); +    xfree(dirname);      return;    } diff --git a/src/nvim/ex_docmd.c b/src/nvim/ex_docmd.c index dfae2b849d..2d17b31f0f 100644 --- a/src/nvim/ex_docmd.c +++ b/src/nvim/ex_docmd.c @@ -381,15 +381,14 @@ int do_cmdline(char_u *cmdline, LineGetter fgetline,      suppress_errthrow = FALSE;    } -  /* -   * If requested, store and reset the global values controlling the -   * exception handling (used when debugging).  Otherwise clear it to avoid -   * a bogus compiler warning when the optimizer uses inline functions... -   */ -  if (flags & DOCMD_EXCRESET) +  // If requested, store and reset the global values controlling the +  // exception handling (used when debugging).  Otherwise clear it to avoid +  // a bogus compiler warning when the optimizer uses inline functions... +  if (flags & DOCMD_EXCRESET) {      save_dbg_stuff(&debug_saved); -  else -    memset(&debug_saved, 0, 1); +  } else { +    memset(&debug_saved, 0, sizeof(debug_saved)); +  }    initial_trylevel = trylevel; @@ -2679,16 +2678,25 @@ set_one_cmd_context (      p = cmd + 1;    } else {      p = cmd; -    while (ASCII_ISALPHA(*p) || *p == '*')        /* Allow * wild card */ -      ++p; -    /* check for non-alpha command */ -    if (p == cmd && vim_strchr((char_u *)"@*!=><&~#", *p) != NULL) -      ++p; -    /* for python 3.x: ":py3*" commands completion */ +    while (ASCII_ISALPHA(*p) || *p == '*') {  // Allow * wild card +      p++; +    } +    // a user command may contain digits +    if (ASCII_ISUPPER(cmd[0])) { +      while (ASCII_ISALNUM(*p) || *p == '*') { +        p++; +      } +    } +    // for python 3.x: ":py3*" commands completion      if (cmd[0] == 'p' && cmd[1] == 'y' && p == cmd + 2 && *p == '3') { -      ++p; -      while (ASCII_ISALPHA(*p) || *p == '*') -        ++p; +      p++; +      while (ASCII_ISALPHA(*p) || *p == '*') { +        p++; +      } +    } +    // check for non-alpha command +    if (p == cmd && vim_strchr((char_u *)"@*!=><&~#", *p) != NULL) { +      p++;      }      len = (int)(p - cmd); @@ -2702,9 +2710,11 @@ set_one_cmd_context (                (size_t)len) == 0)          break; -    if (cmd[0] >= 'A' && cmd[0] <= 'Z') -      while (ASCII_ISALNUM(*p) || *p == '*')            /* Allow * wild card */ -        ++p; +    if (cmd[0] >= 'A' && cmd[0] <= 'Z') { +      while (ASCII_ISALNUM(*p) || *p == '*') {  // Allow * wild card +        p++; +      } +    }    }    /* @@ -8774,19 +8784,18 @@ static int ses_do_frame(frame_T *fr)    return FALSE;  } -/* - * Return non-zero if window "wp" is to be stored in the Session. - */ +/// Return non-zero if window "wp" is to be stored in the Session.  static int ses_do_win(win_T *wp)  {    if (wp->w_buffer->b_fname == NULL -      /* When 'buftype' is "nofile" can't restore the window contents. */ -      || bt_nofile(wp->w_buffer) -      ) +      // When 'buftype' is "nofile" can't restore the window contents. +      || (!wp->w_buffer->terminal && bt_nofile(wp->w_buffer))) {      return ssop_flags & SSOP_BLANK; -  if (wp->w_buffer->b_help) +  } +  if (wp->w_buffer->b_help) {      return ssop_flags & SSOP_HELP; -  return TRUE; +  } +  return true;  }  /* @@ -9352,52 +9361,55 @@ static void ex_nohlsearch(exarg_T *eap)    redraw_all_later(SOME_VALID);  } -/* - * ":[N]match {group} {pattern}" - * Sets nextcmd to the start of the next command, if any.  Also called when - * skipping commands to find the next command. - */ +// ":[N]match {group} {pattern}" +// Sets nextcmd to the start of the next command, if any.  Also called when +// skipping commands to find the next command.  static void ex_match(exarg_T *eap)  { -  char_u      *p; -  char_u      *g = NULL; -  char_u      *end; +  char_u *p; +  char_u *g = NULL; +  char_u *end;    int c;    int id; -  if (eap->line2 <= 3) +  if (eap->line2 <= 3) {      id = eap->line2; -  else { +  } else {      EMSG(e_invcmd);      return;    } -  /* First clear any old pattern. */ -  if (!eap->skip) -    match_delete(curwin, id, FALSE); +  // First clear any old pattern. +  if (!eap->skip) { +    match_delete(curwin, id, false); +  } -  if (ends_excmd(*eap->arg)) +  if (ends_excmd(*eap->arg)) {      end = eap->arg; -  else if ((STRNICMP(eap->arg, "none", 4) == 0 -            && (ascii_iswhite(eap->arg[4]) || ends_excmd(eap->arg[4])))) +  } else if ((STRNICMP(eap->arg, "none", 4) == 0 +              && (ascii_iswhite(eap->arg[4]) || ends_excmd(eap->arg[4])))) {      end = eap->arg + 4; -  else { +  } else {      p = skiptowhite(eap->arg); -    if (!eap->skip) +    if (!eap->skip) {        g = vim_strnsave(eap->arg, (int)(p - eap->arg)); +    }      p = skipwhite(p);      if (*p == NUL) { -      /* There must be two arguments. */ +      // There must be two arguments. +      xfree(g);        EMSG2(_(e_invarg2), eap->arg);        return;      } -    end = skip_regexp(p + 1, *p, TRUE, NULL); +    end = skip_regexp(p + 1, *p, true, NULL);      if (!eap->skip) {        if (*end != NUL && !ends_excmd(*skipwhite(end + 1))) { +        xfree(g);          eap->errmsg = e_trailing;          return;        }        if (*end != *p) { +        xfree(g);          EMSG2(_(e_invarg2), p);          return;        } diff --git a/src/nvim/file_search.c b/src/nvim/file_search.c index b213a42c52..2929790ebf 100644 --- a/src/nvim/file_search.c +++ b/src/nvim/file_search.c @@ -484,28 +484,21 @@ vim_findfile_init (          len = (int)(p - search_ctx->ffsc_fix_path) - 1;          STRNCAT(ff_expand_buffer, search_ctx->ffsc_fix_path, len);          add_pathsep((char *)ff_expand_buffer); -      } else +      } else {          len = (int)STRLEN(search_ctx->ffsc_fix_path); +      }        if (search_ctx->ffsc_wc_path != NULL) {          wc_path = vim_strsave(search_ctx->ffsc_wc_path);          temp = xmalloc(STRLEN(search_ctx->ffsc_wc_path)                         + STRLEN(search_ctx->ffsc_fix_path + len)                         + 1); -      } - -      if (temp == NULL || wc_path == NULL) { -        xfree(buf); -        xfree(temp); +        STRCPY(temp, search_ctx->ffsc_fix_path + len); +        STRCAT(temp, search_ctx->ffsc_wc_path); +        xfree(search_ctx->ffsc_wc_path);          xfree(wc_path); -        goto error_return; +        search_ctx->ffsc_wc_path = temp;        } - -      STRCPY(temp, search_ctx->ffsc_fix_path + len); -      STRCAT(temp, search_ctx->ffsc_wc_path); -      xfree(search_ctx->ffsc_wc_path); -      xfree(wc_path); -      search_ctx->ffsc_wc_path = temp;      }      xfree(buf);    } @@ -1046,41 +1039,44 @@ static ff_visited_list_hdr_T *ff_get_visited_list(char_u *filename, ff_visited_l    return retptr;  } -/* - * check if two wildcard paths are equal. Returns TRUE or FALSE. - * They are equal if: - *  - both paths are NULL - *  - they have the same length - *  - char by char comparison is OK - *  - the only differences are in the counters behind a '**', so - *    '**\20' is equal to '**\24' - */ -static int ff_wc_equal(char_u *s1, char_u *s2) +// Check if two wildcard paths are equal. +// They are equal if: +//  - both paths are NULL +//  - they have the same length +//  - char by char comparison is OK +//  - the only differences are in the counters behind a '**', so +//    '**\20' is equal to '**\24' +static bool ff_wc_equal(char_u *s1, char_u *s2)  { -  int i; +  int i, j; +  int c1 = NUL; +  int c2 = NUL;    int prev1 = NUL;    int prev2 = NUL; -  if (s1 == s2) -    return TRUE; - -  if (s1 == NULL || s2 == NULL) -    return FALSE; +  if (s1 == s2) { +    return true; +  } -  if (STRLEN(s1) != STRLEN(s2)) -    return FAIL; +  if (s1 == NULL || s2 == NULL) { +    return false; +  } -  for (i = 0; s1[i] != NUL && s2[i] != NUL; i += MB_PTR2LEN(s1 + i)) { -    int c1 = PTR2CHAR(s1 + i); -    int c2 = PTR2CHAR(s2 + i); +  for (i = 0, j = 0; s1[i] != NUL && s2[j] != NUL;) { +    c1 = PTR2CHAR(s1 + i); +    c2 = PTR2CHAR(s2 + j);      if ((p_fic ? vim_tolower(c1) != vim_tolower(c2) : c1 != c2) -        && (prev1 != '*' || prev2 != '*')) -      return FAIL; +        && (prev1 != '*' || prev2 != '*')) { +      return false; +    }      prev2 = prev1;      prev1 = c1; + +    i += MB_PTR2LEN(s1 + i); +    j += MB_PTR2LEN(s2 + j);    } -  return TRUE; +  return s1[i] == s2[j];  }  /* @@ -1111,10 +1107,11 @@ static int ff_check_visited(ff_visited_T **visited_list, char_u *fname, char_u *      if ((url && fnamecmp(vp->ffv_fname, ff_expand_buffer) == 0)          || (!url && vp->file_id_valid              && os_fileid_equal(&(vp->file_id), &file_id))) { -      /* are the wildcard parts equal */ -      if (ff_wc_equal(vp->ffv_wc_path, wc_path) == TRUE) -        /* already visited */ +      // are the wildcard parts equal +      if (ff_wc_equal(vp->ffv_wc_path, wc_path)) { +        // already visited          return FAIL; +      }      }    } diff --git a/src/nvim/getchar.c b/src/nvim/getchar.c index 89d22ad811..73b3de0b5d 100644 --- a/src/nvim/getchar.c +++ b/src/nvim/getchar.c @@ -1380,13 +1380,15 @@ int vgetc(void)    } else {      mod_mask = 0x0;      last_recorded_len = 0; -    for (;; ) {                 /* this is done twice if there are modifiers */ -      if (mod_mask) {           /* no mapping after modifier has been read */ +    for (;; ) {                 // this is done twice if there are modifiers +      bool did_inc = false; +      if (mod_mask) {           // no mapping after modifier has been read          ++no_mapping;          ++allow_keys; +        did_inc = true;         // mod_mask may change value        } -      c = vgetorpeek(TRUE); -      if (mod_mask) { +      c = vgetorpeek(true); +      if (did_inc) {          --no_mapping;          --allow_keys;        } diff --git a/src/nvim/indent_c.c b/src/nvim/indent_c.c index 340287499e..17fadc4bfd 100644 --- a/src/nvim/indent_c.c +++ b/src/nvim/indent_c.c @@ -69,23 +69,33 @@ find_start_comment (  /* XXX */    return pos;  } -/* - * Find the start of a comment or raw string, not knowing if we are in a - * comment or raw string right now. - * Search starts at w_cursor.lnum and goes backwards. - * Return NULL when not inside a comment or raw string. - * "CORS" -> Comment Or Raw String - */ +/// Find the start of a comment or raw string, not knowing if we are in a +/// comment or raw string right now. +/// Search starts at w_cursor.lnum and goes backwards. +/// +/// @returns NULL when not inside a comment or raw string. +/// +/// @note "CORS" -> Comment Or Raw String  static pos_T *ind_find_start_CORS(void) -{ /* XXX */ -    pos_T *comment_pos = find_start_comment(curbuf->b_ind_maxcomment); -    pos_T *rs_pos = find_start_rawstring(curbuf->b_ind_maxcomment); - -    /* If comment_pos is before rs_pos the raw string is inside the comment. -     * If rs_pos is before comment_pos the comment is inside the raw string. */ -    if (comment_pos == NULL || (rs_pos != NULL && lt(*rs_pos, *comment_pos))) -        return rs_pos; -    return comment_pos; +{ +  // XXX +  static pos_T comment_pos_copy; + +  pos_T *comment_pos = find_start_comment(curbuf->b_ind_maxcomment); +  if (comment_pos != NULL) { +    // Need to make a copy of the static pos in findmatchlimit(), +    // calling find_start_rawstring() may change it. +    comment_pos_copy = *comment_pos; +    comment_pos = &comment_pos_copy; +  } +  pos_T *rs_pos = find_start_rawstring(curbuf->b_ind_maxcomment); + +  // If comment_pos is before rs_pos the raw string is inside the comment. +  // If rs_pos is before comment_pos the comment is inside the raw string. +  if (comment_pos == NULL || (rs_pos != NULL && lt(*rs_pos, *comment_pos))) { +    return rs_pos; +  } +  return comment_pos;  }  /* @@ -847,13 +857,27 @@ static int cin_isfuncdecl(char_u **sp, linenr_T first_lnum, linenr_T min_lnum)      return FALSE;    while (*s && *s != '(' && *s != ';' && *s != '\'' && *s != '"') { -    if (cin_iscomment(s))       /* ignore comments */ +    // ignore comments +    if (cin_iscomment(s)) {        s = cin_skipcomment(s); -    else -      ++s; +    } else if (*s == ':') { +      if (*(s + 1) == ':') { +        s += 2; +      } else { +        // To avoid a mistake in the following situation: +        // A::A(int a, int b) +        //     : a(0)  // <--not a function decl +        //     , b(0) +        // {... +        return false; +      } +    } else { +      s++; +    } +  } +  if (*s != '(') { +    return false;  // ';', ' or "  before any () or no '('    } -  if (*s != '(') -    return FALSE;               /* ';', ' or "  before any () or no '(' */    while (*s && *s != ';' && *s != '\'' && *s != '"') {      if (*s == ')' && cin_nocode(s + 1)) { @@ -1122,13 +1146,21 @@ static int cin_is_cpp_baseclass(cpp_baseclass_cache_T *cached) {    pos->lnum = lnum;    line = ml_get(lnum); -  s = cin_skipcomment(line); +  s = line;    for (;; ) {      if (*s == NUL) { -      if (lnum == curwin->w_cursor.lnum) +      if (lnum == curwin->w_cursor.lnum) {          break; -      /* Continue in the cursor line. */ +      } +      // Continue in the cursor line.        line = ml_get(++lnum); +      s = line; +    } +    if (s == line) { +      // don't recognize "case (foo):" as a baseclass */ +      if (cin_iscase(s, false)) { +        break; +      }        s = cin_skipcomment(line);        if (*s == NUL)          continue; @@ -2707,7 +2739,8 @@ int get_c_indent(void)            if (terminated == 0 || (lookfor != LOOKFOR_UNTERM                                    && terminated == ',')) { -            if (*skipwhite(l) == '[' || l[STRLEN(l) - 1] == '[') { +            if (lookfor != LOOKFOR_ENUM_OR_INIT +                && (*skipwhite(l) == '[' || l[STRLEN(l) - 1] == '[')) {                amount += ind_continuation;              }              // If we're in the middle of a paren thing, Go back to the line @@ -2915,34 +2948,35 @@ int get_c_indent(void)                    continue;                  } -                /* Ignore unterminated lines in between, but -                 * reduce indent. */ -                if (amount > cur_amount) +                // Ignore unterminated lines in between, but +                // reduce indent. +                if (amount > cur_amount) {                    amount = cur_amount; +                }                } else { -                /* -                 * Found first unterminated line on a row, may -                 * line up with this line, remember its indent -                 *	    100 + -                 * ->	    here; -                 */ +                // Found first unterminated line on a row, may +                // line up with this line, remember its indent +                // 	    100 +  //  NOLINT(whitespace/tab) +                // ->	    here;  //  NOLINT(whitespace/tab)                  l = get_cursor_line_ptr();                  amount = cur_amount; -                if (*skipwhite(l) == ']' || l[STRLEN(l) - 1] == ']') { + +                n = (int)STRLEN(l); +                if (terminated == ',' +                    && (*skipwhite(l) == ']' +                        || (n >=2 && l[n - 2] == ']'))) {                    break;                  } -                /* -                 * If previous line ends in ',', check whether we -                 * are in an initialization or enum -                 * struct xxx = -                 * { -                 *      sizeof a, -                 *      124 }; -                 * or a normal possible continuation line. -                 * but only, of no other statement has been found -                 * yet. -                 */ +                // If previous line ends in ',', check whether we +                // are in an initialization or enum +                // struct xxx = +                // { +                //      sizeof a, +                //      124 }; +                // or a normal possible continuation line. +                // but only, of no other statement has been found +                // yet.                  if (lookfor == LOOKFOR_INITIAL && terminated == ',') {                    if (curbuf->b_ind_js) {                      // Search for a line ending in a comma diff --git a/src/nvim/move.c b/src/nvim/move.c index eb55397511..ba79c0411a 100644 --- a/src/nvim/move.c +++ b/src/nvim/move.c @@ -1288,9 +1288,10 @@ void scroll_cursor_top(int min_scroll, int always)     * - at least 'scrolloff' lines above and below the cursor     */    validate_cheight(); -  int used = curwin->w_cline_height; -  if (curwin->w_cursor.lnum < curwin->w_topline) +  int used = curwin->w_cline_height;  // includes filler lines above +  if (curwin->w_cursor.lnum < curwin->w_topline) {      scrolled = used; +  }    if (hasFolding(curwin->w_cursor.lnum, &top, &bot)) {      --top; @@ -1301,9 +1302,10 @@ void scroll_cursor_top(int min_scroll, int always)    }    new_topline = top + 1; -  /* count filler lines of the cursor window as context */ +  // "used" already contains the number of filler lines above, don't add it +  // again. +  // Hide filler lines above cursor line by adding them to "extra".    int extra = diff_check_fill(curwin, curwin->w_cursor.lnum); -  used += extra;    /*     * Check if the lines from "top" to "bot" fit in the window.  If they do, @@ -1312,7 +1314,7 @@ void scroll_cursor_top(int min_scroll, int always)    while (top > 0) {      int i = hasFolding(top, &top, NULL)              ? 1  // count one logical line for a sequence of folded lines -            : plines(top); +            : plines_nofill(top);      used += i;      if (extra + i <= off && bot < curbuf->b_ml.ml_line_count) {        if (hasFolding(bot, NULL, &bot)) diff --git a/src/nvim/normal.c b/src/nvim/normal.c index e6c5354941..e064d34e09 100644 --- a/src/nvim/normal.c +++ b/src/nvim/normal.c @@ -7783,7 +7783,7 @@ static void nv_open(cmdarg_T *cap)      n_opencmd(cap);  } -// calculate start/end virtual columns for operating in block mode +// Calculate start/end virtual columns for operating in block mode.  static void get_op_vcol(      oparg_T *oap,      colnr_T redo_VIsual_vcol, @@ -7793,7 +7793,8 @@ static void get_op_vcol(    colnr_T start;    colnr_T end; -  if (VIsual_mode != Ctrl_V) { +  if (VIsual_mode != Ctrl_V +      || (!initial && oap->end.col < curwin->w_width)) {      return;    } diff --git a/src/nvim/option.c b/src/nvim/option.c index c11e22703e..0f6874e941 100644 --- a/src/nvim/option.c +++ b/src/nvim/option.c @@ -168,11 +168,12 @@ static int p_ml_nobin;  static long p_tw_nobin;  static long p_wm_nobin; -/* Saved values for when 'paste' is set */ +// Saved values for when 'paste' is set. +static int p_ai_nopaste; +static int p_et_nopaste; +static long p_sts_nopaste;  static long p_tw_nopaste;  static long p_wm_nopaste; -static long p_sts_nopaste; -static int p_ai_nopaste;  typedef struct vimoption {    char        *fullname;        /* full option name */ @@ -710,15 +711,11 @@ void set_init_1(void)    /* Must be before option_expand(), because that one needs vim_isIDc() */    didset_options(); -  /* Use the current chartab for the generic chartab. */ +  // Use the current chartab for the generic chartab. This is not in +  // didset_options() because it only depends on 'encoding'.    init_spell_chartab();    /* -   * initialize the table for 'breakat'. -   */ -  fill_breakat_flags(); - -  /*     * Expand environment variables and things like "~" for the defaults.     * If option_expand() returns non-NULL the variable is expanded.  This can     * only happen for non-indirect options. @@ -750,14 +747,8 @@ void set_init_1(void)      }    } -  /* Initialize the highlight_attr[] table. */ -  highlight_changed(); -    save_file_ff(curbuf);         /* Buffer is unchanged */ -  /* Parse default for 'wildmode'  */ -  check_opt_wim(); -    /* Detect use of mlterm.     * Mlterm is a terminal emulator akin to xterm that has some special     * abilities (bidi namely). @@ -767,11 +758,7 @@ void set_init_1(void)    if (os_env_exists("MLTERM"))      set_option_value((char_u *)"tbidi", 1L, NULL, 0); -  /* Parse default for 'fillchars'. */ -  (void)set_chars_option(&p_fcs); - -  /* Parse default for 'listchars'. */ -  (void)set_chars_option(&p_lcs); +  didset_options2();    // enc_locale() will try to find the encoding of the current locale.    // This will be used when 'default' is used as encoding specifier @@ -1150,9 +1137,12 @@ do_set (         */        arg += 3;        if (*arg == '&') { -        ++arg; -        /* Only for :set command set global value of local options. */ +        arg++; +        // Only for :set command set global value of local options.          set_options_default(OPT_FREE | opt_flags); +        didset_options(); +        didset_options2(); +        redraw_all_later(CLEAR);        } else {          showoptions(1, opt_flags);          did_show = TRUE; @@ -2072,9 +2062,31 @@ static void didset_options(void)    (void)spell_check_msm();    (void)spell_check_sps();    (void)compile_cap_prog(curwin->w_s); -  /* set cedit_key */ +  (void)did_set_spell_option(true); +  // set cedit_key    (void)check_cedit();    briopt_check(curwin); +  // initialize the table for 'breakat'. +  fill_breakat_flags(); +} + +// More side effects of setting options. +static void didset_options2(void) +{ +  // Initialize the highlight_attr[] table. +  (void)highlight_changed(); + +  // Parse default for 'clipboard'. +  (void)opt_strings_flags(p_cb, p_cb_values, &cb_flags, true); + +  // Parse default for 'fillchars'. +  (void)set_chars_option(&p_fcs); + +  // Parse default for 'listchars'. +  (void)set_chars_option(&p_lcs); + +  // Parse default for 'wildmode'. +  check_opt_wim();  }  /* @@ -2853,22 +2865,7 @@ did_set_string_option (               || varp == &(curwin->w_s->b_p_spf)) {      // When 'spelllang' or 'spellfile' is set and there is a window for this      // buffer in which 'spell' is set load the wordlists. -    if (varp == &(curwin->w_s->b_p_spf)) { -      int l = (int)STRLEN(curwin->w_s->b_p_spf); -      if (l > 0 -          && (l < 4 || STRCMP(curwin->w_s->b_p_spf + l - 4, ".add") != 0)) { -        errmsg = e_invarg; -      } -    } - -    if (errmsg == NULL) { -      FOR_ALL_WINDOWS_IN_TAB(wp, curtab) { -        if (wp->w_buffer == curbuf && wp->w_p_spell) { -          errmsg = did_set_spelllang(wp); -          break; -        } -      } -    } +    errmsg = did_set_spell_option(varp == &(curwin->w_s->b_p_spf));    }    /* When 'spellcapcheck' is set compile the regexp program. */    else if (varp == &(curwin->w_s->b_p_spc)) { @@ -3424,6 +3421,30 @@ char_u *check_stl_option(char_u *s)    return NULL;  } +static char_u *did_set_spell_option(bool is_spellfile) +{ +  char_u  *errmsg = NULL; + +  if (is_spellfile) { +    int l = (int)STRLEN(curwin->w_s->b_p_spf); +    if (l > 0 +        && (l < 4 || STRCMP(curwin->w_s->b_p_spf + l - 4, ".add") != 0)) { +      errmsg = e_invarg; +    } +  } + +  if (errmsg == NULL) { +    FOR_ALL_WINDOWS_IN_TAB(wp, curtab) { +      if (wp->w_buffer == curbuf && wp->w_p_spell) { +        errmsg = did_set_spelllang(wp); +        break; +      } +    } +  } + +  return errmsg; +} +  /*   * Set curbuf->b_cap_prog to the regexp program for 'spellcapcheck'.   * Return error message when failed, NULL when OK. @@ -5503,6 +5524,7 @@ void buf_copy_options(buf_T *buf, int flags)        buf->b_p_et = p_et;        buf->b_p_fixeol = p_fixeol;        buf->b_p_et_nobin = p_et_nobin; +      buf->b_p_et_nopaste = p_et_nopaste;        buf->b_p_ml = p_ml;        buf->b_p_ml_nobin = p_ml_nobin;        buf->b_p_inf = p_inf; @@ -6160,6 +6182,7 @@ static void paste_option_changed(void)  {    static int old_p_paste = FALSE;    static int save_sm = 0; +  static int save_sta = 0;    static int save_ru = 0;    static int save_ri = 0;    static int save_hkmap = 0; @@ -6176,40 +6199,44 @@ static void paste_option_changed(void)          buf->b_p_wm_nopaste = buf->b_p_wm;          buf->b_p_sts_nopaste = buf->b_p_sts;          buf->b_p_ai_nopaste = buf->b_p_ai; +        buf->b_p_et_nopaste = buf->b_p_et;        } -      /* save global options */ +      // save global options        save_sm = p_sm; +      save_sta = p_sta;        save_ru = p_ru;        save_ri = p_ri;        save_hkmap = p_hkmap; -      /* save global values for local buffer options */ +      // save global values for local buffer options +      p_ai_nopaste = p_ai; +      p_et_nopaste = p_et; +      p_sts_nopaste = p_sts;        p_tw_nopaste = p_tw;        p_wm_nopaste = p_wm; -      p_sts_nopaste = p_sts; -      p_ai_nopaste = p_ai;      } -    /* -     * Always set the option values, also when 'paste' is set when it is -     * already on. -     */ -    /* set options for each buffer */ +    // Always set the option values, also when 'paste' is set when it is +    // already on. +    // set options for each buffer      FOR_ALL_BUFFERS(buf) { -      buf->b_p_tw = 0;              /* textwidth is 0 */ -      buf->b_p_wm = 0;              /* wrapmargin is 0 */ -      buf->b_p_sts = 0;             /* softtabstop is 0 */ -      buf->b_p_ai = 0;              /* no auto-indent */ -    } - -    /* set global options */ -    p_sm = 0;                       /* no showmatch */ -    if (p_ru) -      status_redraw_all();          /* redraw to remove the ruler */ -    p_ru = 0;                       /* no ruler */ -    p_ri = 0;                       /* no reverse insert */ -    p_hkmap = 0;                    /* no Hebrew keyboard */ -    /* set global values for local buffer options */ +      buf->b_p_tw = 0;              // textwidth is 0 +      buf->b_p_wm = 0;              // wrapmargin is 0 +      buf->b_p_sts = 0;             // softtabstop is 0 +      buf->b_p_ai = 0;              // no auto-indent +      buf->b_p_et = 0;              // no expandtab +    } + +    // set global options +    p_sm = 0;                       // no showmatch +    p_sta = 0;                      // no smarttab +    if (p_ru) { +      status_redraw_all();          // redraw to remove the ruler +    } +    p_ru = 0;                       // no ruler +    p_ri = 0;                       // no reverse insert +    p_hkmap = 0;                    // no Hebrew keyboard +    // set global values for local buffer options      p_tw = 0;      p_wm = 0;      p_sts = 0; @@ -6225,20 +6252,24 @@ static void paste_option_changed(void)        buf->b_p_wm = buf->b_p_wm_nopaste;        buf->b_p_sts = buf->b_p_sts_nopaste;        buf->b_p_ai = buf->b_p_ai_nopaste; +      buf->b_p_et = buf->b_p_et_nopaste;      }      /* restore global options */      p_sm = save_sm; -    if (p_ru != save_ru) -      status_redraw_all();          /* redraw to draw the ruler */ +    p_sta = save_sta; +    if (p_ru != save_ru) { +      status_redraw_all();          // redraw to draw the ruler +    }      p_ru = save_ru;      p_ri = save_ri;      p_hkmap = save_hkmap; -    /* set global values for local buffer options */ +    // set global values for local buffer options +    p_ai = p_ai_nopaste; +    p_et = p_et_nopaste; +    p_sts = p_sts_nopaste;      p_tw = p_tw_nopaste;      p_wm = p_wm_nopaste; -    p_sts = p_sts_nopaste; -    p_ai = p_ai_nopaste;    }    old_p_paste = p_paste; diff --git a/src/nvim/os/env.c b/src/nvim/os/env.c index c1804067e9..41ce8ddbc2 100644 --- a/src/nvim/os/env.c +++ b/src/nvim/os/env.c @@ -262,8 +262,25 @@ void expand_env_esc(char_u *srcp, char_u *dst, int dstlen, bool esc, bool one,      startstr_len = (int)STRLEN(startstr);    src = skipwhite(srcp); -  --dstlen;  // leave one char space for "\," +  dstlen--;  // leave one char space for "\,"    while (*src && dstlen > 0) { +    // Skip over `=expr`. +    if (src[0] == '`' && src[1] == '=') { +      var = src; +      src += 2; +      (void)skip_expr(&src); +      if (*src == '`') { +        src++; +      } +      size_t len = (size_t)(src - var); +      if (len > (size_t)dstlen) { +        len = (size_t)dstlen; +      } +      memcpy((char *)dst, (char *)var, len); +      dst += len; +      dstlen -= (int)len; +      continue; +    }      copy_char = true;      if ((*src == '$') || (*src == '~' && at_start)) {        mustfree = false; diff --git a/src/nvim/path.c b/src/nvim/path.c index 8b9a49dfc0..5cd93ab811 100644 --- a/src/nvim/path.c +++ b/src/nvim/path.c @@ -556,8 +556,9 @@ static size_t do_path_expand(garray_T *gap, const char_u *path,        return 0;    } -  /* make room for file name */ -  buf = xmalloc(STRLEN(path) + BASENAMELEN + 5); +  // Make room for file name.  When doing encoding conversion the actual +  // length may be quite a bit longer, thus use the maximum possible length. +  buf = xmalloc(MAXPATHL);    /*     * Find the first part in the path name that contains a wildcard. @@ -1158,12 +1159,17 @@ int gen_expand_wildcards(int num_pat, char_u **pat, int *num_file,      add_pat = -1;      p = pat[i]; -    if (vim_backtick(p)) +    if (vim_backtick(p)) {        add_pat = expand_backtick(&ga, p, flags); -    else { -      /* -       * First expand environment variables, "~/" and "~user/". -       */ +      if (add_pat == -1) { +        recursive = false; +        FreeWild(ga.ga_len, (char_u **)ga.ga_data); +        *num_file = 0; +        *file = NULL; +        return FAIL; +      } +    } else { +      // First expand environment variables, "~/" and "~user/".        if (has_env_var(p) || *p == '~') {          p = expand_env_save_opt(p, true);          if (p == NULL) @@ -1246,13 +1252,10 @@ static int vim_backtick(char_u *p)    return *p == '`' && *(p + 1) != NUL && *(p + STRLEN(p) - 1) == '`';  } -/* - * Expand an item in `backticks` by executing it as a command. - * Currently only works when pat[] starts and ends with a `. - * Returns number of file names found. - */ -static int  -expand_backtick ( +// Expand an item in `backticks` by executing it as a command. +// Currently only works when pat[] starts and ends with a `. +// Returns number of file names found, -1 if an error is encountered. +static int expand_backtick(      garray_T *gap,      char_u *pat,      int flags              /* EW_* flags */ @@ -1273,8 +1276,9 @@ expand_backtick (      buffer = get_cmd_output(cmd, NULL,          (flags & EW_SILENT) ? kShellOptSilent : 0, NULL);    xfree(cmd); -  if (buffer == NULL) -    return 0; +  if (buffer == NULL) { +    return -1; +  }    cmd = buffer;    while (*cmd != NUL) { @@ -1775,19 +1779,20 @@ bool same_directory(char_u *f1, char_u *f2)   */  int pathcmp(const char *p, const char *q, int maxlen)  { -  int i; +  int i, j;    int c1, c2;    const char  *s = NULL; -  for (i = 0; maxlen < 0 || i < maxlen; i += MB_PTR2LEN((char_u *)p + i)) { +  for (i = 0, j = 0; maxlen < 0 || (i < maxlen && j < maxlen);) {      c1 = PTR2CHAR((char_u *)p + i); -    c2 = PTR2CHAR((char_u *)q + i); +    c2 = PTR2CHAR((char_u *)q + j);      /* End of "p": check if "q" also ends or just has a slash. */      if (c1 == NUL) {        if (c2 == NUL)        /* full match */          return 0;        s = q; +      i = j;        break;      } @@ -1811,9 +1816,13 @@ int pathcmp(const char *p, const char *q, int maxlen)        return p_fic ? vim_toupper(c1) - vim_toupper(c2)               : c1 - c2;         /* no match */      } + +    i += MB_PTR2LEN((char_u *)p + i); +    j += MB_PTR2LEN((char_u *)q + j);    } -  if (s == NULL)        /* "i" ran into "maxlen" */ +  if (s == NULL) {  // "i" or "j" ran into "maxlen"      return 0; +  }    c1 = PTR2CHAR((char_u *)s + i);    c2 = PTR2CHAR((char_u *)s + i + MB_PTR2LEN((char_u *)s + i)); diff --git a/src/nvim/popupmnu.c b/src/nvim/popupmnu.c index 001740943f..5ad621e666 100644 --- a/src/nvim/popupmnu.c +++ b/src/nvim/popupmnu.c @@ -545,7 +545,11 @@ static int pum_set_selected(int n, int repeat)          g_do_tagpreview = (int)p_pvh;        }        RedrawingDisabled++; +      // Prevent undo sync here, if an autocommand syncs undo weird +      // things can happen to the undo tree. +      no_u_sync++;        resized = prepare_tagpreview(false); +      no_u_sync--;        RedrawingDisabled--;        g_do_tagpreview = 0; @@ -629,7 +633,9 @@ static int pum_set_selected(int n, int repeat)              // the window when needed, otherwise it will always be              // redraw.              if (resized) { +              no_u_sync++;                win_enter(curwin_save, true); +              no_u_sync--;                update_topline();              } @@ -640,7 +646,9 @@ static int pum_set_selected(int n, int repeat)              pum_do_redraw = FALSE;              if (!resized && win_valid(curwin_save)) { +              no_u_sync++;                win_enter(curwin_save, true); +              no_u_sync--;              }              // May need to update the screen again when there are diff --git a/src/nvim/screen.c b/src/nvim/screen.c index 7495647ff2..3b5836f0b5 100644 --- a/src/nvim/screen.c +++ b/src/nvim/screen.c @@ -2432,13 +2432,18 @@ win_line (      }    } -  /* find start of trailing whitespace */ -  if (wp->w_p_list && lcs_trail) { -    trailcol = (colnr_T)STRLEN(ptr); -    while (trailcol > (colnr_T)0 && ascii_iswhite(ptr[trailcol - 1])) -      --trailcol; -    trailcol += (colnr_T) (ptr - line); -    extra_check = TRUE; +  if (wp->w_p_list) { +    if (lcs_space || lcs_trail) { +      extra_check = true; +    } +    // find start of trailing whitespace +    if (lcs_trail) { +      trailcol = (colnr_T)STRLEN(ptr); +      while (trailcol > (colnr_T)0 && ascii_iswhite(ptr[trailcol - 1])) { +        trailcol--; +      } +      trailcol += (colnr_T) (ptr - line); +    }    }    /* @@ -3210,27 +3215,7 @@ win_line (          }        } -      ++ptr; - -      // 'list': change char 160 to lcs_nbsp and space to lcs_space. -      if (wp->w_p_list -          && (((c == 160 || (mb_utf8 && (mb_c == 160 || mb_c == 0x202f))) -               && lcs_nbsp) -              || (c == ' ' && lcs_space && ptr - line <=  trailcol))) { -        c = (c == ' ') ? lcs_space : lcs_nbsp; -        if (area_attr == 0 && search_attr == 0) { -          n_attr = 1; -          extra_attr = hl_attr(HLF_8); -          saved_attr2 = char_attr;           /* save current attr */ -        } -        mb_c = c; -        if (enc_utf8 && (*mb_char2len)(c) > 1) { -          mb_utf8 = TRUE; -          u8cc[0] = 0; -          c = 0xc0; -        } else -          mb_utf8 = FALSE; -      } +      ptr++;        if (extra_check) {          bool can_spell = true; @@ -3377,6 +3362,28 @@ win_line (            }          } +        // 'list': change char 160 to lcs_nbsp and space to lcs_space. +        if (wp->w_p_list +            && (((c == 160 +                  || (mb_utf8 && (mb_c == 160 || mb_c == 0x202f))) +                 && lcs_nbsp) +                || (c == ' ' && lcs_space && ptr - line <= trailcol))) { +          c = (c == ' ') ? lcs_space : lcs_nbsp; +          if (area_attr == 0 && search_attr == 0) { +            n_attr = 1; +            extra_attr = hl_attr(HLF_8); +            saved_attr2 = char_attr;  // save current attr +          } +          mb_c = c; +          if (enc_utf8 && (*mb_char2len)(c) > 1) { +            mb_utf8 = true; +            u8cc[0] = 0; +            c = 0xc0; +          } else { +            mb_utf8 = false; +          } +        } +          if (trailcol != MAXCOL && ptr > line + trailcol && c == ' ') {            c = lcs_trail;            if (!attr_pri) { diff --git a/src/nvim/search.c b/src/nvim/search.c index 827473e55d..fffae1ecb2 100644 --- a/src/nvim/search.c +++ b/src/nvim/search.c @@ -3144,10 +3144,12 @@ current_block (    }    if (VIsual_active) { -    if (*p_sel == 'e') -      ++curwin->w_cursor.col; -    if (sol && gchar_cursor() != NUL) -      inc(&curwin->w_cursor);           /* include the line break */ +    if (*p_sel == 'e') { +      inc(&curwin->w_cursor); +    } +    if (sol && gchar_cursor() != NUL) { +      inc(&curwin->w_cursor);  // include the line break +    }      VIsual = start_pos;      VIsual_mode = 'v';      redraw_curbuf_later(INVERTED);      /* update the inversion */ diff --git a/src/nvim/syntax.c b/src/nvim/syntax.c index b7d8a19de9..478fa973a1 100644 --- a/src/nvim/syntax.c +++ b/src/nvim/syntax.c @@ -3294,7 +3294,7 @@ static void syn_cmd_onoff(exarg_T *eap, char *name)    eap->nextcmd = check_nextcmd(eap->arg);    if (!eap->skip) {      char buf[100]; -    strncpy(buf, "so ", 3); +    strncpy(buf, "so ", 4);      vim_snprintf(buf + 3, sizeof(buf) - 3, SYNTAX_FNAME, name);      do_cmdline_cmd(buf);    } diff --git a/src/nvim/terminal.c b/src/nvim/terminal.c index 0a7807d811..fb74569e3b 100644 --- a/src/nvim/terminal.c +++ b/src/nvim/terminal.c @@ -236,7 +236,7 @@ Terminal *terminal_open(TerminalOptions opts)    set_option_value((uint8_t *)"relativenumber", false, NULL, OPT_LOCAL);    RESET_BINDING(curwin);    // Apply TermOpen autocmds so the user can configure the terminal -  apply_autocmds(EVENT_TERMOPEN, NULL, NULL, true, curbuf); +  apply_autocmds(EVENT_TERMOPEN, NULL, NULL, false, curbuf);    // Configure the scrollback buffer. Try to get the size from:    // @@ -288,8 +288,9 @@ void terminal_close(Terminal *term, char *msg)    term->forward_mouse = false;    term->closed = true; +  buf_T *buf = handle_get_buffer(term->buf_handle); +    if (!msg || exiting) { -    buf_T *buf = handle_get_buffer(term->buf_handle);      // If no msg was given, this was called by close_buffer(buffer.c).  Or if      // exiting, we must inform the buffer the terminal no longer exists so that      // close_buffer() doesn't call this again. @@ -304,6 +305,10 @@ void terminal_close(Terminal *term, char *msg)    } else {      terminal_receive(term, msg, strlen(msg));    } + +  if (buf) { +    apply_autocmds(EVENT_TERMCLOSE, NULL, NULL, false, buf); +  }  }  void terminal_resize(Terminal *term, uint16_t width, uint16_t height) diff --git a/src/nvim/testdir/Makefile b/src/nvim/testdir/Makefile index f077414e18..7886835b4d 100644 --- a/src/nvim/testdir/Makefile +++ b/src/nvim/testdir/Makefile @@ -9,12 +9,12 @@ SCRIPTSOURCE := ../../../runtime  SCRIPTS :=                                                             \                                     test8.out               test10.out  \ -           test11.out  test12.out  test13.out  test14.out              \ +                       test12.out  test13.out  test14.out              \                         test17.out                                      \                                                 test24.out              \                                                             test30.out  \                         test32.out              test34.out              \ -           test36.out  test37.out                          test40.out  \ +                       test37.out                          test40.out  \                         test42.out                                      \                         test47.out  test48.out  test49.out              \                         test52.out  test53.out              test55.out  \ @@ -25,7 +25,6 @@ SCRIPTS :=                                                             \                                     test88.out                          \             test_listlbr.out                                            \             test_breakindent.out                                        \ -           test_charsearch.out                                         \             test_close_count.out                                        \             test_marks.out                                              \             test_match_conceal.out                                      \ diff --git a/src/nvim/testdir/test11.in b/src/nvim/testdir/test11.in deleted file mode 100644 index 9e9e257c1d..0000000000 --- a/src/nvim/testdir/test11.in +++ /dev/null @@ -1,84 +0,0 @@ -Tests for autocommands: -- FileWritePre		writing a compressed file -- FileReadPost		reading a compressed file -- BufNewFile		reading a file template -- BufReadPre		decompressing the file to be read -- FilterReadPre		substituting characters in the temp file -- FilterReadPost	substituting characters after filtering -- FileReadPre		set options for decompression -- FileReadPost		decompress the file - -Note: This test is skipped if "gzip" is not available. -$GZIP is made empty, "-v" would cause trouble. -Use a FileChangedShell autocommand to avoid a prompt for "Xtestfile.gz" being -modified outside of Vim (noticed on Solaris). - -STARTTEST -:so small.vim -:" drop out when there is no gzip program -:if !executable("gzip") -: e! test.ok -: w! test.out -: qa! -:endif -:let $GZIP = "" -:au FileChangedShell * echo "caught FileChangedShell" -:set bin -:au FileWritePre    *.gz   '[,']!gzip -:au FileWritePost   *.gz   undo -:/^start of testfile/,/^end of testfile/w! Xtestfile.gz -:au FileReadPost    *.gz   '[,']!gzip -d -:$r Xtestfile.gz                " Read and decompress the testfile -:?startstart?,$w! test.out      " Write contents of this file -:au BufNewFile      *.c    read Xtest.c -:/^start of test.c/+1,/^end of test.c/-1w! Xtest.c -:e! foo.c                       " Will load Xtest.c -:au FileAppendPre   *.out  '[,']s/new/NEW/ -:au FileAppendPost  *.out  !cat Xtest.c >>test.out -:w>>test.out                    " Append it to the output file -:au! FileAppendPre -:" setup autocommands to decompress before reading and re-compress afterwards -:au BufReadPre      *.gz   exe '!gzip -d ' . shellescape(expand("<afile>")) -:au BufReadPre      *.gz   call rename(expand("<afile>:r"), expand("<afile>")) -:au BufReadPost     *.gz   call rename(expand("<afile>"), expand("<afile>:r")) -:au BufReadPost     *.gz   exe '!gzip ' . shellescape(expand("<afile>:r")) -:e! Xtestfile.gz                " Edit compressed file -:w>>test.out                    " Append it to the output file -:set shelltemp                  " need temp files here -:au FilterReadPre   *.out  call rename(expand("<afile>"), expand("<afile>") . ".t") -:au FilterReadPre   *.out  exe 'silent !sed s/e/E/ ' . shellescape(expand("<afile>")) . ".t >" . shellescape(expand("<afile>")) -:au FilterReadPre   *.out  exe 'silent !rm ' . shellescape(expand("<afile>")) . '.t' -:au FilterReadPost  *.out  '[,']s/x/X/g -:e! test.out                    " Edit the output file -:23,$!cat -:23,$s/\r$//                 " remove CR for when sed adds them -:au! FileReadPre    *.gz   exe 'silent !gzip -d ' . shellescape(expand("<afile>")) -:au  FileReadPre    *.gz   call rename(expand("<afile>:r"), expand("<afile>")) -:au! FileReadPost   *.gz   '[,']s/l/L/ -:$r Xtestfile.gz             " Read compressed file -:w                           " write it, after filtering -:au!             " remove all autocommands -:e               " Edit test.out again -:set nobin ff&   " use the default fileformat for writing -:w -:qa! -ENDTEST - -startstart -start of testfile -line 2	Abcdefghijklmnopqrstuvwxyz -line 3	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -line 4	Abcdefghijklmnopqrstuvwxyz -line 5	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -line 6	Abcdefghijklmnopqrstuvwxyz -line 7	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -line 8	Abcdefghijklmnopqrstuvwxyz -line 9	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -line 10 Abcdefghijklmnopqrstuvwxyz -end of testfile - -start of test.c -/* - * Here is a new .c file - */ -end of test.c diff --git a/src/nvim/testdir/test11.ok b/src/nvim/testdir/test11.ok deleted file mode 100644 index af8c5ce261..0000000000 --- a/src/nvim/testdir/test11.ok +++ /dev/null @@ -1,61 +0,0 @@ -startstart -start of testfile -line 2	Abcdefghijklmnopqrstuvwxyz -line 3	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -line 4	Abcdefghijklmnopqrstuvwxyz -line 5	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -line 6	Abcdefghijklmnopqrstuvwxyz -line 7	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -line 8	Abcdefghijklmnopqrstuvwxyz -line 9	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -line 10 Abcdefghijklmnopqrstuvwxyz -end of testfile - -start of test.c -/* - * Here is a new .c file - */ -end of test.c -start of testfile -line 2	Abcdefghijklmnopqrstuvwxyz -line 3	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -line 4	Abcdefghijklmnopqrstuvwxyz -linE 5	XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -linE 6	AbcdefghijklmnopqrstuvwXyz -linE 7	XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -linE 8	AbcdefghijklmnopqrstuvwXyz -linE 9	XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -linE 10 AbcdefghijklmnopqrstuvwXyz -End of testfile - -/* - * HEre is a NEW .c file - */ -/* - * HEre is a new .c file - */ -start of tEstfile -linE 2	AbcdefghijklmnopqrstuvwXyz -linE 3	XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -linE 4	AbcdefghijklmnopqrstuvwXyz -linE 5	XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -linE 6	AbcdefghijklmnopqrstuvwXyz -linE 7	XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -linE 8	AbcdefghijklmnopqrstuvwXyz -linE 9	XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX -linE 10 AbcdefghijklmnopqrstuvwXyz -End of testfile -/* - * HEre is a new .c file - */ -start of testfiLe -Line 2	Abcdefghijklmnopqrstuvwxyz -Line 3	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -Line 4	Abcdefghijklmnopqrstuvwxyz -Line 5	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -Line 6	Abcdefghijklmnopqrstuvwxyz -Line 7	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -Line 8	Abcdefghijklmnopqrstuvwxyz -Line 9	xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx -Line 10 Abcdefghijklmnopqrstuvwxyz -end of testfiLe diff --git a/src/nvim/testdir/test36.in b/src/nvim/testdir/test36.in deleted file mode 100644 index 8cdb5262bd..0000000000 --- a/src/nvim/testdir/test36.in +++ /dev/null @@ -1,105 +0,0 @@ -Test character classes in regexp using regexpengine 0, 1, 2. - -STARTTEST -/^start-here/+1 -Y:s/\%#=0\d//g -p:s/\%#=1\d//g -p:s/\%#=2\d//g -p:s/\%#=0[0-9]//g -p:s/\%#=1[0-9]//g -p:s/\%#=2[0-9]//g -p:s/\%#=0\D//g -p:s/\%#=1\D//g -p:s/\%#=2\D//g -p:s/\%#=0[^0-9]//g -p:s/\%#=1[^0-9]//g -p:s/\%#=2[^0-9]//g -p:s/\%#=0\o//g -p:s/\%#=1\o//g -p:s/\%#=2\o//g -p:s/\%#=0[0-7]//g -p:s/\%#=1[0-7]//g -p:s/\%#=2[0-7]//g -p:s/\%#=0\O//g -p:s/\%#=1\O//g -p:s/\%#=2\O//g -p:s/\%#=0[^0-7]//g -p:s/\%#=1[^0-7]//g -p:s/\%#=2[^0-7]//g -p:s/\%#=0\x//g -p:s/\%#=1\x//g -p:s/\%#=2\x//g -p:s/\%#=0[0-9A-Fa-f]//g -p:s/\%#=1[0-9A-Fa-f]//g -p:s/\%#=2[0-9A-Fa-f]//g -p:s/\%#=0\X//g -p:s/\%#=1\X//g -p:s/\%#=2\X//g -p:s/\%#=0[^0-9A-Fa-f]//g -p:s/\%#=1[^0-9A-Fa-f]//g -p:s/\%#=2[^0-9A-Fa-f]//g -p:s/\%#=0\w//g -p:s/\%#=1\w//g -p:s/\%#=2\w//g -p:s/\%#=0[0-9A-Za-z_]//g -p:s/\%#=1[0-9A-Za-z_]//g -p:s/\%#=2[0-9A-Za-z_]//g -p:s/\%#=0\W//g -p:s/\%#=1\W//g -p:s/\%#=2\W//g -p:s/\%#=0[^0-9A-Za-z_]//g -p:s/\%#=1[^0-9A-Za-z_]//g -p:s/\%#=2[^0-9A-Za-z_]//g -p:s/\%#=0\h//g -p:s/\%#=1\h//g -p:s/\%#=2\h//g -p:s/\%#=0[A-Za-z_]//g -p:s/\%#=1[A-Za-z_]//g -p:s/\%#=2[A-Za-z_]//g -p:s/\%#=0\H//g -p:s/\%#=1\H//g -p:s/\%#=2\H//g -p:s/\%#=0[^A-Za-z_]//g -p:s/\%#=1[^A-Za-z_]//g -p:s/\%#=2[^A-Za-z_]//g -p:s/\%#=0\a//g -p:s/\%#=1\a//g -p:s/\%#=2\a//g -p:s/\%#=0[A-Za-z]//g -p:s/\%#=1[A-Za-z]//g -p:s/\%#=2[A-Za-z]//g -p:s/\%#=0\A//g -p:s/\%#=1\A//g -p:s/\%#=2\A//g -p:s/\%#=0[^A-Za-z]//g -p:s/\%#=1[^A-Za-z]//g -p:s/\%#=2[^A-Za-z]//g -p:s/\%#=0\l//g -p:s/\%#=1\l//g -p:s/\%#=2\l//g -p:s/\%#=0[a-z]//g -p:s/\%#=1[a-z]//g -p:s/\%#=2[a-z]//g -p:s/\%#=0\L//g -p:s/\%#=1\L//g -p:s/\%#=2\L//g -p:s/\%#=0[^a-z]//g -p:s/\%#=1[^a-z]//g -p:s/\%#=2[^a-z]//g -p:s/\%#=0\u//g -p:s/\%#=1\u//g -p:s/\%#=2\u//g -p:s/\%#=0[A-Z]//g -p:s/\%#=1[A-Z]//g -p:s/\%#=2[A-Z]//g -p:s/\%#=0\U//g -p:s/\%#=1\U//g -p:s/\%#=2\U//g -p:s/\%#=0[^A-Z]//g -p:s/\%#=1[^A-Z]//g -p:s/\%#=2[^A-Z]//g -:/^start-here/+1,$wq! test.out -ENDTEST - -start-here -	
 !"#$%&'()#+'-./0123456789:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé diff --git a/src/nvim/testdir/test36.ok b/src/nvim/testdir/test36.ok deleted file mode 100644 index f72a74b2b7..0000000000 --- a/src/nvim/testdir/test36.ok +++ /dev/null @@ -1,96 +0,0 @@ -	
 !"#$%&'()#+'-./:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -0123456789 -0123456789 -0123456789 -0123456789 -0123456789 -0123456789 -	
 !"#$%&'()#+'-./89:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./89:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./89:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./89:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./89:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./89:;<=>?@ABCDEFGHIXYZ[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -01234567 -01234567 -01234567 -01234567 -01234567 -01234567 -	
 !"#$%&'()#+'-./:;<=>?@GHIXYZ[\]^_`ghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@GHIXYZ[\]^_`ghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@GHIXYZ[\]^_`ghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@GHIXYZ[\]^_`ghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@GHIXYZ[\]^_`ghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@GHIXYZ[\]^_`ghiwxyz{|}~€‚›¦±¼ÇÓé -0123456789ABCDEFabcdef -0123456789ABCDEFabcdef -0123456789ABCDEFabcdef -0123456789ABCDEFabcdef -0123456789ABCDEFabcdef -0123456789ABCDEFabcdef -	
 !"#$%&'()#+'-./:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -0123456789ABCDEFGHIXYZ_abcdefghiwxyz -0123456789ABCDEFGHIXYZ_abcdefghiwxyz -0123456789ABCDEFGHIXYZ_abcdefghiwxyz -0123456789ABCDEFGHIXYZ_abcdefghiwxyz -0123456789ABCDEFGHIXYZ_abcdefghiwxyz -0123456789ABCDEFGHIXYZ_abcdefghiwxyz -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^`{|}~€‚›¦±¼ÇÓé -ABCDEFGHIXYZ_abcdefghiwxyz -ABCDEFGHIXYZ_abcdefghiwxyz -ABCDEFGHIXYZ_abcdefghiwxyz -ABCDEFGHIXYZ_abcdefghiwxyz -ABCDEFGHIXYZ_abcdefghiwxyz -ABCDEFGHIXYZ_abcdefghiwxyz -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`{|}~€‚›¦±¼ÇÓé -ABCDEFGHIXYZabcdefghiwxyz -ABCDEFGHIXYZabcdefghiwxyz -ABCDEFGHIXYZabcdefghiwxyz -ABCDEFGHIXYZabcdefghiwxyz -ABCDEFGHIXYZabcdefghiwxyz -ABCDEFGHIXYZabcdefghiwxyz -	
 !"#$%&'()#+'-./0123456789:;<=>?@ABCDEFGHIXYZ[\]^_`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@ABCDEFGHIXYZ[\]^_`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@ABCDEFGHIXYZ[\]^_`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@ABCDEFGHIXYZ[\]^_`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@ABCDEFGHIXYZ[\]^_`{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@ABCDEFGHIXYZ[\]^_`{|}~€‚›¦±¼ÇÓé -abcdefghiwxyz -abcdefghiwxyz -abcdefghiwxyz -abcdefghiwxyz -abcdefghiwxyz -abcdefghiwxyz -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -	
 !"#$%&'()#+'-./0123456789:;<=>?@[\]^_`abcdefghiwxyz{|}~€‚›¦±¼ÇÓé -ABCDEFGHIXYZ -ABCDEFGHIXYZ -ABCDEFGHIXYZ -ABCDEFGHIXYZ -ABCDEFGHIXYZ -ABCDEFGHIXYZ diff --git a/src/nvim/testdir/test49.vim b/src/nvim/testdir/test49.vim index afee9d882c..70d388b06a 100644 --- a/src/nvim/testdir/test49.vim +++ b/src/nvim/testdir/test49.vim @@ -1,6 +1,6 @@  " Vim script language tests  " Author:	Servatius Brandt <Servatius.Brandt@fujitsu-siemens.com> -" Last Change:	2013 Jun 06 +" Last Change:	2015 Sep 25  "-------------------------------------------------------------------------------  " Test environment							    {{{1 @@ -5188,19 +5188,19 @@ catch /.*/      Xpath 65536					" X: 65536      let exception  = v:exception      let throwpoint = v:throwpoint -    call CHECK(1, "oops", '\<F\.\.G\.\.T\>', '\<2\>') +    call CHECK(1, "oops", '\<F\[1]\.\.G\[1]\.\.T\>', '\<2\>')      exec "let exception  = v:exception"      exec "let throwpoint = v:throwpoint" -    call CHECK(2, "oops", '\<F\.\.G\.\.T\>', '\<2\>') +    call CHECK(2, "oops", '\<F\[1]\.\.G\[1]\.\.T\>', '\<2\>')      CmdException      CmdThrowpoint -    call CHECK(3, "oops", '\<F\.\.G\.\.T\>', '\<2\>') +    call CHECK(3, "oops", '\<F\[1]\.\.G\[1]\.\.T\>', '\<2\>')      call FuncException()      call FuncThrowpoint() -    call CHECK(4, "oops", '\<F\.\.G\.\.T\>', '\<2\>') +    call CHECK(4, "oops", '\<F\[1]\.\.G\[1]\.\.T\>', '\<2\>')      exec "source" scriptException      exec "source" scriptThrowPoint -    call CHECK(5, "oops", '\<F\.\.G\.\.T\>', '\<2\>') +    call CHECK(5, "oops", '\<F\[1]\.\.G\[1]\.\.T\>', '\<2\>')      try  	Xpath 131072				" X: 131072  	call G("arrgh", 4) @@ -5208,7 +5208,7 @@ catch /.*/  	Xpath 262144				" X: 262144  	let exception  = v:exception  	let throwpoint = v:throwpoint -	call CHECK(6, "arrgh", '\<G\.\.T\>', '\<4\>') +	call CHECK(6, "arrgh", '\<G\[1]\.\.T\>', '\<4\>')  	try  	    Xpath 524288			" X: 524288  	    let g:arg = "autsch" @@ -5226,7 +5226,7 @@ catch /.*/  	    Xpath 2097152			" X: 2097152  	    let exception  = v:exception  	    let throwpoint = v:throwpoint -	    call CHECK(8, "arrgh", '\<G\.\.T\>', '\<4\>') +	    call CHECK(8, "arrgh", '\<G\[1]\.\.T\>', '\<4\>')  	    try  		Xpath 4194304			" X: 4194304  		let g:arg = "brrrr" @@ -5242,27 +5242,27 @@ catch /.*/  		Xpath 16777216			" X: 16777216  		let exception  = v:exception  		let throwpoint = v:throwpoint -		call CHECK(10, "arrgh", '\<G\.\.T\>', '\<4\>') +		call CHECK(10, "arrgh", '\<G\[1]\.\.T\>', '\<4\>')  	    endtry  	    Xpath 33554432			" X: 33554432  	    let exception  = v:exception  	    let throwpoint = v:throwpoint -	    call CHECK(11, "arrgh", '\<G\.\.T\>', '\<4\>') +	    call CHECK(11, "arrgh", '\<G\[1]\.\.T\>', '\<4\>')  	endtry  	Xpath 67108864				" X: 67108864  	let exception  = v:exception  	let throwpoint = v:throwpoint -	call CHECK(12, "arrgh", '\<G\.\.T\>', '\<4\>') +	call CHECK(12, "arrgh", '\<G\[1]\.\.T\>', '\<4\>')      finally  	Xpath 134217728				" X: 134217728  	let exception  = v:exception  	let throwpoint = v:throwpoint -	call CHECK(13, "oops", '\<F\.\.G\.\.T\>', '\<2\>') +	call CHECK(13, "oops", '\<F\[1]\.\.G\[1]\.\.T\>', '\<2\>')      endtry      Xpath 268435456				" X: 268435456      let exception  = v:exception      let throwpoint = v:throwpoint -    call CHECK(14, "oops", '\<F\.\.G\.\.T\>', '\<2\>') +    call CHECK(14, "oops", '\<F\[1]\.\.G\[1]\.\.T\>', '\<2\>')  finally      Xpath 536870912				" X: 536870912      let exception  = v:exception diff --git a/src/nvim/testdir/test_charsearch.in b/src/nvim/testdir/test_charsearch.in deleted file mode 100644 index 5085cb39bc..0000000000 --- a/src/nvim/testdir/test_charsearch.in +++ /dev/null @@ -1,25 +0,0 @@ -Test for character searches - -STARTTEST -:so small.vim -:" check that "fe" and ";" work -/^X -ylfep;;p,,p: -:" check that save/restore works -/^Y -ylfep:let csave = getcharsearch() -fip:call setcharsearch(csave) -;p;p: -:" check that setcharsearch() changes the settins. -/^Z -ylfep:call setcharsearch({'char': 'k'}) -;p:call setcharsearch({'forward': 0}) -$;p:call setcharseearch({'until'}: 1}) -;;p: -:/^X/,$w! test.out -:qa! -ENDTEST - -Xabcdefghijkemnopqretuvwxyz -Yabcdefghijkemnopqretuvwxyz -Zabcdefghijkemnokqretkvwxyz diff --git a/src/nvim/testdir/test_charsearch.ok b/src/nvim/testdir/test_charsearch.ok deleted file mode 100644 index a0c90e24f9..0000000000 --- a/src/nvim/testdir/test_charsearch.ok +++ /dev/null @@ -1,3 +0,0 @@ -XabcdeXfghijkeXmnopqreXtuvwxyz -YabcdeYfghiYjkeYmnopqreYtuvwxyz -ZabcdeZfghijkZemnokZqretkZvwxyz diff --git a/src/nvim/testdir/test_listlbr.in b/src/nvim/testdir/test_listlbr.in index f13eee121e..6084711786 100644 --- a/src/nvim/testdir/test_listlbr.in +++ b/src/nvim/testdir/test_listlbr.in @@ -24,20 +24,24 @@ STARTTEST  :	$put =g:line  :	wincmd p  :endfu +:"  :let g:test="Test 1: set linebreak"  :redraw!  :let line=ScreenChar(winwidth(0))  :call DoRecordScreen() +:"  :let g:test="Test 2: set linebreak + set list"  :set linebreak list listchars=  :redraw!  :let line=ScreenChar(winwidth(0))  :call DoRecordScreen() +:"  :let g:test ="Test 3: set linebreak nolist"  :set nolist linebreak  :redraw!  :let line=ScreenChar(winwidth(0))  :call DoRecordScreen() +:"  :let g:test ="Test 4: set linebreak with tab and 1 line as long as screen: should break!"  :set nolist linebreak ts=8  :let line="1\t".repeat('a', winwidth(0)-2) @@ -51,6 +55,7 @@ STARTTEST  :$put =line  :$  :norm! zt +:"  :let g:test ="Test 5: set linebreak with conceal and set list and tab displayed by different char (line may not be truncated)"  :set cpo&vim list linebreak conceallevel=2 concealcursor=nv listchars=tab:ab  :syn match ConcealVar contained /_/ conceal @@ -58,6 +63,7 @@ STARTTEST  :let line=ScreenChar(winwidth(0))  :call DoRecordScreen()  :set cpo&vim linebreak +:"  :let g:test ="Test 6: set linebreak with visual block mode"  :let line="REMOVE: this not"  :$put =g:test @@ -67,20 +73,47 @@ STARTTEST  :1/^REMOVE:  0jf x:$put  :set cpo&vim linebreak +:"  :let g:test ="Test 7: set linebreak with visual block mode and v_b_A"  :$put =g:test  Golong line: 40afoobar aTARGET at end  :exe "norm! $3B\<C-v>eAx\<Esc>"  :set cpo&vim linebreak sbr= +:"  :let g:test ="Test 8: set linebreak with visual char mode and changing block"  :$put =g:test  Go1111-1111-1111-11-1111-1111-11110f-lv3lc2222bgj. +:"  :let g:test ="Test 9: using redo after block visual mode"  :$put =g:test  Go  aaa  aaa  a2k2j~e. +:" +:let g:test ="Test 10: using normal commands after block-visual" +:$put =g:test +:set linebreak +Go +abcd{ef +ghijklm +no}pqrs2k0f{c% +:" +:let g:test ="Test 11: using block replace mode after wrapping" +:$put =g:test +:set linebreak wrap +Go150aayypk147|jr0 +:" +:let g:test ="Test 12: set linebreak list listchars=space:_,tab:>-,tail:-,eol:$" +:set list listchars=space:_,trail:-,tab:>-,eol:$ +:$put =g:test +:let line="a aaaaaaaaaaaaaaaaaaaaaa\ta " +:$put =line +:$ +:norm! zt +:redraw! +:let line=ScreenChar(winwidth(0)) +:call DoRecordScreen()  :%w! test.out  :qa!  ENDTEST diff --git a/src/nvim/testdir/test_listlbr.ok b/src/nvim/testdir/test_listlbr.ok index 323bcdee08..b32a54969e 100644 --- a/src/nvim/testdir/test_listlbr.ok +++ b/src/nvim/testdir/test_listlbr.ok @@ -46,3 +46,17 @@ Test 9: using redo after block visual mode  AaA  AaA  A +Test 10: using normal commands after block-visual + +abcdpqrs +Test 11: using block replace mode after wrapping +aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa0aaa +aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa0aaa +Test 12: set linebreak list listchars=space:_,tab:>-,tail:-,eol:$ +a aaaaaaaaaaaaaaaaaaaaaa	a  + +Test 12: set linebreak list listchars=space:_,tab:>-,tail:-,eol:$ +a_                   +aaaaaaaaaaaaaaaaaaaa +aa>-----a-$          +~                    diff --git a/src/nvim/version.c b/src/nvim/version.c index a1db346d1f..4db0cb4b08 100644 --- a/src/nvim/version.c +++ b/src/nvim/version.c @@ -69,6 +69,8 @@ static char *features[] = {  // clang-format off  static int included_patches[] = { +  1366, +    // 1219 NA    // 1218 NA    // 1217 NA @@ -247,7 +249,7 @@ static int included_patches[] = {    // 1044 NA,    // 1043 NA,    // 1042, -  // 1041, +  1041,    // 1040 NA,    // 1039,    // 1038 NA, @@ -311,7 +313,7 @@ static int included_patches[] = {    980,    // 979 NA    978, -  // 977, +  977,    // 976 NA    975,    // 974, @@ -349,7 +351,7 @@ static int included_patches[] = {    // 942,    // 941,    // 940 NA -  // 939, +  939,    // 938 NA    // 937,    // 936, @@ -366,7 +368,7 @@ static int included_patches[] = {    // 925,    // 924 NA    // 923 NA -  // 922, +  922,    // 921 NA    // 920 NA    // 919 NA @@ -376,7 +378,7 @@ static int included_patches[] = {    915,    // 914,    // 913 NA -  // 912, +  912,    // 911 NA    // 910 NA    // 909, @@ -385,42 +387,42 @@ static int included_patches[] = {    // 906 NA    // 905,    // 904, -  // 903, +  903,    // 902 NA -  // 901, +  901,    // 900 NA    // 899 NA    898,    // 897 NA    // 896, -  // 895, +  895,    // 894 NA -  // 893, +  893,    // 892, -  // 891, +  891,    // 890 NA    // 889, -  // 888, +  888,    887,    // 886 NA -  // 885, +  885,    // 884 NA -  // 883, +  883,    // 882, -  // 881, +  881,    // 880 NA -  // 879, -  // 878, -  // 877, +  879, +  878, +  877,    // 876 NA    // 875 NA    // 874 NA    // 873 NA    // 872 NA    // 871, -  // 870, +  870,    // 869 NA -  // 868, +  868,    // 867 NA    // 866 NA    // 865 NA @@ -429,23 +431,23 @@ static int included_patches[] = {    // 862 NA    // 861 NA    // 860 NA -  // 859, +  859,    858,    // 857, -  // 856, +  856,    // 855 NA    // 854 NA -  // 853, +  853,    // 852 NA    // 851 NA    // 850 NA    849,    848, -  // 847, +  847,    // 846 NA -  // 845, -  // 844, -  // 843, +  845, +  844, +  843,    // 842 NA    // 841 NA    // 840 NA @@ -453,12 +455,12 @@ static int included_patches[] = {    // 838 NA    // 837 NA    836, -  // 835, +  835,    834, -  // 833, -  // 832, -  // 831, -  // 830, +  833, +  832, +  831, +  830,    // 829 NA    828,    // 827 NA @@ -470,7 +472,7 @@ static int included_patches[] = {    // 821 NA    820,    // 819, -  // 818, +  818,    817,    816,    815, | 
