diff options
author | Bram Moolenaar <Bram@vim.org> | 2018-12-09 15:00:52 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2018-12-09 15:00:52 +0100 |
commit | 4af7259b2b35e85c590d54908fcd248d2c733be8 (patch) | |
tree | 5df9467836d8ec86c789c519b639abbdf8c803c7 | |
parent | 55d46913084745a48749d7ac4f48930852e1d87e (diff) | |
download | vim-git-4af7259b2b35e85c590d54908fcd248d2c733be8.tar.gz |
patch 8.1.0574: 'commentstring' not used when adding fold marker in Cv8.1.0574
Problem: 'commentstring' not used when adding fold marker in C.
Solution: Require white space before middle comment part. (mostly by
Hirohito Higashi)
-rw-r--r-- | src/misc1.c | 13 | ||||
-rw-r--r-- | src/testdir/test_fold.vim | 29 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 37 insertions, 7 deletions
diff --git a/src/misc1.c b/src/misc1.c index d8e7e1acc..f1f007478 100644 --- a/src/misc1.c +++ b/src/misc1.c @@ -1993,7 +1993,6 @@ get_last_leader_offset(char_u *line, char_u **flags) for (list = curbuf->b_p_com; *list; ) { char_u *flags_save = list; - int is_only_whitespace = FALSE; /* * Get one option part into part_buf[]. Advance list to next one. @@ -2021,8 +2020,6 @@ get_last_leader_offset(char_u *line, char_u **flags) continue; while (VIM_ISWHITE(*string)) ++string; - if (*string == NUL) - is_only_whitespace = TRUE; } for (j = 0; string[j] != NUL && string[j] == line[i + j]; ++j) /* do nothing */; @@ -2037,11 +2034,13 @@ get_last_leader_offset(char_u *line, char_u **flags) && !VIM_ISWHITE(line[i + j]) && line[i + j] != NUL) continue; - // For a middlepart comment that is only white space, only consider - // it to match if everything before the current position in the - // line is also whitespace. - if (is_only_whitespace && vim_strchr(part_buf, COM_MIDDLE) != NULL) + if (vim_strchr(part_buf, COM_MIDDLE) != NULL) { + // For a middlepart comment, only consider it to match if + // everything before the current position in the line is + // whitespace. Otherwise we would think we are inside a + // comment if the middle part appears somewhere in the middle + // of the line. E.g. for C the "*" appears often. for (j = 0; VIM_ISWHITE(line[j]) && j <= i; j++) ; if (j < i) diff --git a/src/testdir/test_fold.vim b/src/testdir/test_fold.vim index f8664d46f..67e5a48fe 100644 --- a/src/testdir/test_fold.vim +++ b/src/testdir/test_fold.vim @@ -507,6 +507,35 @@ func Test_fold_marker() enew! endfunc +" test create fold markers with C filetype +func Test_fold_create_marker_in_C() + enew! + set fdm=marker fdl=9 + set filetype=c + + let content = [ + \ '/*', + \ ' * comment', + \ ' * ', + \ ' *', + \ ' */', + \ 'int f(int* p) {', + \ ' *p = 3;', + \ ' return 0;', + \ '}' + \] + for c in range(len(content) - 1) + bw! + call append(0, content) + call cursor(c + 1, 1) + norm! zfG + call assert_equal(content[c] . (c < 4 ? '{{{' : '/*{{{*/'), getline(c + 1)) + endfor + + set fdm& fdl& + enew! +endfunc + " test folding with indent func Test_fold_indent() enew! diff --git a/src/version.c b/src/version.c index 880a5101a..45d18587b 100644 --- a/src/version.c +++ b/src/version.c @@ -793,6 +793,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 574, +/**/ 573, /**/ 572, |