forked from aniani/vim
patch 8.1.0574: 'commentstring' not used when adding fold marker in C
Problem: 'commentstring' not used when adding fold marker in C. Solution: Require white space before middle comment part. (mostly by Hirohito Higashi)
This commit is contained in:
13
src/misc1.c
13
src/misc1.c
@@ -1993,7 +1993,6 @@ get_last_leader_offset(char_u *line, char_u **flags)
|
|||||||
for (list = curbuf->b_p_com; *list; )
|
for (list = curbuf->b_p_com; *list; )
|
||||||
{
|
{
|
||||||
char_u *flags_save = list;
|
char_u *flags_save = list;
|
||||||
int is_only_whitespace = FALSE;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Get one option part into part_buf[]. Advance list to next one.
|
* 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;
|
continue;
|
||||||
while (VIM_ISWHITE(*string))
|
while (VIM_ISWHITE(*string))
|
||||||
++string;
|
++string;
|
||||||
if (*string == NUL)
|
|
||||||
is_only_whitespace = TRUE;
|
|
||||||
}
|
}
|
||||||
for (j = 0; string[j] != NUL && string[j] == line[i + j]; ++j)
|
for (j = 0; string[j] != NUL && string[j] == line[i + j]; ++j)
|
||||||
/* do nothing */;
|
/* 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)
|
&& !VIM_ISWHITE(line[i + j]) && line[i + j] != NUL)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
// For a middlepart comment that is only white space, only consider
|
if (vim_strchr(part_buf, COM_MIDDLE) != NULL)
|
||||||
// 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)
|
|
||||||
{
|
{
|
||||||
|
// 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++)
|
for (j = 0; VIM_ISWHITE(line[j]) && j <= i; j++)
|
||||||
;
|
;
|
||||||
if (j < i)
|
if (j < i)
|
||||||
|
@@ -507,6 +507,35 @@ func Test_fold_marker()
|
|||||||
enew!
|
enew!
|
||||||
endfunc
|
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
|
" test folding with indent
|
||||||
func Test_fold_indent()
|
func Test_fold_indent()
|
||||||
enew!
|
enew!
|
||||||
|
@@ -792,6 +792,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
574,
|
||||||
/**/
|
/**/
|
||||||
573,
|
573,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user