RE.java (initialize): Add RETokenLookAhead support.
authorShashank Bapat <shashankbapat@yahoo.com>
Sat, 25 Sep 2004 19:04:34 +0000 (19:04 +0000)
committerMark Wielaard <mark@gcc.gnu.org>
Sat, 25 Sep 2004 19:04:34 +0000 (19:04 +0000)
2004-09-25  Shashank Bapat  <shashankbapat@yahoo.com>
            Mark Wielaard  <mark@klomp.org>

       * gnu/regexp/RE.java (initialize): Add RETokenLookAhead support.
       * gnu/regexp/RETokenLookAhead.java: New file.

       * Makefile.am (ordinary_java_source_files): Add RETokenLookAhead.java.
       * Makefile.in: Regenerated.

Co-Authored-By: Mark Wielaard <mark@klomp.org>
From-SVN: r88106

libjava/ChangeLog
libjava/Makefile.am
libjava/Makefile.in
libjava/gnu/regexp/RE.java
libjava/gnu/regexp/RETokenLookAhead.java [new file with mode: 0644]

index 7c925bcac3f794912429d39d10df7862e5b4d7fa..64ac4ce8a02c7465dcf4ad08e16c33d2b8dcb16a 100644 (file)
@@ -1,3 +1,12 @@
+2004-09-25  Shashank Bapat  <shashankbapat@yahoo.com>
+            Mark Wielaard  <mark@klomp.org>
+
+       * gnu/regexp/RE.java (initialize): Add RETokenLookAhead support.
+       * gnu/regexp/RETokenLookAhead.java: New file.
+
+       * Makefile.am (ordinary_java_source_files): Add RETokenLookAhead.java.
+       * Makefile.in: Regenerated.
+
 2004-09-25  Michael Koch  <konqueror@gmx.de>
 
        * java/io/ObjectStreamField.java:
index 4b127042324e446bf77d944208f094c9f5754ddb..b126ab2c2560c9564866f811bb0693f4949796b2 100644 (file)
@@ -2692,6 +2692,7 @@ gnu/regexp/RETokenBackRef.java \
 gnu/regexp/RETokenChar.java \
 gnu/regexp/RETokenEnd.java \
 gnu/regexp/RETokenEndSub.java \
+gnu/regexp/RETokenLookAhead.java \
 gnu/regexp/RETokenOneOf.java \
 gnu/regexp/RETokenPOSIX.java \
 gnu/regexp/RETokenRange.java \
index a65ca2587a83db78831979ebc87ce5c662832881..083bf097ce2f87f04215feec2b7e84d0a9dfab23 100644 (file)
@@ -802,9 +802,9 @@ am__libgcj_la_SOURCES_DIST = prims.cc jni.cc exception.cc resolve.cc \
        gnu/regexp/REToken.java gnu/regexp/RETokenAny.java \
        gnu/regexp/RETokenBackRef.java gnu/regexp/RETokenChar.java \
        gnu/regexp/RETokenEnd.java gnu/regexp/RETokenEndSub.java \
-       gnu/regexp/RETokenOneOf.java gnu/regexp/RETokenPOSIX.java \
-       gnu/regexp/RETokenRange.java gnu/regexp/RETokenRepeated.java \
-       gnu/regexp/RETokenStart.java \
+       gnu/regexp/RETokenLookAhead.java gnu/regexp/RETokenOneOf.java \
+       gnu/regexp/RETokenPOSIX.java gnu/regexp/RETokenRange.java \
+       gnu/regexp/RETokenRepeated.java gnu/regexp/RETokenStart.java \
        gnu/regexp/RETokenWordBoundary.java \
        gnu/regexp/UncheckedRE.java gnu/java/security/Engine.java \
        gnu/java/security/OID.java \
@@ -3699,12 +3699,12 @@ am__objects_14 = $(am__objects_9) gnu/classpath/ServiceFactory.lo \
        gnu/regexp/RESyntax.lo gnu/regexp/REToken.lo \
        gnu/regexp/RETokenAny.lo gnu/regexp/RETokenBackRef.lo \
        gnu/regexp/RETokenChar.lo gnu/regexp/RETokenEnd.lo \
-       gnu/regexp/RETokenEndSub.lo gnu/regexp/RETokenOneOf.lo \
-       gnu/regexp/RETokenPOSIX.lo gnu/regexp/RETokenRange.lo \
-       gnu/regexp/RETokenRepeated.lo gnu/regexp/RETokenStart.lo \
-       gnu/regexp/RETokenWordBoundary.lo gnu/regexp/UncheckedRE.lo \
-       gnu/java/security/Engine.lo gnu/java/security/OID.lo \
-       gnu/java/security/der/BitString.lo \
+       gnu/regexp/RETokenEndSub.lo gnu/regexp/RETokenLookAhead.lo \
+       gnu/regexp/RETokenOneOf.lo gnu/regexp/RETokenPOSIX.lo \
+       gnu/regexp/RETokenRange.lo gnu/regexp/RETokenRepeated.lo \
+       gnu/regexp/RETokenStart.lo gnu/regexp/RETokenWordBoundary.lo \
+       gnu/regexp/UncheckedRE.lo gnu/java/security/Engine.lo \
+       gnu/java/security/OID.lo gnu/java/security/der/BitString.lo \
        gnu/java/security/der/DER.lo \
        gnu/java/security/der/DEREncodingException.lo \
        gnu/java/security/der/DERReader.lo \
@@ -6497,6 +6497,7 @@ gnu/regexp/RETokenBackRef.java \
 gnu/regexp/RETokenChar.java \
 gnu/regexp/RETokenEnd.java \
 gnu/regexp/RETokenEndSub.java \
+gnu/regexp/RETokenLookAhead.java \
 gnu/regexp/RETokenOneOf.java \
 gnu/regexp/RETokenPOSIX.java \
 gnu/regexp/RETokenRange.java \
@@ -9310,6 +9311,8 @@ gnu/regexp/RETokenEnd.lo: gnu/regexp/$(am__dirstamp) \
        gnu/regexp/$(DEPDIR)/$(am__dirstamp)
 gnu/regexp/RETokenEndSub.lo: gnu/regexp/$(am__dirstamp) \
        gnu/regexp/$(DEPDIR)/$(am__dirstamp)
+gnu/regexp/RETokenLookAhead.lo: gnu/regexp/$(am__dirstamp) \
+       gnu/regexp/$(DEPDIR)/$(am__dirstamp)
 gnu/regexp/RETokenOneOf.lo: gnu/regexp/$(am__dirstamp) \
        gnu/regexp/$(DEPDIR)/$(am__dirstamp)
 gnu/regexp/RETokenPOSIX.lo: gnu/regexp/$(am__dirstamp) \
@@ -15000,6 +15003,8 @@ mostlyclean-compile:
        -rm -f gnu/regexp/RETokenEnd.lo
        -rm -f gnu/regexp/RETokenEndSub.$(OBJEXT)
        -rm -f gnu/regexp/RETokenEndSub.lo
+       -rm -f gnu/regexp/RETokenLookAhead.$(OBJEXT)
+       -rm -f gnu/regexp/RETokenLookAhead.lo
        -rm -f gnu/regexp/RETokenOneOf.$(OBJEXT)
        -rm -f gnu/regexp/RETokenOneOf.lo
        -rm -f gnu/regexp/RETokenPOSIX.$(OBJEXT)
@@ -19465,6 +19470,7 @@ distclean-compile:
 @AMDEP_TRUE@@am__include@ @am__quote@gnu/regexp/$(DEPDIR)/RETokenChar.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@gnu/regexp/$(DEPDIR)/RETokenEnd.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@gnu/regexp/$(DEPDIR)/RETokenEndSub.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@gnu/regexp/$(DEPDIR)/RETokenLookAhead.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@gnu/regexp/$(DEPDIR)/RETokenOneOf.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@gnu/regexp/$(DEPDIR)/RETokenPOSIX.Plo@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@gnu/regexp/$(DEPDIR)/RETokenRange.Plo@am__quote@
index fdc00feb3fb638f6a949a7cba10e675ddb392c15..d782975e9aff5223138ab2c424ce040ebeab8d2d 100644 (file)
@@ -492,8 +492,25 @@ public class RE extends REToken {
       else if ((unit.ch == '(') && (syntax.get(RESyntax.RE_NO_BK_PARENS) ^ unit.bk)) {
        boolean pure = false;
        boolean comment = false;
+        boolean lookAhead = false;
+        boolean negativelh = false;
        if ((index+1 < pLength) && (pattern[index] == '?')) {
          switch (pattern[index+1]) {
+          case '!':
+            if (syntax.get(RESyntax.RE_LOOKAHEAD)) {
+              pure = true;
+              negativelh = true;
+              lookAhead = true;
+              index += 2;
+            }
+            break;
+          case '=':
+            if (syntax.get(RESyntax.RE_LOOKAHEAD)) {
+              pure = true;
+              lookAhead = true;
+              index += 2;
+            }
+            break;
          case ':':
            if (syntax.get(RESyntax.RE_PURE_GROUPING)) {
              pure = true;
@@ -539,10 +556,14 @@ public class RE extends REToken {
            numSubs++;
          }
 
-         int useIndex = (pure) ? 0 : nextSub + numSubs;
+         int useIndex = (pure || lookAhead) ? 0 : nextSub + numSubs;
          currentToken = new RE(String.valueOf(pattern,index,endIndex-index).toCharArray(),cflags,syntax,useIndex,nextSub + numSubs);
          numSubs += ((RE) currentToken).getNumSubs();
 
+          if (lookAhead) {
+             currentToken = new RETokenLookAhead(currentToken,negativelh);
+         }
+
          index = nextIndex;
        } // not a comment
       } // subexpression
diff --git a/libjava/gnu/regexp/RETokenLookAhead.java b/libjava/gnu/regexp/RETokenLookAhead.java
new file mode 100644 (file)
index 0000000..650bb35
--- /dev/null
@@ -0,0 +1,87 @@
+/* gnu/regexp/RETokenLookAhead.java
+   Copyright (C) 1998-2001, 2004 Free Software Foundation, Inc.
+
+This file is part of GNU Classpath.
+
+GNU Classpath is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2, or (at your option)
+any later version.
+
+GNU Classpath is distributed in the hope that it will be useful, but
+WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with GNU Classpath; see the file COPYING.  If not, write to the
+Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+02111-1307 USA.
+
+Linking this library statically or dynamically with other modules is
+making a combined work based on this library.  Thus, the terms and
+conditions of the GNU General Public License cover the whole
+combination.
+
+As a special exception, the copyright holders of this library give you
+permission to link this library with independent modules to produce an
+executable, regardless of the license terms of these independent
+modules, and to copy and distribute the resulting executable under
+terms of your choice, provided that you also meet, for each linked
+independent module, the terms and conditions of the license of that
+module.  An independent module is a module which is not derived from
+or based on this library.  If you modify this library, you may extend
+this exception to your version of the library, but you are not
+obligated to do so.  If you do not wish to do so, delete this
+exception statement from your version. */
+
+package gnu.regexp;
+
+/**
+ * @since gnu.regexp 1.1.3
+ * @author Shashank Bapat
+ */
+final class RETokenLookAhead extends REToken
+{
+  REToken re;
+  boolean negative;
+
+  RETokenLookAhead(REToken re, boolean negative) throws REException {
+    super(0);
+    this.re = re;
+    this.negative = negative;
+  }
+
+  boolean match(CharIndexed input, REMatch mymatch)
+  {
+    REMatch trymatch = (REMatch)mymatch.clone();
+    REMatch trymatch1 = (REMatch)mymatch.clone();
+    REMatch newMatch = null;
+    if (re.match(input, trymatch)) {
+      if (negative) return false;
+      if (next(input, trymatch1))
+        newMatch = trymatch1;
+    }
+
+    if (newMatch != null) {
+      if (negative) return false;
+      //else
+      mymatch.assignFrom(newMatch);
+      return true;
+    }
+    else { // no match
+      if (negative)
+        return next(input, mymatch);
+      //else
+      return false;
+    }
+  }
+
+    void dump(StringBuffer os) {
+       os.append("(?");
+       os.append(negative ? '!' : '=');
+       re.dumpAll(os);
+       os.append(')');
+    }
+}
+