X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/d9c911529b1480684bb8b6280410f2d09c8525a1..a61a2713e0da8cffde645b2655df4bf7c04e32c5:/Highlight.cpp?ds=sidebyside diff --git a/Highlight.cpp b/Highlight.cpp index 73814ec..d668f78 100644 --- a/Highlight.cpp +++ b/Highlight.cpp @@ -19,12 +19,11 @@ **/ /* }}} */ +#include "Code.hpp" +#include "Driver.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 ¤t, 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') - current.lines(); + current.Lines(); else - current.columns(); + current.Columns(); } } @@ -56,22 +55,22 @@ struct CYColor { }; _visible void CYLexerHighlight(const char *data, size_t size, std::ostream &output, bool ignore) { + CYLocalPool pool; + CYStream stream(data, data + size); - CYDriver driver(stream); - driver.commented_ = true; + CYDriver driver(pool, stream); + driver.highlight_ = true; size_t offset(0); CYPosition current; - CYLocalPool pool; - - YYSTYPE value; + hi::Value highlight; CYLocation location; - while (cylex(&value, &location, driver.scanner_) != 0) { + while (CYLexerHighlight(highlight, location, driver.scanner_)) { 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;