summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristian Brabandt <cb@256bit.org>2022-04-07 21:00:53 +0100
committerBram Moolenaar <Bram@vim.org>2022-04-07 21:00:53 +0100
commitac72c21da696cf6c31630a9e5ff4c0d3e2049c11 (patch)
tree77e3a365158f60d4764db59d54ca20d42a07d922
parent5017c66bd461eab46094e076ad1aa818e246ce9d (diff)
patch 8.2.4710: smart indenting does not work after completionv8.2.4710
Problem: Smart indenting does not work after completion. Solution: Set "can_si". (Christian Brabandt, closes #10113, closes #558)
-rw-r--r--src/edit.c3
-rw-r--r--src/testdir/test_ins_complete.vim19
-rw-r--r--src/version.c2
3 files changed, 24 insertions, 0 deletions
diff --git a/src/edit.c b/src/edit.c
index 53e86ff18f..f30edd5c79 100644
--- a/src/edit.c
+++ b/src/edit.c
@@ -1293,6 +1293,9 @@ docomplete:
disable_fold_update--;
#endif
compl_busy = FALSE;
+#ifdef FEAT_SMARTINDENT
+ can_si = TRUE; // allow smartindenting
+#endif
break;
case Ctrl_Y: // copy from previous line or scroll down
diff --git a/src/testdir/test_ins_complete.vim b/src/testdir/test_ins_complete.vim
index 3712abe690..75ec03cb37 100644
--- a/src/testdir/test_ins_complete.vim
+++ b/src/testdir/test_ins_complete.vim
@@ -2132,4 +2132,23 @@ func Test_thesaurusfunc_callback()
%bw!
endfunc
+func FooBarComplete(findstart, base)
+ if a:findstart
+ return col('.') - 1
+ else
+ return ["Foo", "Bar", "}"]
+ endif
+endfunc
+
+func Test_complete_smartindent()
+ new
+ setlocal smartindent completefunc=FooBarComplete
+
+ exe "norm! o{\<cr>\<c-x>\<c-u>\<c-p>}\<cr>\<esc>"
+ let result = getline(1,'$')
+ call assert_equal(['', '{','}',''], result)
+ bw!
+ delfunction! FooBarComplete
+endfunc
+
" vim: shiftwidth=2 sts=2 expandtab
diff --git a/src/version.c b/src/version.c
index 7eec582d98..956100304b 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 */
/**/
+ 4710,
+/**/
4709,
/**/
4708,