Author: [EMAIL PROTECTED]
Date: Mon Nov 17 04:41:09 2008
New Revision: 771

Modified:
    branches/experimental/regexp2000/src/jsregexp.cc
    branches/experimental/regexp2000/src/jsregexp.h

Log:
Assertions now mark their following nodes with interest.


Modified: branches/experimental/regexp2000/src/jsregexp.cc
==============================================================================
--- branches/experimental/regexp2000/src/jsregexp.cc    (original)
+++ branches/experimental/regexp2000/src/jsregexp.cc    Mon Nov 17 04:41:09  
2008
@@ -1451,7 +1451,20 @@
  RegExpNode* RegExpAssertion::ToNode(RegExpCompiler* compiler,
                                      RegExpNode* on_success,
                                      RegExpNode* on_failure) {
-  // TODO(self): implement assertions.
+  switch (type()) {
+    case START_OF_LINE:
+      on_success->info()->follows_newline_interest = true;
+      break;
+    case START_OF_INPUT:
+      on_success->info()->follows_start_interest = true;
+      break;
+    case BOUNDARY: case NON_BOUNDARY:
+      on_success->info()->follows_word_interest = true;
+      break;
+    case END_OF_LINE: case END_OF_INPUT:
+      // This is wrong but has the effect of making the compiler abort.
+      on_success->info()->follows_start_interest = true;
+  }
    return on_success;
  }

@@ -1802,8 +1815,9 @@
  void Analysis::VisitAction(ActionNode* that) {
    RegExpNode* next = that->on_success();
    EnsureAnalyzed(next);
-  that->info()->propagate_line = next->info()->propagate_line;
+  that->info()->propagate_newline = next->info()->propagate_newline;
    that->info()->propagate_word = next->info()->propagate_word;
+  that->info()->propagate_start = next->info()->propagate_start;
  }


@@ -1812,8 +1826,9 @@
    for (int i = 0; i < that->alternatives()->length(); i++) {
      RegExpNode* node = that->alternatives()->at(i).node();
      EnsureAnalyzed(node);
-    info->propagate_line |= node->info()->propagate_line;
+    info->propagate_newline |= node->info()->propagate_newline;
      info->propagate_word |= node->info()->propagate_word;
+    info->propagate_start |= node->info()->propagate_start;
    }
    if (!that->table_calculated()) {
      DispatchTableConstructor cons(that->table());

Modified: branches/experimental/regexp2000/src/jsregexp.h
==============================================================================
--- branches/experimental/regexp2000/src/jsregexp.h     (original)
+++ branches/experimental/regexp2000/src/jsregexp.h     Mon Nov 17 04:41:09 2008
@@ -438,11 +438,19 @@
      : being_analyzed(false),
        been_analyzed(false),
        propagate_word(false),
-      propagate_line(false) { }
+      propagate_newline(false),
+      propagate_start(false),
+      follows_word_interest(false),
+      follows_newline_interest(false),
+      follows_start_interest(false) { }
    bool being_analyzed: 1;
    bool been_analyzed: 1;
    bool propagate_word: 1;
-  bool propagate_line: 1;
+  bool propagate_newline: 1;
+  bool propagate_start: 1;
+  bool follows_word_interest: 1;
+  bool follows_newline_interest: 1;
+  bool follows_start_interest: 1;
  };



--~--~---------~--~----~------------~-------~--~----~
v8-dev mailing list
[email protected]
http://groups.google.com/group/v8-dev
-~----------~----~----~----~------~----~------~--~---

Reply via email to