can be extended to support selecting - is file readable - is file writeable - file exists - file is hidden PR: 20222 Submitted by: Jeff Turner (jefft at apache dot org) git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@274617 13f79535-47bb-0310-9956-ffa450edef68master
| @@ -137,11 +137,10 @@ Fixed bugs: | |||||
| Report 19953. | Report 19953. | ||||
| * <different> selector : make ignoreFileTimes effectively default to true | * <different> selector : make ignoreFileTimes effectively default to true | ||||
| and fix a bug in the comparison of timestamps. Bugzilla Report 20205 | |||||
| and fix a bug in the comparison of timestamps. Bugzilla Report 20205. | |||||
| * <different> selector can now be nested directly under a fileset | * <different> selector can now be nested directly under a fileset | ||||
| Bugzilla Report 20220. Documentation of the different selector | |||||
| Bugzilla Report 20220. | |||||
| Other changes: | Other changes: | ||||
| -------------- | -------------- | ||||
| @@ -373,6 +372,9 @@ Other changes: | |||||
| continue the build if an I/O error caused a problem. Bugzilla | continue the build if an I/O error caused a problem. Bugzilla | ||||
| Report 12999. | Report 12999. | ||||
| * new selector <type/> allowing to select only files or only directories. | |||||
| Bugzilla Report 20222. | |||||
| Changes from Ant 1.5.2 to Ant 1.5.3 | Changes from Ant 1.5.2 to Ant 1.5.3 | ||||
| =================================== | =================================== | ||||
| @@ -60,6 +60,8 @@ | |||||
| files that match a regular expression | files that match a regular expression | ||||
| <li><a href="#sizeselect"><size></a> - Select files | <li><a href="#sizeselect"><size></a> - Select files | ||||
| that are larger or smaller than a particular number of bytes. | that are larger or smaller than a particular number of bytes. | ||||
| <li><a href="#typeselect"><type></a> - Select files | |||||
| that are either regular files or directories. | |||||
| </ul> | </ul> | ||||
| <a name="containsselect"></a> | <a name="containsselect"></a> | ||||
| @@ -542,6 +544,53 @@ | |||||
| <p>Selects all JAR files that are larger than 4096 bytes.</p> | <p>Selects all JAR files that are larger than 4096 bytes.</p> | ||||
| <a name="typeselect"></a> | |||||
| <h4>Type Selector</h4> | |||||
| <p>The <code><type></code> tag selects files of a certain type: | |||||
| directory or regular.</p> | |||||
| <table border="1" cellpadding="2" cellspacing="0"> | |||||
| <tr> | |||||
| <td valign="top"><b>Attribute</b></td> | |||||
| <td valign="top"><b>Description</b></td> | |||||
| <td align="center" valign="top"><b>Required</b></td> | |||||
| </tr> | |||||
| <tr> | |||||
| <td valign="top">type</td> | |||||
| <td valign="top">The type of file which should be tested for. | |||||
| Acceptable values are: | |||||
| <ul> | |||||
| <li>file - regular files</li> | |||||
| <li>dir - directories</li> | |||||
| </ul> | |||||
| </td> | |||||
| <td valign="top" align="center">Yes</td> | |||||
| </tr> | |||||
| </table> | |||||
| <p>Here is an example of how to use the Type Selector to select only | |||||
| directories in <code>${src}</code></p> | |||||
| <blockquote><pre> | |||||
| <fileset dir="${src}"> | |||||
| <type type="dir"/> | |||||
| </fileset> | |||||
| </pre></blockquote> | |||||
| <p>The Type Selector is often used in conjunction with other selectors. | |||||
| For example, to select files that also exist in a <code>template</code> | |||||
| directory, but avoid selecting empty directories, use: | |||||
| <blockquote><pre> | |||||
| <fileset dir="${src}"> | |||||
| <and> | |||||
| <present targetdir="template"/> | |||||
| <type type="file"/> | |||||
| </and> | |||||
| </fileset> | |||||
| </pre></blockquote> | |||||
| <a name="selectcontainers"></a> | <a name="selectcontainers"></a> | ||||
| <h3>Selector Containers</h3> | <h3>Selector Containers</h3> | ||||
| @@ -72,6 +72,7 @@ import org.apache.tools.ant.types.selectors.ExtendSelector; | |||||
| import org.apache.tools.ant.types.selectors.FileSelector; | import org.apache.tools.ant.types.selectors.FileSelector; | ||||
| import org.apache.tools.ant.types.selectors.DifferentSelector; | import org.apache.tools.ant.types.selectors.DifferentSelector; | ||||
| import org.apache.tools.ant.types.selectors.FilenameSelector; | import org.apache.tools.ant.types.selectors.FilenameSelector; | ||||
| import org.apache.tools.ant.types.selectors.TypeSelector; | |||||
| import org.apache.tools.ant.types.selectors.MajoritySelector; | import org.apache.tools.ant.types.selectors.MajoritySelector; | ||||
| import org.apache.tools.ant.types.selectors.NoneSelector; | import org.apache.tools.ant.types.selectors.NoneSelector; | ||||
| import org.apache.tools.ant.types.selectors.NotSelector; | import org.apache.tools.ant.types.selectors.NotSelector; | ||||
| @@ -599,6 +600,13 @@ public abstract class AbstractFileSet extends DataType implements Cloneable, | |||||
| appendSelector(selector); | appendSelector(selector); | ||||
| } | } | ||||
| /** | |||||
| * add a selector type entry on the selector list | |||||
| */ | |||||
| public void addType(TypeSelector selector) { | |||||
| appendSelector(selector); | |||||
| } | |||||
| /** | /** | ||||
| * add an extended selector entry on the selector list | * add an extended selector entry on the selector list | ||||
| */ | */ | ||||
| @@ -290,7 +290,14 @@ public abstract class BaseSelectorContainer extends BaseSelector | |||||
| public void addDifferent(DifferentSelector selector) { | public void addDifferent(DifferentSelector selector) { | ||||
| appendSelector(selector); | appendSelector(selector); | ||||
| } | } | ||||
| /** | |||||
| * adds a type selector to the selector list | |||||
| */ | |||||
| public void addType(TypeSelector selector) { | |||||
| appendSelector(selector); | |||||
| } | |||||
| /** | /** | ||||
| * add a regular expression selector entry on the selector list | * add a regular expression selector entry on the selector list | ||||
| */ | */ | ||||
| @@ -0,0 +1,159 @@ | |||||
| /* | |||||
| * The Apache Software License, Version 1.1 | |||||
| * | |||||
| * Copyright (c) 2002-2003 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 "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.types.selectors; | |||||
| import java.io.BufferedReader; | |||||
| import java.io.File; | |||||
| import java.io.IOException; | |||||
| import org.apache.tools.ant.types.EnumeratedAttribute; | |||||
| import org.apache.tools.ant.BuildException; | |||||
| import org.apache.tools.ant.Project; | |||||
| import org.apache.tools.ant.types.Parameter; | |||||
| /** | |||||
| * Selector that selects a certain kind of file: directory or regular. | |||||
| * | |||||
| * @author <a href="mailto:jefft@apache.org">Jeff Turner</a> | |||||
| * @since 1.6 | |||||
| */ | |||||
| public class TypeSelector extends BaseExtendSelector { | |||||
| private String type = null; | |||||
| public final static String TYPE_KEY = "type"; | |||||
| public TypeSelector() { | |||||
| } | |||||
| public String toString() { | |||||
| StringBuffer buf = new StringBuffer("{typeselector type: "); | |||||
| buf.append(type); | |||||
| buf.append("}"); | |||||
| return buf.toString(); | |||||
| } | |||||
| /** | |||||
| * Set the type of file to require. | |||||
| */ | |||||
| public void setType(FileType fileTypes) { | |||||
| this.type = fileTypes.getValue(); | |||||
| } | |||||
| /** | |||||
| * When using this as a custom selector, this method will be called. | |||||
| * It translates each parameter into the appropriate setXXX() call. | |||||
| * | |||||
| * @param parameters the complete set of parameters for this selector | |||||
| */ | |||||
| public void setParameters(Parameter[] parameters) { | |||||
| super.setParameters(parameters); | |||||
| if (parameters != null) { | |||||
| for (int i = 0; i < parameters.length; i++) { | |||||
| String paramname = parameters[i].getName(); | |||||
| if (TYPE_KEY.equalsIgnoreCase(paramname)) { | |||||
| FileType type = new FileType(); | |||||
| type.setValue(parameters[i].getValue()); | |||||
| setType(type); | |||||
| } | |||||
| else { | |||||
| setError("Invalid parameter " + paramname); | |||||
| } | |||||
| } | |||||
| } | |||||
| } | |||||
| /** | |||||
| * Checks to make sure all settings are kosher. In this case, it | |||||
| * means that the pattern attribute has been set. | |||||
| * | |||||
| */ | |||||
| public void verifySettings() { | |||||
| if (type == null) { | |||||
| setError("The type attribute is required"); | |||||
| } | |||||
| } | |||||
| /** | |||||
| * The heart of the matter. This is where the selector gets to decide | |||||
| * on the inclusion of a file in a particular fileset. | |||||
| * | |||||
| * @param basedir the base directory the scan is being done from | |||||
| * @param filename is the name of the file to check | |||||
| * @param file is a java.io.File object the selector can use | |||||
| * @return whether the file should be selected or not | |||||
| */ | |||||
| public boolean isSelected(File basedir, String filename, File file) { | |||||
| // throw BuildException on error | |||||
| validate(); | |||||
| if (file.isDirectory()) { | |||||
| return type.equals(FileType.DIR); | |||||
| } else return type.equals(FileType.FILE); | |||||
| } | |||||
| /** | |||||
| * Enumerated attribute with the values for types of file | |||||
| */ | |||||
| public static class FileType extends EnumeratedAttribute { | |||||
| public static final String FILE="file"; | |||||
| public static final String DIR="dir"; | |||||
| public String[] getValues() { | |||||
| return new String[] {FILE, DIR}; | |||||
| } | |||||
| } | |||||
| } | |||||
| @@ -0,0 +1,139 @@ | |||||
| /* | |||||
| * The Apache Software License, Version 1.1 | |||||
| * | |||||
| * Copyright (c) 2000-2002 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 "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.types.selectors; | |||||
| import org.apache.tools.ant.BuildException; | |||||
| import org.apache.tools.ant.Project; | |||||
| import org.apache.tools.ant.BuildFileTest; | |||||
| import org.apache.tools.ant.types.Parameter; | |||||
| import org.apache.tools.ant.util.JavaEnvUtils; | |||||
| import java.text.SimpleDateFormat; | |||||
| import java.text.ParsePosition; | |||||
| import java.util.Date; | |||||
| import junit.framework.TestCase; | |||||
| import junit.framework.AssertionFailedError; | |||||
| /** | |||||
| * Tests Type Selectors. | |||||
| * | |||||
| * @author <a href="mailto:bruce@callenish.com">Bruce Atherton</a> | |||||
| * @author <a href="mailto:levylambert@tiscali-dsl.de">Antoine Levy-Lambert</a> | |||||
| */ | |||||
| public class TypeSelectorTest extends BaseSelectorTest { | |||||
| public TypeSelectorTest(String name) { | |||||
| super(name); | |||||
| } | |||||
| /** | |||||
| * Factory method from base class. This is overriden in child | |||||
| * classes to return a specific Selector class. | |||||
| */ | |||||
| public BaseSelector getInstance() { | |||||
| return new TypeSelector(); | |||||
| } | |||||
| /** | |||||
| * Test the code that validates the selector. | |||||
| */ | |||||
| public void testValidate() { | |||||
| TypeSelector s = (TypeSelector)getInstance(); | |||||
| try { | |||||
| s.isSelected(basedir,filenames[0],files[0]); | |||||
| fail("TypeSelector did not check for required fields"); | |||||
| } catch (BuildException be1) { | |||||
| assertEquals("The type attribute is required" | |||||
| , be1.getMessage()); | |||||
| } | |||||
| } | |||||
| /** | |||||
| * Tests to make sure that the selector is selecting files correctly. | |||||
| */ | |||||
| public void testSelectionBehaviour() { | |||||
| TypeSelector s; | |||||
| String results; | |||||
| TypeSelector.FileType directory = new | |||||
| TypeSelector.FileType(); | |||||
| directory.setValue("dir"); | |||||
| TypeSelector.FileType file = new | |||||
| TypeSelector.FileType(); | |||||
| file.setValue("file"); | |||||
| try { | |||||
| makeBed(); | |||||
| s = (TypeSelector)getInstance(); | |||||
| s.setType(directory); | |||||
| results = selectionString(s); | |||||
| assertEquals("TFFFFFFFFFFT", results); | |||||
| s = (TypeSelector)getInstance(); | |||||
| s.setType(file); | |||||
| results = selectionString(s); | |||||
| assertEquals("FTTTTTTTTTTF", results); | |||||
| } | |||||
| finally { | |||||
| cleanupBed(); | |||||
| } | |||||
| } | |||||
| } | |||||