summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorMichael R Sweet <michael.r.sweet@gmail.com>2002-09-26 20:43:03 +0000
committerMichael R Sweet <michael.r.sweet@gmail.com>2002-09-26 20:43:03 +0000
commit7ef44a5266ca6c3da049faab68f196368804aeae (patch)
tree42bc25b160c84f858bd85443f2ee2e9ef46a4201 /test
parent0c0035904c10acb85a66fe17532dfa844120e72c (diff)
Fix editor syntax highlighting (bug #613089)
git-svn-id: file:///fltk/svn/fltk/branches/branch-1.1@2639 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
Diffstat (limited to 'test')
-rw-r--r--test/editor.cxx17
1 files changed, 13 insertions, 4 deletions
diff --git a/test/editor.cxx b/test/editor.cxx
index 3000980b2..c425fa809 100644
--- a/test/editor.cxx
+++ b/test/editor.cxx
@@ -1,5 +1,5 @@
//
-// "$Id: editor.cxx,v 1.2.2.3.2.14 2002/09/20 19:59:45 easysw Exp $"
+// "$Id: editor.cxx,v 1.2.2.3.2.15 2002/09/26 20:43:03 easysw Exp $"
//
// A simple text editor program for the Fast Light Tool Kit (FLTK).
//
@@ -173,6 +173,7 @@ style_parse(const char *text,
const char *temp;
for (current = *style, col = 0, last = 0; length > 0; length --, text ++) {
+ if (current == 'B') current = 'A';
if (current == 'A') {
// Check for directives, comments, strings, and keywords...
if (col == 0 && *text == '#') {
@@ -180,6 +181,9 @@ style_parse(const char *text,
current = 'E';
} else if (strncmp(text, "//", 2) == 0) {
current = 'B';
+ for (; length > 0 && *text != '\n'; length --, text ++) *style++ = 'B';
+
+ if (length == 0) break;
} else if (strncmp(text, "/*", 2) == 0) {
current = 'C';
} else if (strncmp(text, "\\\"", 2) == 0) {
@@ -319,7 +323,7 @@ style_update(int pos, // I - Position of update
int nInserted, // I - Number of inserted chars
int nDeleted, // I - Number of deleted chars
int /*nRestyled*/, // I - Number of restyled chars
- const char * /*deletedText*/, // I - Text that was deleted
+ const char * /*deletedText*/,// I - Text that was deleted
void *cbArg) { // I - Callback data
int start, // Start of text
end; // End of text
@@ -358,13 +362,18 @@ style_update(int pos, // I - Position of update
// style character and keep updating if we have a multi-line
// comment character...
start = textbuf->line_start(pos);
- end = textbuf->line_end(pos + nInserted - nDeleted);
+ end = textbuf->line_end(pos + nInserted);
text = textbuf->text_range(start, end);
style = stylebuf->text_range(start, end);
last = style[end - start - 1];
+ printf("start = %d, end = %d, text = \"%s\", style = \"%s\"...\n",
+ start, end, text, style);
+
style_parse(text, style, end - start);
+ printf("new style = \"%s\"...\n", style);
+
stylebuf->replace(start, end, style);
((Fl_Text_Editor *)cbArg)->redisplay_range(start, end);
@@ -762,5 +771,5 @@ int main(int argc, char **argv) {
}
//
-// End of "$Id: editor.cxx,v 1.2.2.3.2.14 2002/09/20 19:59:45 easysw Exp $".
+// End of "$Id: editor.cxx,v 1.2.2.3.2.15 2002/09/26 20:43:03 easysw Exp $".
//