patch 8.2.3935: CTRL-U in Insert mode does not fix the indent
Problem: CTRL-U in Insert mode does not fix the indent.
Solution: Fix the indent when 'cindent' is set.
diff --git a/src/edit.c b/src/edit.c
index f4e9327..bccf319 100644
--- a/src/edit.c
+++ b/src/edit.c
@@ -3980,6 +3980,9 @@
int in_indent;
int oldState;
int cpc[MAX_MCO]; // composing characters
+#if defined(FEAT_LISP) || defined(FEAT_CINDENT)
+ int call_fix_indent = FALSE;
+#endif
/*
* can't delete anything in an empty file
@@ -4161,7 +4164,13 @@
save_col = curwin->w_cursor.col;
beginline(BL_WHITE);
if (curwin->w_cursor.col < save_col)
+ {
mincol = curwin->w_cursor.col;
+#if defined(FEAT_LISP) || defined(FEAT_CINDENT)
+ // should now fix the indent to match with the previous line
+ call_fix_indent = TRUE;
+#endif
+ }
curwin->w_cursor.col = save_col;
}
@@ -4333,6 +4342,12 @@
#endif
if (curwin->w_cursor.col <= 1)
did_ai = FALSE;
+
+#if defined(FEAT_LISP) || defined(FEAT_CINDENT)
+ if (call_fix_indent)
+ fix_indent();
+#endif
+
/*
* It's a little strange to put backspaces into the redo
* buffer, but it makes auto-indent a lot easier to deal
diff --git a/src/testdir/test_textformat.vim b/src/testdir/test_textformat.vim
index 1a7bb68..ccfd36f 100644
--- a/src/testdir/test_textformat.vim
+++ b/src/testdir/test_textformat.vim
@@ -238,7 +238,7 @@
END
call assert_equal(expected, getline(1, '$'))
- " Using "o" repeates the line comment, "O" does not.
+ " Using "o" repeats the line comment, "O" does not.
%del
let text =<< trim END
nop;
@@ -261,6 +261,21 @@
END
call assert_equal(expected, getline(1, '$'))
+ " Using CTRL-U after "o" fixes the indent
+ %del
+ let text =<< trim END
+ {
+ val = val; // This is a comment
+ END
+ call setline(1, text)
+ exe "normal! 2Go\<C-U>x\<Esc>"
+ let expected =<< trim END
+ {
+ val = val; // This is a comment
+ x
+ END
+ call assert_equal(expected, getline(1, '$'))
+
bwipe!
endfunc
diff --git a/src/version.c b/src/version.c
index e4b481b..6849bd9 100644
--- a/src/version.c
+++ b/src/version.c
@@ -750,6 +750,8 @@
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 3935,
+/**/
3934,
/**/
3933,