01: /*
02: * Licensed to the Apache Software Foundation (ASF) under one or more
03: * contributor license agreements. See the NOTICE file distributed with
04: * this work for additional information regarding copyright ownership.
05: * The ASF licenses this file to You under the Apache License, Version 2.0
06: * (the "License"); you may not use this file except in compliance with
07: * the License. You may obtain a copy of the License at
08: *
09: * http://www.apache.org/licenses/LICENSE-2.0
10: *
11: * Unless required by applicable law or agreed to in writing, software
12: * distributed under the License is distributed on an "AS IS" BASIS,
13: * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14: * See the License for the specific language governing permissions and
15: * limitations under the License.
16: */
17:
18: /**
19: * @author Nikolay A. Kuznetsov
20: * @version $Revision: 1.4.2.2 $
21: */package java.util.regex;
22:
23: import java.util.ArrayList;
24:
25: /**
26: * Negative look behind node.
27: *
28: * @author Nikolay A. Kuznetsov
29: * @version $Revision: 1.4.2.2 $
30: */
31: class NegativeLookBehind extends AtomicJointSet {
32:
33: public NegativeLookBehind(ArrayList children, FSet fSet) {
34: super (children, fSet);
35: }
36:
37: /**
38: * Returns stringIndex+shift, the next position to match
39: */
40: public int matches(int stringIndex, CharSequence testString,
41: MatchResultImpl matchResult) {
42:
43: int size = children.size();
44: int shift;
45:
46: // fSet will take this index to check if we at the right bound
47: // and return true if the current index equal to this one
48: matchResult.setConsumed(groupIndex, stringIndex);
49:
50: for (int i = 0; i < size; i++) {
51: AbstractSet e = (AbstractSet) children.get(i);
52: // find limits could be calculated though e.getCharCount()
53: // fSet will return true only if string index at fSet equal
54: // to stringIndex
55: shift = e.findBack(0, stringIndex, testString, matchResult);
56: if (shift >= 0) {
57: return -1;
58: }
59: }
60:
61: return next.matches(stringIndex, testString, matchResult);
62: }
63:
64: public boolean hasConsumed(MatchResultImpl matchResult) {
65: return false;
66: }
67:
68: protected String getName() {
69: return "NegBehindJointSet"; //$NON-NLS-1$
70: }
71: }
|