# HG changeset patch # User Bram Moolenaar # Date 1578083414 -3600 # Node ID 143d44d8f47745c8f89a66ed948c463f163136ba # Parent af795b6a2624d07e6db3e685bcfb3bb109c1aa79 patch 8.2.0083: text properties wrong when tabs and spaces are exchanged Commit: https://github.com/vim/vim/commit/5cb0b93d52fa5c12ca50a18509947ee6459bb7a8 Author: Bram Moolenaar 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) diff --git a/src/edit.c b/src/edit.c --- 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()) diff --git a/src/testdir/test_textprop.vim b/src/testdir/test_textprop.vim --- 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("\\0Ca\\\", "tx") + call prop_type_add('test', {'highlight': 'ErrorMsg'}) + call prop_add(1, 1, {'end_col': 2, 'type': 'test'}) + call feedkeys("0i\", "tx") + call prop_remove({'type': 'test'}) + call prop_add(1, 2, {'end_col': 3, 'type': 'test'}) + call feedkeys("A\\", "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\\", "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 diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -743,6 +743,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 83, +/**/ 82, /**/ 81,