X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/f95d2598051e347460e028286ff2d33e5825e548..1e8d80477a3e058a30c477955f1e0c56deb6e956:/Highlight.cpp diff --git a/Highlight.cpp b/Highlight.cpp index c056315..a2926d3 100644 --- a/Highlight.cpp +++ b/Highlight.cpp @@ -1,5 +1,5 @@ -/* Cycript - Optimizing JavaScript Compiler/Runtime - * Copyright (C) 2009-2014 Jay Freeman (saurik) +/* Cycript - The Truly Universal Scripting Language + * Copyright (C) 2009-2016 Jay Freeman (saurik) */ /* GNU Affero General Public License, Version 3 {{{ */ @@ -19,14 +19,13 @@ **/ /* }}} */ +#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, cy::position ¤t, cy::position target) { +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) { _assert(offset != size); char next(data[offset++]); @@ -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(); } } @@ -55,23 +54,23 @@ struct CYColor { } }; -void CYLexerHighlight(const char *data, size_t size, std::ostream &output, bool ignore) { +_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); - cy::position current; - - CYLocalPool pool; + CYPosition current; - YYSTYPE value; - cy::location location; + 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;