X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/a5662a5364816f852acb056d5c2b2fc94e0c0a5c..bf998c10baabbd95f2d59d29f9edea0eb107b156:/Driver.cpp diff --git a/Driver.cpp b/Driver.cpp index 274cbb9..031625c 100644 --- a/Driver.cpp +++ b/Driver.cpp @@ -19,25 +19,31 @@ **/ /* }}} */ -#include "Cycript.tab.hh" #include "Driver.hpp" +#include "Syntax.hpp" -CYDriver::CYDriver(CYPool &pool, std::istream &data, const std::string &filename) : +bool CYParser(CYPool &pool, bool debug); + +CYDriver::CYDriver(CYPool &pool, std::streambuf &data, const std::string &filename) : pool_(pool), newline_(false), last_(false), data_(data), debug_(0), strict_(false), - commented_(false), + highlight_(false), filename_(filename), - program_(NULL), + 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); - program_->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); + script_->Replace(context); }