aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorMark Reay <mark@reay.net.au>2020-01-04 22:37:08 +0000
committerMark Reay <mark@reay.net.au>2020-01-04 22:37:08 +0000
commit402399a62130099bd17e11f11cec180fd6bf8aa9 (patch)
tree0d7c486f121ff9092f21cad608ed4de42fdae664
parentc249a1ae20d17d00be42a31f602ece2e14139f40 (diff)
downloadscintilla-mirror-402399a62130099bd17e11f11cec180fd6bf8aa9.tar.gz
Backport: Feature [feature-requests:#1328] Handle CRLF in SCE_RAKU_COMMENTLINEs and
HEREDOCs style termination. Backport of changeset 7915:4bdfd413a442.
-rw-r--r--lexers/LexRaku.cxx9
-rw-r--r--lexilla/test/examples/raku/x.p6.styled8
2 files changed, 10 insertions, 7 deletions
diff --git a/lexers/LexRaku.cxx b/lexers/LexRaku.cxx
index a3038dfdd..967102afd 100644
--- a/lexers/LexRaku.cxx
+++ b/lexers/LexRaku.cxx
@@ -892,6 +892,7 @@ void LexerRaku::ProcessStringVars(StyleContext &sc, const Sci_Position length, c
bool LexerRaku::ProcessValidRegQlangStart(StyleContext &sc, Sci_Position length, const int type,
WordList &wordsAdverbs, DelimPair &dp) {
Sci_Position startPos = sc.currentPos;
+ Sci_Position startLen = length;
const int target_state = sc.state;
int state = SCE_RAKU_DEFAULT;
std::string str;
@@ -908,7 +909,7 @@ bool LexerRaku::ProcessValidRegQlangStart(StyleContext &sc, Sci_Position length,
if (!got_all_adverbs && was_space) {
sc.Forward(LengthToNextChar(sc, length));
}
- length -= sc.currentPos - startPos; // update length remaining
+ length = startLen - (sc.currentPos - startPos); // update length remaining
// parse / eat an identifier (if type == RAKUTYPE_REGEX)
if (dp.opener == 0 && !got_ident && type == RAKUTYPE_REGEX && IsAlphabet(sc.ch)) {
@@ -1067,7 +1068,7 @@ void SCI_METHOD LexerRaku::Lex(Sci_PositionU startPos, Sci_Position length, int
sc.SetState(SCE_RAKU_DEFAULT);
break; // FIXME: better valid operator sequences needed?
case SCE_RAKU_COMMENTLINE:
- if (sc.atLineEnd) {
+ if (IsANewLine(sc.ch)) {
sc.SetState(SCE_RAKU_DEFAULT);
}
break;
@@ -1424,7 +1425,9 @@ void SCI_METHOD LexerRaku::Lex(Sci_PositionU startPos, Sci_Position length, int
}
// --- Heredoc: begin ---------------------------------------------
- else if (sc.atLineEnd && !hereDelim.empty()) {
+ else if (!hereDelim.empty() && sc.atLineEnd) {
+ if (IsANewLine(sc.ch))
+ sc.Forward(); // skip a possible CRLF situation
sc.SetState(hereState);
}
diff --git a/lexilla/test/examples/raku/x.p6.styled b/lexilla/test/examples/raku/x.p6.styled
index 9bef97940..f23902104 100644
--- a/lexilla/test/examples/raku/x.p6.styled
+++ b/lexilla/test/examples/raku/x.p6.styled
@@ -21,14 +21,14 @@
POD Documentation...
=end pod{0}
-{20}say{0} {10}qq{15}:to{10}/END/{18};{7}
-A multi-line
+{20}say{0} {10}qq{15}:to{10}/END/{18};{0}
+{7}A multi-line
string with interpolated vars: {12}$i{7}, {12}$r{7}
END{0}
{20}sub{0} {21}function{0} {18}{{0}
- {20}return{0} {9}q{15}:to{9}/END/{18};{6}
-Here is
+ {20}return{0} {9}q{15}:to{9}/END/{18};{0}
+{6}Here is
some multi-line
string
END{0}