aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--doc/ScintillaHistory.html5
-rw-r--r--lexers/LexMatlab.cxx13
2 files changed, 18 insertions, 0 deletions
diff --git a/doc/ScintillaHistory.html b/doc/ScintillaHistory.html
index f84075717..ed8e947a2 100644
--- a/doc/ScintillaHistory.html
+++ b/doc/ScintillaHistory.html
@@ -553,6 +553,11 @@
'Ctrl+L|SCI_LINEDELETE|'.
</li>
<li>
+ The Matlab lexer treats 'end' as a number rather than a keyword when used as a index.
+ This also stops incorrect folding.
+ <a href="http://sourceforge.net/p/scintilla/bugs/1951/">Bug #1951</a>.
+ </li>
+ <li>
The Rust lexer recognizes 'usize' numeric literal suffixes.
<a href="http://sourceforge.net/p/scintilla/bugs/1919/">Bug #1919</a>.
</li>
diff --git a/lexers/LexMatlab.cxx b/lexers/LexMatlab.cxx
index 45f0b6926..a0e3ea937 100644
--- a/lexers/LexMatlab.cxx
+++ b/lexers/LexMatlab.cxx
@@ -100,6 +100,9 @@ static void ColouriseMatlabOctaveDoc(
// of a string
bool transpose = false;
+ // count of brackets as boolean for when end could be an operator not a keyword
+ int allow_end_op = 0;
+
// approximate position of first non space character in a line
int nonSpaceColumn = -1;
// approximate column position of the current character in a line
@@ -153,7 +156,11 @@ static void ColouriseMatlabOctaveDoc(
if (!isalnum(sc.ch) && sc.ch != '_') {
char s[100];
sc.GetCurrentLowered(s, sizeof(s));
+
if (keywords.InList(s)) {
+ if (strcmp ("end", s) == 0 && allow_end_op) {
+ sc.ChangeState(SCE_MATLAB_NUMBER);
+ }
sc.SetState(SCE_MATLAB_DEFAULT);
transpose = false;
} else {
@@ -253,6 +260,12 @@ static void ColouriseMatlabOctaveDoc(
} else if (isalpha(sc.ch)) {
sc.SetState(SCE_MATLAB_KEYWORD);
} else if (isoperator(static_cast<char>(sc.ch)) || sc.ch == '@' || sc.ch == '\\') {
+ if (sc.ch == '(' || sc.ch == '[' || sc.ch == '{') {
+ allow_end_op ++;
+ } else if ((sc.ch == ')' || sc.ch == ']' || sc.ch == '}') && (allow_end_op > 0)) {
+ allow_end_op --;
+ }
+
if (sc.ch == ')' || sc.ch == ']' || sc.ch == '}') {
transpose = true;
} else {