summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2018-12-09 15:00:52 +0100
committerBram Moolenaar <Bram@vim.org>2018-12-09 15:00:52 +0100
commit4af7259b2b35e85c590d54908fcd248d2c733be8 (patch)
tree5df9467836d8ec86c789c519b639abbdf8c803c7
parent55d46913084745a48749d7ac4f48930852e1d87e (diff)
downloadvim-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.c13
-rw-r--r--src/testdir/test_fold.vim29
-rw-r--r--src/version.c2
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,