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: * Positive lookbehind node.
27: *
28: * @author Nikolay A. Kuznetsov
29: * @version $Revision: 1.4.2.2 $
30: */
31: class PositiveLookBehind extends AtomicJointSet {
32:
33: public PositiveLookBehind(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 leftBound = matchResult.hasTransparentBounds() ? 0
45: : matchResult.getLeftBound();
46:
47: int shift = next.matches(stringIndex, testString, matchResult);
48: if (shift >= 0) {
49: //fSet will take this index to check if we at the right bound
50: // and return true if the current index equal to this one
51: matchResult.setConsumed(groupIndex, stringIndex);
52: for (int i = 0; i < size; i++) {
53: AbstractSet e = (AbstractSet) children.get(i);
54: // find limits could be calculated though e.getCharCount()
55: // fSet will return true only if string index at fSet equal
56: // to stringIndex
57: if (e.findBack(leftBound, stringIndex, testString,
58: matchResult) >= 0) {
59: matchResult.setConsumed(groupIndex, -1);
60: return shift;
61: }
62: }
63: }
64:
65: return -1;
66: }
67:
68: public boolean hasConsumed(MatchResultImpl matchResult) {
69: return false;
70: }
71:
72: protected String getName() {
73: return "PosBehindJointSet"; //$NON-NLS-1$
74: }
75: }
|