jakarta-regexp is supported, at least an ORO implementation will follow. git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@268257 13f79535-47bb-0310-9956-ffa450edef68master
| @@ -44,7 +44,7 @@ mkdir %CLASSDIR% | |||
| echo. | |||
| echo ... Compiling Ant Classes | |||
| %JAVAC% -d %CLASSDIR% %TOOLS%\tar\*.java %TOOLS%\ant\*.java %TOOLS%\ant\types\*.java %TOOLS%\ant\taskdefs\*.java %TOOLS%\ant\util\*.java | |||
| %JAVAC% -d %CLASSDIR% %TOOLS%\tar\*.java %TOOLS%\ant\*.java %TOOLS%\ant\types\*.java %TOOLS%\ant\taskdefs\*.java %TOOLS%\ant\util\*.java %TOOLS%\ant\util\regexp\RegexpMatcher.java | |||
| echo. | |||
| echo ... Copying Required Files | |||
| @@ -51,6 +51,7 @@ echo ... Compiling Ant Classes | |||
| ${JAVAC} -d ${CLASSDIR} ${TOOLS}/tar/*.java | |||
| ${JAVAC} -d ${CLASSDIR} ${TOOLS}/ant/types/*.java | |||
| ${JAVAC} -d ${CLASSDIR} ${TOOLS}/ant/*.java | |||
| ${JAVAC} -d ${CLASSDIR} ${TOOLS}/ant/util/regexp/RegexpMatcher.java | |||
| ${JAVAC} -d ${CLASSDIR} ${TOOLS}/ant/util/*.java | |||
| ${JAVAC} -d ${CLASSDIR} ${TOOLS}/ant/taskdefs/*.java | |||
| @@ -74,6 +74,7 @@ | |||
| <available property="antlr.present" classname="antlr.Tool" /> | |||
| <available property="vaj.present" classname="com.ibm.ivj.util.base.Workspace" /> | |||
| <available property="stylebook.present" classname="org.apache.stylebook.Engine" /> | |||
| <available property="jakarta.regexp.present" classname="org.apache.regexp.RE" /> | |||
| </target> | |||
| <!-- =================================================================== --> | |||
| @@ -113,6 +114,7 @@ | |||
| <exclude name="**/AntStarTeam*.java" unless="starteam.present" /> | |||
| <exclude name="**/ANTLR.java" unless="antlr.present" /> | |||
| <exclude name="**/ide/VAJ*.java" unless="vaj.present" /> | |||
| <exclude name="**/JakartaRegexpMatcher.java" unless="jakarta.regexp.present" /> | |||
| </javac> | |||
| <copy todir="${build.classes}"> | |||
| @@ -335,6 +337,7 @@ | |||
| <path refid="classpath" /> | |||
| </classpath> | |||
| <exclude name="org/apache/tools/ant/taskdefs/optional/ANTLRTest.java" unless="antlr.present" /> | |||
| <exclude name="org/apache/tools/ant/util/regexp/JakartaRegexpMatcherTest.java" unless="jakarta.regexp.present" /> | |||
| </javac> | |||
| </target> | |||
| @@ -358,6 +361,7 @@ | |||
| <include name="**/*Test*" /> | |||
| <!-- abstract class, not a testcase --> | |||
| <exclude name="org/apache/tools/ant/taskdefs/TaskdefsTest.java" /> | |||
| <exclude name="org/apache/tools/ant/util/regexp/RegexpMatcherTest.java" /> | |||
| <!-- these depend on order --> | |||
| <exclude name="org/apache/tools/ant/taskdefs/GUnzipTest.java" /> | |||
| @@ -365,6 +369,8 @@ | |||
| <!-- only run this test if ANTLR is installed --> | |||
| <exclude name="org/apache/tools/ant/taskdefs/optional/ANTLRTest.java" unless="antlr.present" /> | |||
| <exclude name="org/apache/tools/ant/util/regexp/JakartaRegexpMatcherTest.java" unless="jakarta.regexp.present" /> | |||
| </fileset> | |||
| </batchtest> | |||
| @@ -376,6 +382,7 @@ | |||
| <delete dir="src/etc/testcases/taskdefs/optional/antlr/antlr.tmp" /> | |||
| <delete dir="src/etc/testcases/taskdefs/taskdefs.tmp" /> | |||
| <delete dir="src/etc/testcases/taskdefs.tmp" /> | |||
| <delete file="src/etc/testcases/taskdefs/tmp.jar" /> | |||
| </target> | |||
| <target name="run.single.test" if="testcase" depends="compiletests"> | |||
| @@ -141,6 +141,8 @@ public class Mapper extends DataType { | |||
| m.setFrom(from); | |||
| m.setTo(to); | |||
| return m; | |||
| } catch (BuildException be) { | |||
| throw be; | |||
| } catch (Throwable t) { | |||
| throw new BuildException(t); | |||
| } | |||
| @@ -182,10 +184,12 @@ public class Mapper extends DataType { | |||
| "org.apache.tools.ant.util.GlobPatternMapper"); | |||
| implementations.put("merge", | |||
| "org.apache.tools.ant.util.MergingMapper"); | |||
| implementations.put("regexp", | |||
| "org.apache.tools.ant.util.RegexpPatternMapper"); | |||
| } | |||
| public String[] getValues() { | |||
| return new String[] {"identity", "flatten", "glob", "merge"}; | |||
| return new String[] {"identity", "flatten", "glob", "merge", "regexp"}; | |||
| } | |||
| public String getImplementation() { | |||
| @@ -0,0 +1,155 @@ | |||
| /* | |||
| * The Apache Software License, Version 1.1 | |||
| * | |||
| * Copyright (c) 2000 The Apache Software Foundation. All rights | |||
| * reserved. | |||
| * | |||
| * Redistribution and use in source and binary forms, with or without | |||
| * modification, are permitted provided that the following conditions | |||
| * are met: | |||
| * | |||
| * 1. Redistributions of source code must retain the above copyright | |||
| * notice, this list of conditions and the following disclaimer. | |||
| * | |||
| * 2. Redistributions in binary form must reproduce the above copyright | |||
| * notice, this list of conditions and the following disclaimer in | |||
| * the documentation and/or other materials provided with the | |||
| * distribution. | |||
| * | |||
| * 3. The end-user documentation included with the redistribution, if | |||
| * any, must include the following acknowlegement: | |||
| * "This product includes software developed by the | |||
| * Apache Software Foundation (http://www.apache.org/)." | |||
| * Alternately, this acknowlegement may appear in the software itself, | |||
| * if and wherever such third-party acknowlegements normally appear. | |||
| * | |||
| * 4. The names "The Jakarta Project", "Tomcat", and "Apache Software | |||
| * Foundation" must not be used to endorse or promote products derived | |||
| * from this software without prior written permission. For written | |||
| * permission, please contact apache@apache.org. | |||
| * | |||
| * 5. Products derived from this software may not be called "Apache" | |||
| * nor may "Apache" appear in their names without prior written | |||
| * permission of the Apache Group. | |||
| * | |||
| * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED | |||
| * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |||
| * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |||
| * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR | |||
| * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |||
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |||
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF | |||
| * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |||
| * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |||
| * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT | |||
| * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |||
| * SUCH DAMAGE. | |||
| * ==================================================================== | |||
| * | |||
| * This software consists of voluntary contributions made by many | |||
| * individuals on behalf of the Apache Software Foundation. For more | |||
| * information on the Apache Software Foundation, please see | |||
| * <http://www.apache.org/>. | |||
| */ | |||
| package org.apache.tools.ant.util; | |||
| import org.apache.tools.ant.BuildException; | |||
| import org.apache.tools.ant.util.regexp.RegexpMatcher; | |||
| import java.util.Enumeration; | |||
| import java.util.Vector; | |||
| /** | |||
| * Implementation of FileNameMapper that does regular expression | |||
| * replacements. | |||
| * | |||
| * @author <a href="mailto:stefan.bodewig@epost.de">Stefan Bodewig</a> | |||
| */ | |||
| public class RegexpPatternMapper implements FileNameMapper { | |||
| protected RegexpMatcher reg = null; | |||
| protected char[] to = null; | |||
| protected StringBuffer result = new StringBuffer(); | |||
| protected Class regexpMatcherClass = null; | |||
| public RegexpPatternMapper() throws BuildException { | |||
| try { | |||
| regexpMatcherClass = Class.forName("org.apache.tools.ant.util.regexp.JakartaRegexpMatcher"); | |||
| } catch (ClassNotFoundException ce) {} | |||
| if (regexpMatcherClass == null) { | |||
| throw new BuildException("No supported regular expression matcher found"); | |||
| } | |||
| } | |||
| /** | |||
| * Sets the "from" pattern. Required. | |||
| */ | |||
| public void setFrom(String from) throws BuildException { | |||
| reg = createMatcher(from); | |||
| } | |||
| /** | |||
| * Sets the "to" pattern. Required. | |||
| */ | |||
| public void setTo(String to) { | |||
| this.to = to.toCharArray(); | |||
| } | |||
| /** | |||
| * Returns null if the source file name doesn't match the | |||
| * "from" pattern, an one-element array containing the | |||
| * translated file otherwise. | |||
| */ | |||
| public String[] mapFileName(String sourceFileName) { | |||
| if (reg == null || to == null | |||
| || !reg.matches(sourceFileName)) { | |||
| return null; | |||
| } | |||
| return new String[] {replaceReferences(sourceFileName)}; | |||
| } | |||
| /** | |||
| * Replace all backreferences in the to pattern with the matched | |||
| * groups of the source. | |||
| */ | |||
| protected String replaceReferences(String source) { | |||
| Vector v = reg.getGroups(source); | |||
| result.setLength(0); | |||
| for (int i=0; i<to.length; i++) { | |||
| if (to[i] == '\\') { | |||
| if (++i < to.length) { | |||
| int value = Character.digit(to[i], 10); | |||
| if (value > -1) { | |||
| result.append((String) v.elementAt(value)); | |||
| } else { | |||
| result.append(to[i]); | |||
| } | |||
| } else { | |||
| // XXX - should throw an exception instead? | |||
| result.append('\\'); | |||
| } | |||
| } else { | |||
| result.append(to[i]); | |||
| } | |||
| } | |||
| return result.toString(); | |||
| } | |||
| /** | |||
| * Create an implementation of RegexpMatcher based on the classes | |||
| * that can be loaded. | |||
| */ | |||
| protected RegexpMatcher createMatcher(String pattern) | |||
| throws BuildException { | |||
| try { | |||
| RegexpMatcher rm = (RegexpMatcher) regexpMatcherClass.newInstance(); | |||
| rm.setPattern(pattern); | |||
| return rm; | |||
| } catch (Throwable t) { | |||
| throw new BuildException(t); | |||
| } | |||
| } | |||
| } | |||
| @@ -0,0 +1,115 @@ | |||
| /* | |||
| * The Apache Software License, Version 1.1 | |||
| * | |||
| * Copyright (c) 2000 The Apache Software Foundation. All rights | |||
| * reserved. | |||
| * | |||
| * Redistribution and use in source and binary forms, with or without | |||
| * modification, are permitted provided that the following conditions | |||
| * are met: | |||
| * | |||
| * 1. Redistributions of source code must retain the above copyright | |||
| * notice, this list of conditions and the following disclaimer. | |||
| * | |||
| * 2. Redistributions in binary form must reproduce the above copyright | |||
| * notice, this list of conditions and the following disclaimer in | |||
| * the documentation and/or other materials provided with the | |||
| * distribution. | |||
| * | |||
| * 3. The end-user documentation included with the redistribution, if | |||
| * any, must include the following acknowlegement: | |||
| * "This product includes software developed by the | |||
| * Apache Software Foundation (http://www.apache.org/)." | |||
| * Alternately, this acknowlegement may appear in the software itself, | |||
| * if and wherever such third-party acknowlegements normally appear. | |||
| * | |||
| * 4. The names "The Jakarta Project", "Tomcat", and "Apache Software | |||
| * Foundation" must not be used to endorse or promote products derived | |||
| * from this software without prior written permission. For written | |||
| * permission, please contact apache@apache.org. | |||
| * | |||
| * 5. Products derived from this software may not be called "Apache" | |||
| * nor may "Apache" appear in their names without prior written | |||
| * permission of the Apache Group. | |||
| * | |||
| * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED | |||
| * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |||
| * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |||
| * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR | |||
| * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |||
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |||
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF | |||
| * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |||
| * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |||
| * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT | |||
| * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |||
| * SUCH DAMAGE. | |||
| * ==================================================================== | |||
| * | |||
| * This software consists of voluntary contributions made by many | |||
| * individuals on behalf of the Apache Software Foundation. For more | |||
| * information on the Apache Software Foundation, please see | |||
| * <http://www.apache.org/>. | |||
| */ | |||
| package org.apache.tools.ant.util.regexp; | |||
| import org.apache.regexp.*; | |||
| import org.apache.tools.ant.BuildException; | |||
| import java.util.Vector; | |||
| /** | |||
| * Implementation of RegexpMatcher for Jakarta-Regexp. | |||
| * | |||
| * @author <a href="mailto:stefan.bodewig@epost.de">Stefan Bodewig</a> | |||
| */ | |||
| public class JakartaRegexpMatcher implements RegexpMatcher { | |||
| protected RE reg = null; | |||
| private String pattern; | |||
| /** | |||
| * Set the regexp pattern from the String description. | |||
| */ | |||
| public void setPattern(String pattern) throws BuildException { | |||
| try { | |||
| this.pattern = pattern; | |||
| reg = new RE(pattern); | |||
| } catch (RESyntaxException e) { | |||
| throw new BuildException(e); | |||
| } | |||
| } | |||
| /** | |||
| * Get a String representation of the regexp pattern | |||
| */ | |||
| public String getPattern() { | |||
| return pattern; | |||
| } | |||
| /** | |||
| * Does the given argument match the pattern? | |||
| */ | |||
| public boolean matches(String argument) { | |||
| return reg.match(argument); | |||
| } | |||
| /** | |||
| * Returns a Vector of matched groups found in the argument. | |||
| * | |||
| * <p>Group 0 will be the full match, the rest are the | |||
| * parenthesized subexpressions</p>. | |||
| */ | |||
| public Vector getGroups(String argument) { | |||
| if (!matches(argument)) { | |||
| return null; | |||
| } | |||
| Vector v = new Vector(); | |||
| for (int i=0; i<reg.getParenCount(); i++) { | |||
| v.addElement(reg.getParen(i)); | |||
| } | |||
| return v; | |||
| } | |||
| } | |||
| @@ -0,0 +1,89 @@ | |||
| /* | |||
| * The Apache Software License, Version 1.1 | |||
| * | |||
| * Copyright (c) 2000 The Apache Software Foundation. All rights | |||
| * reserved. | |||
| * | |||
| * Redistribution and use in source and binary forms, with or without | |||
| * modification, are permitted provided that the following conditions | |||
| * are met: | |||
| * | |||
| * 1. Redistributions of source code must retain the above copyright | |||
| * notice, this list of conditions and the following disclaimer. | |||
| * | |||
| * 2. Redistributions in binary form must reproduce the above copyright | |||
| * notice, this list of conditions and the following disclaimer in | |||
| * the documentation and/or other materials provided with the | |||
| * distribution. | |||
| * | |||
| * 3. The end-user documentation included with the redistribution, if | |||
| * any, must include the following acknowlegement: | |||
| * "This product includes software developed by the | |||
| * Apache Software Foundation (http://www.apache.org/)." | |||
| * Alternately, this acknowlegement may appear in the software itself, | |||
| * if and wherever such third-party acknowlegements normally appear. | |||
| * | |||
| * 4. The names "The Jakarta Project", "Ant", and "Apache Software | |||
| * Foundation" must not be used to endorse or promote products derived | |||
| * from this software without prior written permission. For written | |||
| * permission, please contact apache@apache.org. | |||
| * | |||
| * 5. Products derived from this software may not be called "Apache" | |||
| * nor may "Apache" appear in their names without prior written | |||
| * permission of the Apache Group. | |||
| * | |||
| * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED | |||
| * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |||
| * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |||
| * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR | |||
| * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |||
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |||
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF | |||
| * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |||
| * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |||
| * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT | |||
| * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |||
| * SUCH DAMAGE. | |||
| * ==================================================================== | |||
| * | |||
| * This software consists of voluntary contributions made by many | |||
| * individuals on behalf of the Apache Software Foundation. For more | |||
| * information on the Apache Software Foundation, please see | |||
| * <http://www.apache.org/>. | |||
| */ | |||
| package org.apache.tools.ant.util.regexp; | |||
| import org.apache.tools.ant.BuildException; | |||
| import java.util.Vector; | |||
| /** | |||
| * Interface describing a regular expression matcher. | |||
| * | |||
| * @author <a href="mailto:stefan.bodewig@epost.de">Stefan Bodewig</a> | |||
| */ | |||
| public interface RegexpMatcher { | |||
| /** | |||
| * Set the regexp pattern from the String description. | |||
| */ | |||
| public void setPattern(String pattern) throws BuildException; | |||
| /** | |||
| * Get a String representation of the regexp pattern | |||
| */ | |||
| public String getPattern(); | |||
| /** | |||
| * Does the given argument match the pattern? | |||
| */ | |||
| public boolean matches(String argument); | |||
| /** | |||
| * Returns a Vector of matched groups found in the argument. | |||
| * | |||
| * <p>Group 0 will be the full match, the rest are the | |||
| * parenthesized subexpressions</p>. | |||
| */ | |||
| public Vector getGroups(String argument); | |||
| } | |||
| @@ -0,0 +1,72 @@ | |||
| /* | |||
| * The Apache Software License, Version 1.1 | |||
| * | |||
| * Copyright (c) 2000 The Apache Software Foundation. All rights | |||
| * reserved. | |||
| * | |||
| * Redistribution and use in source and binary forms, with or without | |||
| * modification, are permitted provided that the following conditions | |||
| * are met: | |||
| * | |||
| * 1. Redistributions of source code must retain the above copyright | |||
| * notice, this list of conditions and the following disclaimer. | |||
| * | |||
| * 2. Redistributions in binary form must reproduce the above copyright | |||
| * notice, this list of conditions and the following disclaimer in | |||
| * the documentation and/or other materials provided with the | |||
| * distribution. | |||
| * | |||
| * 3. The end-user documentation included with the redistribution, if | |||
| * any, must include the following acknowlegement: | |||
| * "This product includes software developed by the | |||
| * Apache Software Foundation (http://www.apache.org/)." | |||
| * Alternately, this acknowlegement may appear in the software itself, | |||
| * if and wherever such third-party acknowlegements normally appear. | |||
| * | |||
| * 4. The names "The Jakarta Project", "Tomcat", and "Apache Software | |||
| * Foundation" must not be used to endorse or promote products derived | |||
| * from this software without prior written permission. For written | |||
| * permission, please contact apache@apache.org. | |||
| * | |||
| * 5. Products derived from this software may not be called "Apache" | |||
| * nor may "Apache" appear in their names without prior written | |||
| * permission of the Apache Group. | |||
| * | |||
| * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED | |||
| * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |||
| * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |||
| * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR | |||
| * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |||
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |||
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF | |||
| * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |||
| * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |||
| * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT | |||
| * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |||
| * SUCH DAMAGE. | |||
| * ==================================================================== | |||
| * | |||
| * This software consists of voluntary contributions made by many | |||
| * individuals on behalf of the Apache Software Foundation. For more | |||
| * information on the Apache Software Foundation, please see | |||
| * <http://www.apache.org/>. | |||
| */ | |||
| package org.apache.tools.ant.util.regexp; | |||
| /** | |||
| * Tests for the jakarta-regexp implementation of the RegexpMatcher interface. | |||
| * | |||
| * @author <a href="mailto:stefan.bodewig@epost.de">Stefan Bodewig</a> | |||
| */ | |||
| public class JakartaRegexpMatcherTest extends RegexpMatcherTest { | |||
| public RegexpMatcher getImplementation() { | |||
| return new JakartaRegexpMatcher(); | |||
| } | |||
| public JakartaRegexpMatcherTest(String name) { | |||
| super(name); | |||
| } | |||
| } | |||
| @@ -0,0 +1,126 @@ | |||
| /* | |||
| * The Apache Software License, Version 1.1 | |||
| * | |||
| * Copyright (c) 2000 The Apache Software Foundation. All rights | |||
| * reserved. | |||
| * | |||
| * Redistribution and use in source and binary forms, with or without | |||
| * modification, are permitted provided that the following conditions | |||
| * are met: | |||
| * | |||
| * 1. Redistributions of source code must retain the above copyright | |||
| * notice, this list of conditions and the following disclaimer. | |||
| * | |||
| * 2. Redistributions in binary form must reproduce the above copyright | |||
| * notice, this list of conditions and the following disclaimer in | |||
| * the documentation and/or other materials provided with the | |||
| * distribution. | |||
| * | |||
| * 3. The end-user documentation included with the redistribution, if | |||
| * any, must include the following acknowlegement: | |||
| * "This product includes software developed by the | |||
| * Apache Software Foundation (http://www.apache.org/)." | |||
| * Alternately, this acknowlegement may appear in the software itself, | |||
| * if and wherever such third-party acknowlegements normally appear. | |||
| * | |||
| * 4. The names "The Jakarta Project", "Tomcat", and "Apache Software | |||
| * Foundation" must not be used to endorse or promote products derived | |||
| * from this software without prior written permission. For written | |||
| * permission, please contact apache@apache.org. | |||
| * | |||
| * 5. Products derived from this software may not be called "Apache" | |||
| * nor may "Apache" appear in their names without prior written | |||
| * permission of the Apache Group. | |||
| * | |||
| * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED | |||
| * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |||
| * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |||
| * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR | |||
| * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |||
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |||
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF | |||
| * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |||
| * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |||
| * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT | |||
| * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |||
| * SUCH DAMAGE. | |||
| * ==================================================================== | |||
| * | |||
| * This software consists of voluntary contributions made by many | |||
| * individuals on behalf of the Apache Software Foundation. For more | |||
| * information on the Apache Software Foundation, please see | |||
| * <http://www.apache.org/>. | |||
| */ | |||
| package org.apache.tools.ant.util.regexp; | |||
| import java.util.Vector; | |||
| import junit.framework.Test; | |||
| import junit.framework.TestCase; | |||
| import junit.framework.TestSuite; | |||
| /** | |||
| * Tests for all implementations of the RegexpMatcher interface. | |||
| * | |||
| * @author <a href="mailto:stefan.bodewig@epost.de">Stefan Bodewig</a> | |||
| */ | |||
| public abstract class RegexpMatcherTest extends TestCase { | |||
| public abstract RegexpMatcher getImplementation(); | |||
| public RegexpMatcherTest(String name) { | |||
| super(name); | |||
| } | |||
| public void testMatches() { | |||
| RegexpMatcher reg = getImplementation(); | |||
| reg.setPattern("aaaa"); | |||
| assert("aaaa should match itself", reg.matches("aaaa")); | |||
| assert("aaaa should match xaaaa", reg.matches("xaaaa")); | |||
| assert("aaaa shouldn\'t match xaaa", !reg.matches("xaaa")); | |||
| reg.setPattern("^aaaa"); | |||
| assert("^aaaa shouldn\'t match xaaaa", !reg.matches("xaaaa")); | |||
| assert("^aaaa should match aaaax", reg.matches("aaaax")); | |||
| reg.setPattern("aaaa$"); | |||
| assert("aaaa$ shouldn\'t match aaaax", !reg.matches("aaaax")); | |||
| assert("aaaa$ should match xaaaa", reg.matches("xaaaa")); | |||
| reg.setPattern("[0-9]+"); | |||
| assert("[0-9]+ should match 123", reg.matches("123")); | |||
| assert("[0-9]+ should match 1", reg.matches("1")); | |||
| assert("[0-9]+ shouldn\'t match \'\'", !reg.matches("")); | |||
| assert("[0-9]+ shouldn\'t match a", !reg.matches("a")); | |||
| reg.setPattern("[0-9]*"); | |||
| assert("[0-9]* should match 123", reg.matches("123")); | |||
| assert("[0-9]* should match 1", reg.matches("1")); | |||
| assert("[0-9]* should match \'\'", reg.matches("")); | |||
| assert("[0-9]* should match a", reg.matches("a")); | |||
| reg.setPattern("([0-9]+)=\\1"); | |||
| assert("([0-9]+)=\\1 should match 1=1", reg.matches("1=1")); | |||
| assert("([0-9]+)=\\1 shouldn\'t match 1=2", !reg.matches("1=2")); | |||
| } | |||
| public void testGroups() { | |||
| RegexpMatcher reg = getImplementation(); | |||
| reg.setPattern("aaaa"); | |||
| Vector v = reg.getGroups("xaaaa"); | |||
| assertEquals("No parens -> no extra groups", 1, v.size()); | |||
| assertEquals("Trivial match with no parens", "aaaa", | |||
| (String) v.elementAt(0)); | |||
| reg.setPattern("(aaaa)"); | |||
| v = reg.getGroups("xaaaa"); | |||
| assertEquals("Trivial match with single paren", 2, v.size()); | |||
| assertEquals("Trivial match with single paren, full match", "aaaa", | |||
| (String) v.elementAt(0)); | |||
| assertEquals("Trivial match with single paren, matched paren", "aaaa", | |||
| (String) v.elementAt(0)); | |||
| reg.setPattern("(a+)b(b+)"); | |||
| v = reg.getGroups("xaabb"); | |||
| assertEquals(3, v.size()); | |||
| assertEquals("aabb", (String) v.elementAt(0)); | |||
| assertEquals("aa", (String) v.elementAt(1)); | |||
| assertEquals("b", (String) v.elementAt(2)); | |||
| } | |||
| } | |||