From 1dfe7a614cb1f76a00942dbe71cfda7206e42144 Mon Sep 17 00:00:00 2001 From: Jad Altahan Date: Sun, 13 Jan 2019 17:55:32 +1100 Subject: Backport: Feature [feature-requests:#1254]. Fix bug causing fold line creation in comments Backport of changeset 7230:8bfffdf3bbc0. --- lexers/LexNim.cxx | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) (limited to 'lexers/LexNim.cxx') diff --git a/lexers/LexNim.cxx b/lexers/LexNim.cxx index b61f33cc8..fae9e8d6e 100644 --- a/lexers/LexNim.cxx +++ b/lexers/LexNim.cxx @@ -99,10 +99,8 @@ int GetIndent(const Sci_Position line, Accessor &styler) { bool inPrevPrefix = line > 0; Sci_Position posPrev = inPrevPrefix ? styler.LineStart(line - 1) : 0; - // No fold points inside block comments and triple literals - while ((IsASpaceOrTab(ch) - || IsStreamComment(style) - || IsTripleLiteral(style)) && (startPos < eolPos)) { + // No fold points inside triple literals + while ((IsASpaceOrTab(ch) || IsTripleLiteral(style)) && (startPos < eolPos)) { if (inPrevPrefix) { char chPrev = styler[posPrev++]; if (chPrev != ' ' && chPrev != '\t') { @@ -121,11 +119,14 @@ int GetIndent(const Sci_Position line, Accessor &styler) { style = styler.StyleAt(startPos); } - indent += SC_FOLDLEVELBASE; + // Prevent creating fold lines for comments if indented + if (!(IsStreamComment(style) || IsLineComment(style))) + indent += SC_FOLDLEVELBASE; if (styler.LineStart(line) == styler.Length() || IsASpaceOrTab(ch) || IsNewline(ch) + || IsStreamComment(style) || IsLineComment(style)) { return indent | SC_FOLDLEVELWHITEFLAG; } else { -- cgit v1.2.3