Mercurial > vim
diff src/misc1.c @ 15127:31a0127813cb v8.1.0574
patch 8.1.0574: 'commentstring' not used when adding fold marker in C
commit https://github.com/vim/vim/commit/4af7259b2b35e85c590d54908fcd248d2c733be8
Author: Bram Moolenaar <Bram@vim.org>
Date: Sun Dec 9 15:00:52 2018 +0100
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)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Sun, 09 Dec 2018 15:15:06 +0100 |
parents | 6e9f37bf987b |
children | 9df130fd5e0d |
line wrap: on
line diff
--- a/src/misc1.c +++ b/src/misc1.c @@ -1993,7 +1993,6 @@ get_last_leader_offset(char_u *line, cha 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, cha 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, cha && !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)