diff options
author | Mark Wielaard <mark@gcc.gnu.org> | 2006-05-18 17:29:21 +0000 |
---|---|---|
committer | Mark Wielaard <mark@gcc.gnu.org> | 2006-05-18 17:29:21 +0000 |
commit | 4f9533c7722fa07511a94d005227961f4a4dec23 (patch) | |
tree | 9f9c470de62ee62fba1331a396450d728d2b1fad /libjava/classpath/gnu/regexp/REMatch.java | |
parent | eaec4980e139903ae9b274d1abcf3a13946603a8 (diff) | |
download | gcc-4f9533c7722fa07511a94d005227961f4a4dec23.zip gcc-4f9533c7722fa07511a94d005227961f4a4dec23.tar.gz gcc-4f9533c7722fa07511a94d005227961f4a4dec23.tar.bz2 |
Imported GNU Classpath 0.90
Imported GNU Classpath 0.90
* scripts/makemake.tcl: LocaleData.java moved to gnu/java/locale.
* sources.am: Regenerated.
* gcj/javaprims.h: Regenerated.
* Makefile.in: Regenerated.
* gcj/Makefile.in: Regenerated.
* include/Makefile.in: Regenerated.
* testsuite/Makefile.in: Regenerated.
* gnu/java/lang/VMInstrumentationImpl.java: New override.
* gnu/java/net/local/LocalSocketImpl.java: Likewise.
* gnu/classpath/jdwp/VMMethod.java: Likewise.
* gnu/classpath/jdwp/VMVirtualMachine.java: Update to latest
interface.
* java/lang/Thread.java: Add UncaughtExceptionHandler.
* java/lang/reflect/Method.java: Implements GenericDeclaration and
isSynthetic(),
* java/lang/reflect/Field.java: Likewise.
* java/lang/reflect/Constructor.java
* java/lang/Class.java: Implements Type, GenericDeclaration,
getSimpleName() and getEnclosing*() methods.
* java/lang/Class.h: Add new public methods.
* java/lang/Math.java: Add signum(), ulp() and log10().
* java/lang/natMath.cc (log10): New function.
* java/security/VMSecureRandom.java: New override.
* java/util/logging/Logger.java: Updated to latest classpath
version.
* java/util/logging/LogManager.java: New override.
From-SVN: r113887
Diffstat (limited to 'libjava/classpath/gnu/regexp/REMatch.java')
-rw-r--r-- | libjava/classpath/gnu/regexp/REMatch.java | 101 |
1 files changed, 53 insertions, 48 deletions
diff --git a/libjava/classpath/gnu/regexp/REMatch.java b/libjava/classpath/gnu/regexp/REMatch.java index 91a3c02..140a9c4 100644 --- a/libjava/classpath/gnu/regexp/REMatch.java +++ b/libjava/classpath/gnu/regexp/REMatch.java @@ -49,6 +49,7 @@ import java.io.Serializable; */ public final class REMatch implements Serializable, Cloneable { private String matchedText; + private CharIndexed matchedCharIndexed; // These variables are package scope for fast access within the engine int eflags; // execution flags this match was made using @@ -64,20 +65,28 @@ public final class REMatch implements Serializable, Cloneable { // Package scope; used by RE. int index; // used while matching to mark current match position in input + // start1[i] is set when the i-th subexp starts. And start1[i] is copied + // to start[i] when the i-th subexp ends. So start[i] keeps the previously + // assigned value while the i-th subexp is being processed. This makes + // backreference to the i-th subexp within the i-th subexp possible. int[] start; // start positions (relative to offset) for each (sub)exp. + int[] start1; // start positions (relative to offset) for each (sub)exp. int[] end; // end positions for the same - REMatch next; // other possibility (to avoid having to use arrays) + // start[i] == -1 or end[i] == -1 means that the start/end position is void. + // start[i] == p or end[i] == p where p < 0 and p != -1 means that + // the actual start/end position is (p+1). Start/end positions may + // become negative when the subexpression is in a RETokenLookBehind. boolean empty; // empty string matched. This flag is used only within // RETokenRepeated. - int matchFlags; // flags passed to match methods - static final int MF_FIND_ALL = 0x01; + + BacktrackStack backtrackStack; public Object clone() { try { REMatch copy = (REMatch) super.clone(); - copy.next = null; copy.start = (int[]) start.clone(); + copy.start1 = (int[]) start1.clone(); copy.end = (int[]) end.clone(); return copy; @@ -88,14 +97,15 @@ public final class REMatch implements Serializable, Cloneable { void assignFrom(REMatch other) { start = other.start; + start1 = other.start1; end = other.end; index = other.index; - // need to deep clone? - next = other.next; + backtrackStack = other.backtrackStack; } REMatch(int subs, int anchor, int eflags) { start = new int[subs+1]; + start1 = new int[subs+1]; end = new int[subs+1]; this.anchor = anchor; this.eflags = eflags; @@ -109,6 +119,7 @@ public final class REMatch implements Serializable, Cloneable { for (i = 0; i < end[0]; i++) sb.append(text.charAt(i)); matchedText = sb.toString(); + matchedCharIndexed = text; for (i = 0; i < start.length; i++) { // If any subexpressions didn't terminate, they don't count // TODO check if this code ever gets hit @@ -117,7 +128,7 @@ public final class REMatch implements Serializable, Cloneable { end[i] = -1; } } - next = null; // cut off alternates + backtrackStack = null; } /** Clears the current match and moves the offset to the new index. */ @@ -125,9 +136,9 @@ public final class REMatch implements Serializable, Cloneable { offset = index; this.index = 0; for (int i = 0; i < start.length; i++) { - start[i] = end[i] = -1; + start[i] = start1[i] = end[i] = -1; } - next = null; // cut off alternates + backtrackStack = null; } /** @@ -184,7 +195,19 @@ public final class REMatch implements Serializable, Cloneable { if ((sub >= start.length) || sub < 0) throw new IndexOutOfBoundsException("No group " + sub); if (start[sub] == -1) return null; - return (matchedText.substring(start[sub],end[sub])); + if (start[sub] >= 0 && end[sub] <= matchedText.length()) + return (matchedText.substring(start[sub],end[sub])); + else { + // This case occurs with RETokenLookAhead or RETokenLookBehind. + StringBuffer sb = new StringBuffer(); + int s = start[sub]; + int e = end[sub]; + if (s < 0) s += 1; + if (e < 0) e += 1; + for (int i = start[0] + s; i < start[0] + e; i++) + sb.append(matchedCharIndexed.charAt(i)); + return sb.toString(); + } } /** @@ -198,7 +221,8 @@ public final class REMatch implements Serializable, Cloneable { public int getSubStartIndex(int sub) { if (sub >= start.length) return -1; int x = start[sub]; - return (x == -1) ? x : offset + x; + return (x == -1) ? x : + (x >= 0) ? offset + x : offset + x + 1; } /** @@ -212,7 +236,8 @@ public final class REMatch implements Serializable, Cloneable { public int getStartIndex(int sub) { if (sub >= start.length) return -1; int x = start[sub]; - return (x == -1) ? x : offset + x; + return (x == -1) ? x : + (x >= 0) ? offset + x : offset + x + 1; } /** @@ -226,7 +251,8 @@ public final class REMatch implements Serializable, Cloneable { public int getSubEndIndex(int sub) { if (sub >= start.length) return -1; int x = end[sub]; - return (x == -1) ? x : offset + x; + return (x == -1) ? x : + (x >= 0) ? offset + x : offset + x + 1; } /** @@ -239,7 +265,8 @@ public final class REMatch implements Serializable, Cloneable { public int getEndIndex(int sub) { if (sub >= start.length) return -1; int x = end[sub]; - return (x == -1) ? x : offset + x; + return (x == -1) ? x : + (x >= 0) ? offset + x : offset + x + 1; } /** @@ -279,41 +306,19 @@ public final class REMatch implements Serializable, Cloneable { return output.toString(); } - static class REMatchList { - REMatch head; - REMatch tail; - REMatchList() { - head = tail = null; - } - /* Not used now. But we may need this some day? - void addHead(REMatch newone) { - if (head == null) { - head = newone; - tail = newone; - while (tail.next != null) { - tail = tail.next; - } - } - else { - REMatch tmp = newone; - while (tmp.next != null) tmp = tmp.next; - tmp.next = head; - head = newone; - } - } - */ - void addTail(REMatch newone) { - if (head == null) { - head = newone; - tail = newone; - } - else { - tail.next = newone; - } - while (tail.next != null) { - tail = tail.next; - } +/* The following are used for debugging purpose + static String d(REMatch m) { + if (m == null) return "null"; + else return "[" + m.index + "]"; + } + + String substringUptoIndex(CharIndexed input) { + StringBuffer sb = new StringBuffer(); + for (int i = 0; i < index; i++) { + sb.append(input.charAt(i)); } + return sb.toString(); } +*/ } |