gnu.regexp
Class REMatch

java.lang.Object
  |
  +--gnu.regexp.REMatch

public class REMatch
extends java.lang.Object

An instance of this class represents a match completed by a gnu.regexp matching function. It can be used to obtain relevant information about the location of a match or submatch.

Version:
1.0.3
Author:
Wes Biggs

Method Summary
 int getEndIndex()
          Returns the index within the input string where the match in its entirety ends.
 int getStartIndex()
          Returns the index within the input text where the match in its entirety began.
 int getSubEndIndex(int sub)
          Returns the index within the input string used to generate this match where subexpression number sub ends, or -1 if the subexpression does not exist.
 int getSubStartIndex(int sub)
          Returns the index within the input string used to generate this match where subexpression number sub begins, or -1 if the subexpression does not exist.
 java.lang.String substituteInto(java.lang.String input)
          Substitute the results of this match to create a new string.
 java.lang.String toString()
          Returns the string matching the pattern.
 java.lang.String toString(int sub)
          Returns the string matching the given subexpression.
 
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, wait, wait, wait
 

Method Detail

toString

public java.lang.String toString()
Returns the string matching the pattern. This makes it convenient to write code like the following:

REMatch myMatch = myExpression.getMatch(myString);
if (myMatch != null) System.out.println("Regexp found: "+myMatch);

Overrides:
toString in class java.lang.Object

getStartIndex

public int getStartIndex()
Returns the index within the input text where the match in its entirety began.

getEndIndex

public int getEndIndex()
Returns the index within the input string where the match in its entirety ends. The return value is the next position after the end of the string; therefore, a match created by the following call:

REMatch myMatch = myExpression.getMatch(myString);

can be viewed (given that myMatch is not null) by creating

String theMatch = myString.substring(myMatch.getStartIndex(), myMatch.getEndIndex());

But you can save yourself that work, since the toString() method (above) does exactly that for you.


toString

public java.lang.String toString(int sub)
Returns the string matching the given subexpression.
Parameters:
sub - Index of the subexpression.

getSubStartIndex

public int getSubStartIndex(int sub)
Returns the index within the input string used to generate this match where subexpression number sub begins, or -1 if the subexpression does not exist.
Parameters:
sub - Subexpression index

getSubEndIndex

public int getSubEndIndex(int sub)
Returns the index within the input string used to generate this match where subexpression number sub ends, or -1 if the subexpression does not exist.
Parameters:
sub - Subexpression index

substituteInto

public java.lang.String substituteInto(java.lang.String input)
Substitute the results of this match to create a new string. This is patterned after PERL, so the tokens to watch out for are $0 through $9. $0 matches the full substring matched; $n matches subexpression number n.
Parameters:
input - A string consisting of literals and $n tokens.