X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/a7d8b4130acfb550e437d8cf1f6d3d81cb0cf6ee..57efef5ffbec97896a112ca5439cde154e025ff4:/Driver.cpp diff --git a/Driver.cpp b/Driver.cpp index b944022..788afee 100644 --- a/Driver.cpp +++ b/Driver.cpp @@ -19,8 +19,10 @@ **/ /* }}} */ -#include "Cycript.tab.hh" #include "Driver.hpp" +#include "Syntax.hpp" + +bool CYParser(CYPool &pool, bool debug); CYDriver::CYDriver(CYPool &pool, std::istream &data, const std::string &filename) : pool_(pool), @@ -29,15 +31,19 @@ CYDriver::CYDriver(CYPool &pool, std::istream &data, const std::string &filename data_(data), debug_(0), strict_(false), - commented_(false), + highlight_(false), filename_(filename), script_(NULL), auto_(false), context_(NULL), mode_(AutoNone) { - memset(&no_, 0, sizeof(no_)); in_.push(false); + return_.push(false); + super_.push(false); + template_.push(false); + yield_.push(false); + ScannerInit(); } @@ -45,36 +51,8 @@ CYDriver::~CYDriver() { ScannerDestroy(); } -bool CYDriver::Parse() { - CYLocal local(&pool_); - cy::parser parser(*this); -#ifdef YYDEBUG - parser.set_debug_level(debug_); -#endif - return parser.parse() != 0; -} - void CYDriver::Replace(CYOptions &options) { CYLocal local(&pool_); CYContext context(options); script_->Replace(context); } - -void CYDriver::Warning(const cy::parser::location_type &location, const char *message) { - if (!strict_) - return; - - CYDriver::Error error; - error.warning_ = true; - error.location_ = location; - error.message_ = message; - errors_.push_back(error); -} - -void cy::parser::error(const cy::parser::location_type &location, const std::string &message) { - CYDriver::Error error; - error.warning_ = false; - error.location_ = location; - error.message_ = message; - driver.errors_.push_back(error); -}