From 001c26cd6194fba2bfccb06dec30fdc9e1410e62 Mon Sep 17 00:00:00 2001 From: glepnir Date: Sun, 2 Feb 2025 09:36:22 +0100 Subject: [PATCH] patch 9.1.1069: preinsert text completions not deleted with / Problem: preinsert text completions not deleted with / (ddad431, after v9.1.1059) Solution: handle or specifically and clear the completion (glepnir) fixes: #16557 closes: #16565 Signed-off-by: glepnir Signed-off-by: Christian Brabandt --- src/insexpand.c | 3 +++ src/testdir/test_ins_complete.vim | 8 ++++++++ src/version.c | 2 ++ 3 files changed, 13 insertions(+) diff --git a/src/insexpand.c b/src/insexpand.c index df757ce9b8..856c06d593 100644 --- a/src/insexpand.c +++ b/src/insexpand.c @@ -2498,6 +2498,9 @@ ins_compl_stop(int c, int prev_mode, int retval) retval = TRUE; } + if ((c == Ctrl_W || c == Ctrl_U) && ins_compl_preinsert_effect()) + ins_compl_delete(); + auto_format(FALSE, TRUE); // Trigger the CompleteDonePre event to give scripts a chance to diff --git a/src/testdir/test_ins_complete.vim b/src/testdir/test_ins_complete.vim index 49e44653a2..5d24d51d6a 100644 --- a/src/testdir/test_ins_complete.vim +++ b/src/testdir/test_ins_complete.vim @@ -3103,6 +3103,14 @@ function Test_completeopt_preinsert() call assert_equal("fo ", getline('.')) call assert_equal(3, col('.')) + call feedkeys("She\\\", 'tx') + call assert_equal("", getline('.')) + call assert_equal(1, col('.')) + + call feedkeys("She\\\", 'tx') + call assert_equal("", getline('.')) + call assert_equal(1, col('.')) + " whole line call feedkeys("Shello hero\\\", 'tx') call assert_equal("hello hero", getline('.')) diff --git a/src/version.c b/src/version.c index 7137c675bb..f9d99a5dc3 100644 --- a/src/version.c +++ b/src/version.c @@ -704,6 +704,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 1069, /**/ 1068, /**/