1
0
forked from aniani/vim

patch 8.2.3684: blockwise insert does not handle autoindent properly

Problem:    Blockwise insert does not handle autoindent properly.
Solution:   Adjust text column for indent. (closes #9229)
This commit is contained in:
Bram Moolenaar
2021-11-27 13:28:24 +00:00
parent 279d733dfb
commit e9b0b40b79
3 changed files with 33 additions and 0 deletions

View File

@@ -1627,6 +1627,10 @@ op_insert(oparg_T *oap, long count1)
--bd2.textlen; --bd2.textlen;
} }
bd.textcol = bd2.textcol; bd.textcol = bd2.textcol;
if (did_indent && bd.textcol > ind_pre)
// If the insert was in the indent then include the indent
// change in the new text, otherwise don't.
bd.textcol += ind_post - ind_pre;
bd.textlen = bd2.textlen; bd.textlen = bd2.textlen;
} }

View File

@@ -14,6 +14,33 @@ func Test_blockinsert_indent()
bwipe! bwipe!
endfunc endfunc
func Test_blockinsert_autoindent()
new
let lines =<< trim END
var d = {
a: () => 0,
b: () => 0,
c: () => 0,
}
END
call setline(1, lines)
filetype plugin indent on
setlocal sw=2 et ft=vim
setlocal indentkeys+=:
exe "norm! 2Gf)\<c-v>2jA: asdf\<esc>"
let expected =<< trim END
var d = {
a: (): asdf => 0,
b: (): asdf => 0,
c: (): asdf => 0,
}
END
call assert_equal(expected, getline(1, 5))
filetype off
bwipe!
endfunc
func Test_blockinsert_delete() func Test_blockinsert_delete()
new new
let _bs = &bs let _bs = &bs

View File

@@ -757,6 +757,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
3684,
/**/ /**/
3683, 3683,
/**/ /**/