diff options
author | Bram Moolenaar <Bram@vim.org> | 2019-11-12 20:31:20 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2019-11-12 20:31:20 +0100 |
commit | cc184cfb09161b3bbc7d5d8859a18e812367d19c (patch) | |
tree | f4c2c860ec034a3466ca89968bd8d8f5b50d99e2 | |
parent | d002e411c60a231b7c136a84422b3d9bf7b8b4df (diff) | |
download | vim-git-cc184cfb09161b3bbc7d5d8859a18e812367d19c.tar.gz |
patch 8.1.2293: join adds trailing space when second line is emptyv8.1.2293
Problem: Join adds trailing space when second line is empty. (Brennan
Vincent)
Solution: Do not add a trailing space.
-rw-r--r-- | src/ops.c | 3 | ||||
-rw-r--r-- | src/testdir/test_join.vim | 21 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 25 insertions, 1 deletions
@@ -1999,7 +1999,8 @@ do_join( if (insert_space && t > 0) { curr = skipwhite(curr); - if (*curr != ')' && currsize != 0 && endcurr1 != TAB + if (*curr != NUL && *curr != ')' + && currsize != 0 && endcurr1 != TAB && (!has_format_option(FO_MBYTE_JOIN) || (mb_ptr2char(curr) < 0x100 && endcurr1 < 0x100)) && (!has_format_option(FO_MBYTE_JOIN2) diff --git a/src/testdir/test_join.vim b/src/testdir/test_join.vim index 78835b2cc..5801c2f12 100644 --- a/src/testdir/test_join.vim +++ b/src/testdir/test_join.vim @@ -9,6 +9,27 @@ func Test_join_with_count() call setline(1, ['one', 'two', 'three', 'four']) normal 10J call assert_equal('one two three four', getline(1)) + + call setline(1, ['one', '', 'two']) + normal J + call assert_equal('one', getline(1)) + + call setline(1, ['one', ' ', 'two']) + normal J + call assert_equal('one', getline(1)) + + call setline(1, ['one', '', '', 'two']) + normal JJ + call assert_equal('one', getline(1)) + + call setline(1, ['one', ' ', ' ', 'two']) + normal JJ + call assert_equal('one', getline(1)) + + call setline(1, ['one', '', '', 'two']) + normal 2J + call assert_equal('one', getline(1)) + quit! endfunc diff --git a/src/version.c b/src/version.c index 0e9b27be5..31133c53e 100644 --- a/src/version.c +++ b/src/version.c @@ -742,6 +742,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 2293, +/**/ 2292, /**/ 2291, |