X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/d9c911529b1480684bb8b6280410f2d09c8525a1..972562bf68a236b4580b6074415cbf4e07b0a0c6:/Driver.cpp diff --git a/Driver.cpp b/Driver.cpp index e529cbc..83b9462 100644 --- a/Driver.cpp +++ b/Driver.cpp @@ -19,23 +19,32 @@ **/ /* }}} */ -#include "Cycript.tab.hh" #include "Driver.hpp" +#include "Syntax.hpp" -CYDriver::CYDriver(std::istream &data, const std::string &filename) : - state_(CYClear), +bool CYParser(CYPool &pool, bool debug); + +CYDriver::CYDriver(CYPool &pool, std::istream &data, const std::string &filename) : + pool_(pool), + newline_(false), + last_(false), + next_(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(); } @@ -43,36 +52,8 @@ CYDriver::~CYDriver() { ScannerDestroy(); } -bool CYDriver::Parse(CYPool &pool) { - CYLocal local(&pool); - cy::parser parser(*this); -#ifdef YYDEBUG - parser.set_debug_level(debug_); -#endif - return parser.parse() != 0; -} - -void CYDriver::Replace(CYPool &pool, CYOptions &options) { - CYLocal local(&pool); +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); }