diff options
author | zeertzjq <zeertzjq@outlook.com> | 2022-02-08 21:45:39 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-02-08 21:45:39 +0800 |
commit | 1a5e893cee699481e15d73948cc4e42a5b1c7eae (patch) | |
tree | 7ef48bb661f074258198f8e514976c56ec2daa09 | |
parent | 51b432a7d1aa2a76ccfbf7a50f19c53e1151609f (diff) | |
parent | 3c75e63bf68f6ee88d1eda31caf042ed132badd9 (diff) | |
download | rneovim-1a5e893cee699481e15d73948cc4e42a5b1c7eae.tar.gz rneovim-1a5e893cee699481e15d73948cc4e42a5b1c7eae.tar.bz2 rneovim-1a5e893cee699481e15d73948cc4e42a5b1c7eae.zip |
Merge pull request #17334 from zeertzjq/vim-8.2.4326
vim-patch:8.2.4326: "o" and "O" copying comment not sufficiently tested
-rw-r--r-- | src/nvim/change.c | 6 | ||||
-rw-r--r-- | src/nvim/testdir/test_textformat.vim | 28 |
2 files changed, 30 insertions, 4 deletions
diff --git a/src/nvim/change.c b/src/nvim/change.c index 54c4ba5319..6ac759d5e0 100644 --- a/src/nvim/change.c +++ b/src/nvim/change.c @@ -1201,10 +1201,10 @@ int open_line(int dir, int flags, int second_line_indent, bool *did_do_comment) // Find out if the current line starts with a comment leader. // This may then be inserted in front of the new line. end_comment_pending = NUL; - if (flags & OPENLINE_DO_COM && dir == FORWARD) { - // Check for a line comment after code. + if (flags & OPENLINE_DO_COM) { lead_len = get_leader_len(saved_line, &lead_flags, dir == BACKWARD, true); - if (lead_len == 0 && do_cindent) { + if (lead_len == 0 && do_cindent && dir == FORWARD) { + // Check for a line comment after code. comment_start = check_linecomment(saved_line); if (comment_start != MAXCOL) { lead_len = get_leader_len(saved_line + comment_start, diff --git a/src/nvim/testdir/test_textformat.vim b/src/nvim/testdir/test_textformat.vim index 052c32214d..783793984d 100644 --- a/src/nvim/testdir/test_textformat.vim +++ b/src/nvim/testdir/test_textformat.vim @@ -238,7 +238,33 @@ func Test_format_c_comment() END call assert_equal(expected, getline(1, '$')) - " Using "o" repeats the line comment, "O" does not. + " Using either "o" or "O" repeats a line comment occupying a whole line. + %del + let text =<< trim END + nop; + // This is a comment + val = val; + END + call setline(1, text) + normal 2Go + let expected =<< trim END + nop; + // This is a comment + // + val = val; + END + call assert_equal(expected, getline(1, '$')) + normal 2GO + let expected =<< trim END + nop; + // + // This is a comment + // + val = val; + END + call assert_equal(expected, getline(1, '$')) + + " Using "o" repeats a line comment after a statement, "O" does not. %del let text =<< trim END nop; |