Mercurial > vim
changeset 19045:143d44d8f477 v8.2.0083
patch 8.2.0083: text properties wrong when tabs and spaces are exchanged
Commit: https://github.com/vim/vim/commit/5cb0b93d52fa5c12ca50a18509947ee6459bb7a8
Author: Bram Moolenaar <Bram@vim.org>
Date: Fri Jan 3 21:25:59 2020 +0100
patch 8.2.0083: text properties wrong when tabs and spaces are exchanged
Problem: Text properties wrong when tabs and spaces are exchanged.
Solution: Take text properties into account. (Nobuhiro Takasaki,
closes #5427)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Fri, 03 Jan 2020 21:30:14 +0100 |
parents | af795b6a2624 |
children | 69e878ae5d4b |
files | src/edit.c src/testdir/test_textprop.vim src/version.c |
diffstat | 3 files changed, 48 insertions(+), 4 deletions(-) [+] |
line wrap: on
line diff
--- a/src/edit.c +++ b/src/edit.c @@ -5601,14 +5601,20 @@ ins_tab(void) i = cursor->col - fpos.col; if (i > 0) { - STRMOVE(ptr, ptr + i); +#ifdef FEAT_PROP_POPUP + if (!(State & VREPLACE_FLAG)) + { + mch_memmove(ptr, ptr + i, curbuf->b_ml.ml_line_len - i + - (ptr - curbuf->b_ml.ml_line_ptr)); + curbuf->b_ml.ml_line_len -= i; + } + else +#endif + STRMOVE(ptr, ptr + i); // correct replace stack. if ((State & REPLACE_FLAG) && !(State & VREPLACE_FLAG)) for (temp = i; --temp >= 0; ) replace_join(repl_off); -#ifdef FEAT_PROP_POPUP - curbuf->b_ml.ml_line_len -= i; -#endif } #ifdef FEAT_NETBEANS_INTG if (netbeans_active())
--- a/src/testdir/test_textprop.vim +++ b/src/testdir/test_textprop.vim @@ -925,3 +925,39 @@ func Test_proptype_substitute2() call assert_equal(expected, prop_list(1)) bwipe! endfunc + +func Test_textprop_noexpandtab() + %bwipe! + new + let save_ts = &tabstop + set tabstop=8 + let save_sts = &softtabstop + set softtabstop=4 + let save_sw = &shiftwidth + set shiftwidth=4 + let save_et = &expandtab + set noexpandtab + let save_fdm = &foldmethod + set foldmethod=marker + call feedkeys("\<esc>\<esc>0Ca\<cr>\<esc>\<up>", "tx") + call prop_type_add('test', {'highlight': 'ErrorMsg'}) + call prop_add(1, 1, {'end_col': 2, 'type': 'test'}) + call feedkeys("0i\<tab>", "tx") + call prop_remove({'type': 'test'}) + call prop_add(1, 2, {'end_col': 3, 'type': 'test'}) + call feedkeys("A\<left>\<tab>", "tx") + call prop_remove({'type': 'test'}) + try + " It is correct that this does not pass + call prop_add(1, 6, {'end_col': 7, 'type': 'test'}) + " Has already collapsed here, start_col:6 does not result in an error + call feedkeys("A\<left>\<tab>", "tx") + catch /^Vim\%((\a\+)\)\=:E964/ + endtry + call prop_remove({'type': 'test'}) + let &foldmethod = save_fdm + let &expandtab = save_et + let &shiftwidth = save_sw + let &softtabstop = save_sts + let &tabstop = save_ts +endfunc