]> git.saurik.com Git - cycript.git/blobdiff - Driver.cpp
Avoid crashing when the user types a mismatched }.
[cycript.git] / Driver.cpp
index 387a46d679fe24b600b43b7b041264f6ec082fa7..df31a036935f95f033f1617fa5c83f948854a3fb 100644 (file)
 **/
 /* }}} */
 
 **/
 /* }}} */
 
-#include "Cycript.tab.hh"
 #include "Driver.hpp"
 #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),
     newline_(false),
     last_(false),
 
 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),
     data_(data),
     debug_(0),
     strict_(false),
@@ -36,9 +39,11 @@ CYDriver::CYDriver(CYPool &pool, std::istream &data, const std::string &filename
     context_(NULL),
     mode_(AutoNone)
 {
     context_(NULL),
     mode_(AutoNone)
 {
-    memset(&no_, 0, sizeof(no_));
     in_.push(false);
     in_.push(false);
+    return_.push(false);
     template_.push(false);
     template_.push(false);
+    yield_.push(false);
+
     ScannerInit();
 }
 
     ScannerInit();
 }
 
@@ -46,36 +51,8 @@ CYDriver::~CYDriver() {
     ScannerDestroy();
 }
 
     ScannerDestroy();
 }
 
-bool CYDriver::Parse() {
-    CYLocal<CYPool> local(&pool_);
-    cy::parser parser(*this);
-#ifdef YYDEBUG
-    parser.set_debug_level(debug_);
-#endif
-    return parser.parse() != 0;
-}
-
 void CYDriver::Replace(CYOptions &options) {
     CYLocal<CYPool> local(&pool_);
     CYContext context(options);
     script_->Replace(context);
 }
 void CYDriver::Replace(CYOptions &options) {
     CYLocal<CYPool> 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);
-}