summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2022-05-14 12:54:23 +0100
committerBram Moolenaar <Bram@vim.org>2022-05-14 12:54:23 +0100
commit2e444bbef0f36535bf941f007f2961f3f66bbe87 (patch)
tree339b31cf21dc01e77bf19400c52ba88ac10c4374
parent98feacedf9c03b8db79da03508a2c3c25dac3e53 (diff)
patch 8.2.4953: with 'si' inserting '}' after completion goes wrongv8.2.4953
Problem: With 'smartindent' inserting '}' after completion goes wrong. Solution: Check the cursor is in indent. (closes #10420)
-rw-r--r--src/indent.c3
-rw-r--r--src/testdir/test_smartindent.vim5
-rw-r--r--src/version.c2
3 files changed, 9 insertions, 1 deletions
diff --git a/src/indent.c b/src/indent.c
index dfc481a785..486259ef2a 100644
--- a/src/indent.c
+++ b/src/indent.c
@@ -1197,7 +1197,8 @@ ins_try_si(int c)
int temp;
// do some very smart indenting when entering '{' or '}'
- if (((did_si || can_si_back) && c == '{') || (can_si && c == '}'))
+ if (((did_si || can_si_back) && c == '{')
+ || (can_si && c == '}' && inindent(0)))
{
// for '}' set indent equal to indent of line containing matching '{'
if (c == '}' && (pos = findmatch(NULL, '{')) != NULL)
diff --git a/src/testdir/test_smartindent.vim b/src/testdir/test_smartindent.vim
index edfec9a809..9bb7b9c227 100644
--- a/src/testdir/test_smartindent.vim
+++ b/src/testdir/test_smartindent.vim
@@ -140,6 +140,11 @@ func Test_si_after_completion()
call setline(1, 'foo foot')
call feedkeys("o f\<C-X>\<C-N>#", 'tx')
call assert_equal(' foo#', getline(2))
+
+ call setline(2, '')
+ call feedkeys("1Go f\<C-X>\<C-N>}", 'tx')
+ call assert_equal(' foo}', getline(2))
+
bwipe!
endfunc
diff --git a/src/version.c b/src/version.c
index 9017eeb1f5..81bbdf9583 100644
--- a/src/version.c
+++ b/src/version.c
@@ -747,6 +747,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 4953,
+/**/
4952,
/**/
4951,