]> git.saurik.com Git - cycript.git/blobdiff - Highlight.cpp
Correct even more bugs in no line terminator code.
[cycript.git] / Highlight.cpp
index 3e8aa7bff1ed90b4091c487d3956193be9bbef79..d668f78ff27d215fce9c6309493d7713e01428c5 100644 (file)
 **/
 /* }}} */
 
 **/
 /* }}} */
 
+#include "Code.hpp"
+#include "Driver.hpp"
 #include "Highlight.hpp"
 #include "Highlight.hpp"
-#include "Parser.hpp"
 
 
-#include "Cycript.tab.hh"
-#include "Driver.hpp"
-#include "Code.hpp"
+bool CYLexerHighlight(hi::Value &highlight, CYLocation &location, void *scanner);
 
 static void Skip(const char *data, size_t size, std::ostream &output, size_t &offset, CYPosition &current, CYPosition target) {
     while (current.line != target.line || current.column != target.column) {
 
 static void Skip(const char *data, size_t size, std::ostream &output, size_t &offset, CYPosition &current, CYPosition target) {
     while (current.line != target.line || current.column != target.column) {
@@ -35,9 +34,9 @@ static void Skip(const char *data, size_t size, std::ostream &output, size_t &of
 
         _assert(current.line < target.line || current.line == target.line && current.column < target.column);
         if (next == '\n')
 
         _assert(current.line < target.line || current.line == target.line && current.column < target.column);
         if (next == '\n')
-            current.lines();
+            current.Lines();
         else
         else
-            current.columns();
+            current.Columns();
     }
 }
 
     }
 }
 
@@ -60,18 +59,18 @@ _visible void CYLexerHighlight(const char *data, size_t size, std::ostream &outp
 
     CYStream stream(data, data + size);
     CYDriver driver(pool, stream);
 
     CYStream stream(data, data + size);
     CYDriver driver(pool, stream);
-    driver.commented_ = true;
+    driver.highlight_ = true;
 
     size_t offset(0);
     CYPosition current;
 
 
     size_t offset(0);
     CYPosition current;
 
-    YYSTYPE value;
+    hi::Value highlight;
     CYLocation location;
 
     CYLocation location;
 
-    while (cylex(&value, &location, driver.scanner_) != 0) {
+    while (CYLexerHighlight(highlight, location, driver.scanner_)) {
         CYColor color;
 
         CYColor color;
 
-        switch (value.highlight_) {
+        switch (highlight) {
             case hi::Comment: color = CYColor(true, 30); break;
             case hi::Constant: color = CYColor(false, 31); break;
             case hi::Control: color = CYColor(false, 33); break;
             case hi::Comment: color = CYColor(true, 30); break;
             case hi::Constant: color = CYColor(false, 31); break;
             case hi::Control: color = CYColor(false, 33); break;