X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/2c1d569a0ed9ddd14d3d1d73ee8be776e0889d35..7e551bb166cb5e24d52a32938335cd18f9efb217:/Driver.cpp diff --git a/Driver.cpp b/Driver.cpp index 5f3ffa1..0bdd62d 100644 --- a/Driver.cpp +++ b/Driver.cpp @@ -1,5 +1,5 @@ -/* Cycript - Optimizing JavaScript Compiler/Runtime - * Copyright (C) 2009-2015 Jay Freeman (saurik) +/* Cycript - The Truly Universal Scripting Language + * Copyright (C) 2009-2016 Jay Freeman (saurik) */ /* GNU Affero General Public License, Version 3 {{{ */ @@ -19,24 +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), - state_(CYClear), + 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(); } @@ -44,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); }