1
0
mirror of https://github.com/chylex/IntelliJ-IdeaVim.git synced 2025-05-19 12:34:02 +02:00
IntelliJ-IdeaVim/src/gnu/regexp/util/RETest.java
2003-04-22 23:49:47 +00:00

150 lines
5.2 KiB
Java

/*
* gnu/regexp/util/RETest.java
* Copyright (C) 1998-2001 Wes Biggs
*
* This file is in the public domain. However, the gnu.regexp library
* proper is licensed under the terms of the GNU Lesser General Public
* License (see the file COPYING.LIB for details).
*/
package gnu.regexp.util;
import gnu.regexp.*;
/**
* RETest provides a simple way to test regular expressions.
* It runs from the command line using the Java interpreter.
* To use it, enter the following from a command prompt (provided
* that the Java system knows where to find the RETest bytecodes):
* <BR><CODE>java gnu.regexp.util.RETest [regExp] [inputString]</CODE><BR>
* where <i>regExp</i> is a regular expression (you'll probably have
* to escape shell meta-characters) and <i>inputString</i> is the string
* to match against (again, put it in quotes or escape any shell meta-
* characters).
* <P>
* The test function will report the package version number, whether
* the expression matches the input string, what the match it found was,
* and the contents of any subexpressions, if applicable.
* <P>
* You may optionally add a third integer argument which is the number of
* times to repeat the test. When this option is used, RETest will report
* average compile and match times.
*
* @author <A HREF="mailto:wes@cacas.org">Wes Biggs</A>
* @version 1.01
*/
public class RETest
{
private RETest()
{
}
/**
* Invokes the test function with the command line arguments specified.
* See class description for usage notes.
*
* @param argv
* The command line arguments.
*
* @exception REException
* There was an error compiling or executing the regular expression.
*/
public static void main(String argv[]) throws REException
{
System.out.println("gnu.regexp version " + RE.version());
int numRepeats = 1;
if (argv.length == 3)
numRepeats = Integer.parseInt(argv[2]);
if (argv.length < 2)
{
System.out.println("usage: java gnu.regexp.util.RETest regExp inputString [numRepeats]");
System.exit(1);
}
// Construct the regular expression
RE expression = null;
long begin = System.currentTimeMillis();
for (int rpt = 0; rpt < numRepeats; rpt++)
expression = new RE(argv[0]);
long end = System.currentTimeMillis();
if (numRepeats > 1)
{
System.out.println("Compiling " + numRepeats + " times took " + (end - begin) + " ms");
System.out.println("Average compile time: " + ((end - begin) / numRepeats) + " ms");
}
// Display regular expression
System.out.println(" Input Text: " + argv[1]);
System.out.println("Regular Expression: " + argv[0]);
System.out.println(" Compiled Form: " + expression);
System.out.println(" Minimum Length: " + expression.getMinimumLength());
// Is the input in its entirety a match?
System.out.println(" isMatch() returns: " + expression.isMatch(argv[1]));
REMatch[] matches = expression.getAllMatches(argv[1]);
System.out.println(" getAllMatches(): " + matches.length + " matches");
for (int i = 0; i < matches.length; i++)
{
System.out.println("Match " + i + " (" + matches[i].getStartIndex()
+ "," + matches[i].getEndIndex() + "): "
+ matches[i]);
}
// Get the first match
REMatch match = null;
begin = System.currentTimeMillis();
for (int rpt = 0; rpt < numRepeats; rpt++)
match = expression.getMatch(argv[1]);
end = System.currentTimeMillis();
if (numRepeats > 1)
{
System.out.println("Finding first match " + numRepeats + " times took " + (end - begin) + " ms");
System.out.println("Average match time: " + ((end - begin) / numRepeats) + " ms");
}
if (match == null)
System.out.println("Expression did not find a match.");
else
{
// Report the full match indices
System.out.println("Match found from position "
+ match.getStartIndex() + " to position "
+ match.getEndIndex());
// Take advantage of REMatch.toString() to print match text
System.out.println("Match was: '" + match + "'");
// Report subexpression positions
for (int i = 1; i <= expression.getNumSubs(); i++)
{
if (match.getStartIndex(i) > -1)
{
System.out.println("Subexpression #" + i + ": from position "
+ match.getStartIndex(i) + " to position "
+ match.getEndIndex(i));
// Note how the $n is constructed for substituteInto
System.out.println(match.substituteInto("The subexpression matched this text: '$" + i + "'"));
}
}
}
// Here's a substitute test.
System.out.println("substitute(): " + expression.substitute(argv[1], "<!--$0-->"));
System.out.println("substituteAll(): " + expression.substituteAll(argv[1], "<!--$0-->"));
}
}