]> git.saurik.com Git - cycript.git/blobdiff - Driver.cpp
Use start conditions to parse regular expressions.
[cycript.git] / Driver.cpp
index 6501fbf14144142da38850134923f3fdbe738b09..4bac2c2a920f1092c16e07f179ed0e25da5556ff 100644 (file)
@@ -1,5 +1,5 @@
 /* Cycript - Optimizing JavaScript Compiler/Runtime
- * Copyright (C) 2009-2014  Jay Freeman (saurik)
+ * Copyright (C) 2009-2015  Jay Freeman (saurik)
 */
 
 /* GNU Affero General Public License, Version 3 {{{ */
 **/
 /* }}} */
 
-#include "Cycript.tab.hh"
 #include "Driver.hpp"
+#include "Parser.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);
+    template_.push(false);
+    yield_.push(false);
+
     ScannerInit();
 }
 
@@ -42,21 +51,8 @@ CYDriver::~CYDriver() {
     ScannerDestroy();
 }
 
-void CYDriver::Warning(const cy::location &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);
+void CYDriver::Replace(CYOptions &options) {
+    CYLocal<CYPool> local(&pool_);
+    CYContext context(options);
+    script_->Replace(context);
 }