1  /*
     2   * Copyright the original author or authors.
     3   * 
     4   * Licensed under the MOZILLA PUBLIC LICENSE, Version 1.1 (the "License");
     5   * you may not use this file except in compliance with the License.
     6   * You may obtain a copy of the License at
     7   * 
     8   *      http://www.mozilla.org/MPL/MPL-1.1.html
     9   * 
    10   * Unless required by applicable law or agreed to in writing, software
    11   * distributed under the License is distributed on an "AS IS" BASIS,
    12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    13   * See the License for the specific language governing permissions and
    14   * limitations under the License.
    15   */
    16   
    17  import org.as2lib.regexp.node.Node; 
    18  
    19  /**
    20   * {@code NotBehind} is a zero-width negative lookbehind.
    21   * 
    22   * @author Igor Sadovskiy
    23   */
    24   
    25  class org.as2lib.regexp.node.NotBehind extends Node {
    26  	
    27      private var cond:Node;
    28      private var rmax, rmin:Number;
    29      
    30      public function NotBehind(cond:Node, rmax:Number, rmin:Number) {
    31          this.cond = cond;
    32          this.rmax = rmax;
    33          this.rmin = rmin;
    34      }
    35      
    36      public function match(matcher:Object, i:Number, seq:String):Boolean {
    37          var from:Number = Math.max(i - rmax, matcher.from);
    38          for (var j = i - rmin; j >= from; j--) {
    39              if (cond.match(matcher, j, seq) && matcher.last == i) {
    40                  return false;
    41              }
    42          }
    43          return next.match(matcher, i, seq);
    44      }
    45  }
    46  
    47