Spaces:
Sleeping
Sleeping
| /* | |
| * $Id: MatchingTask.php 3076 2006-12-18 08:52:12Z fabien $ | |
| * | |
| * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | |
| * "AS IS" AND ANY EXPRESS 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 COPYRIGHT | |
| * OWNER OR 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 | |
| * and is licensed under the LGPL. For more information please see | |
| * <http://phing.info>. | |
| */ | |
| require_once 'phing/TaskPhing.php'; | |
| require_once 'phing/types/selectors/SelectorContainer.php'; | |
| include_once 'phing/types/FileSet.php'; | |
| include_once 'phing/types/PatternSet.php'; | |
| include_once 'phing/util/DirectoryScanner.php'; | |
| /** | |
| * This is an abstract task that should be used by all those tasks that | |
| * require to include or exclude files based on pattern matching. | |
| * | |
| * This is very closely based on the ANT class of the same name. | |
| * | |
| * @author Hans Lellelid <hans@xmpl.org> (Phing) | |
| * @author Arnout J. Kuiper <ajkuiper@wxs.nl> (Ant) | |
| * @author Stefano Mazzocchi <stefano@apache.org> (Ant) | |
| * @author Sam Ruby <rubys@us.ibm.com> (Ant) | |
| * @author Jon S. Stevens <jon@clearink.com> (Ant | |
| * @author Stefan Bodewig <stefan.bodewig@epost.de> (Ant) | |
| * @author Bruce Atherton <bruce@callenish.com> (Ant) | |
| * @version $Revision: 1.4 $ | |
| * @package phing.tasks.system | |
| */ | |
| abstract class MatchingTask extends TaskPhing implements SelectorContainer { | |
| /** @var boolean */ | |
| protected $useDefaultExcludes = true; | |
| /** @var FileSet */ | |
| protected $fileset; | |
| /** | |
| * Create instance; set fileset to new FileSet. | |
| */ | |
| public function __construct() { | |
| $this->fileset = new FileSet(); | |
| } | |
| /** | |
| * @see ProjectComponent::setProject() | |
| */ | |
| public function setProject(Project $project) { | |
| parent::setProject($project); | |
| $this->fileset->setProject($project); | |
| } | |
| /** | |
| * add a name entry on the include list | |
| * @return PatternSetNameEntry | |
| */ | |
| public function createInclude() { | |
| return $this->fileset->createInclude(); | |
| } | |
| /** | |
| * add a name entry on the include files list | |
| * @return PatternSetNameEntry | |
| */ | |
| public function createIncludesFile() { | |
| return $this->fileset->createIncludesFile(); | |
| } | |
| /** | |
| * add a name entry on the exclude list | |
| * @return PatternSetNameEntry | |
| */ | |
| public function createExclude() { | |
| return $this->fileset->createExclude(); | |
| } | |
| /** | |
| * add a name entry on the include files list | |
| * @return PatternSetNameEntry | |
| */ | |
| public function createExcludesFile() { | |
| return $this->fileset->createExcludesFile(); | |
| } | |
| /** | |
| * add a set of patterns | |
| * @return PatternSet | |
| */ | |
| public function createPatternSet() { | |
| return $this->fileset->createPatternSet(); | |
| } | |
| /** | |
| * Sets the set of include patterns. Patterns may be separated by a comma | |
| * or a space. | |
| * | |
| * @param string $includes the string containing the include patterns | |
| * @return void | |
| */ | |
| public function setIncludes($includes) { | |
| $this->fileset->setIncludes($includes); | |
| } | |
| /** | |
| * Sets the set of exclude patterns. Patterns may be separated by a comma | |
| * or a space. | |
| * | |
| * @param string $excludes the string containing the exclude patterns | |
| */ | |
| public function setExcludes($excludes) { | |
| $this->fileset->setExcludes($excludes); | |
| } | |
| /** | |
| * Sets whether default exclusions should be used or not. | |
| * | |
| * @param boolean $useDefaultExcludes "true"|"on"|"yes" when default exclusions | |
| * should be used, "false"|"off"|"no" when they | |
| * shouldn't be used. | |
| */ | |
| public function setDefaultexcludes($useDefaultExcludes) { | |
| $this->useDefaultExcludes = (boolean) $useDefaultExcludes; | |
| } | |
| /** | |
| * Returns the directory scanner needed to access the files to process. | |
| * @return DirectoryScanner | |
| */ | |
| protected function getDirectoryScanner(PhingFile $baseDir) { | |
| $this->fileset->setDir($baseDir); | |
| $this->fileset->setDefaultexcludes($this->useDefaultExcludes); | |
| return $this->fileset->getDirectoryScanner($this->project); | |
| } | |
| /** | |
| * Sets the name of the file containing the includes patterns. | |
| * | |
| * @param PhingFile $includesfile A string containing the filename to fetch | |
| * the include patterns from. | |
| * @return void | |
| */ | |
| public function setIncludesfile(PhingFile $includesfile) { | |
| $this->fileset->setIncludesfile(includesfile); | |
| } | |
| /** | |
| * Sets the name of the file containing the includes patterns. | |
| * | |
| * @param PhingFile $excludesfile A string containing the filename to fetch | |
| * the include patterns from. | |
| * @return void | |
| */ | |
| public function setExcludesfile(PhingFile $excludesfile) { | |
| $this->fileset->setExcludesfile($excludesfile); | |
| } | |
| /** | |
| * Sets case sensitivity of the file system | |
| * | |
| * @param boolean $isCaseSensitive "true"|"on"|"yes" if file system is case | |
| * sensitive, "false"|"off"|"no" when not. | |
| * @return void | |
| */ | |
| public function setCaseSensitive($isCaseSensitive) { | |
| $this->fileset->setCaseSensitive($isCaseSensitive); | |
| } | |
| /** | |
| * Sets whether or not symbolic links should be followed. | |
| * | |
| * @param boolean $followSymlinks whether or not symbolic links should be followed | |
| * @return void | |
| */ | |
| public function setFollowSymlinks($followSymlinks) { | |
| $this->fileset->setFollowSymlinks($followSymlinks); | |
| } | |
| /** | |
| * Indicates whether there are any selectors here. | |
| * | |
| * @return boolean Whether any selectors are in this container | |
| */ | |
| public function hasSelectors() { | |
| return $this->fileset->hasSelectors(); | |
| } | |
| /** | |
| * Gives the count of the number of selectors in this container | |
| * | |
| * @return int The number of selectors in this container | |
| */ | |
| public function selectorCount() { | |
| return $this->fileset->selectorCount(); | |
| } | |
| /** | |
| * Returns the set of selectors as an array. | |
| * | |
| * @return array FileSelector[] An array of selectors in this container | |
| */ | |
| public function getSelectors(Project $p) { | |
| return $this->fileset->getSelectors($p); | |
| } | |
| /** | |
| * Returns an enumerator for accessing the set of selectors. | |
| * | |
| * @return an enumerator that goes through each of the selectors | |
| */ | |
| public function selectorElements() { | |
| return $this->fileset->selectorElements(); | |
| } | |
| /** | |
| * Add a new selector into this container. | |
| * | |
| * @param FileSelector $selector the new selector to add | |
| * @return void | |
| */ | |
| public function appendSelector(FileSelector $selector) { | |
| $this->fileset->appendSelector($selector); | |
| } | |
| /* Methods below all add specific selectors */ | |
| /** | |
| * add a "Select" selector entry on the selector list | |
| * @return SelectSelector | |
| */ | |
| public function createSelector() { | |
| return $this->fileset->createSelector(); | |
| } | |
| /** | |
| * add an "And" selector entry on the selector list | |
| * @return AndSelector | |
| */ | |
| public function createAnd() { | |
| return $this->fileset->createAnd(); | |
| } | |
| /** | |
| * add an "Or" selector entry on the selector list | |
| * @return void | |
| */ | |
| public function createOr() { | |
| return $this->fileset->createOr(); | |
| } | |
| /** | |
| * add a "Not" selector entry on the selector list | |
| * @return NotSelector | |
| */ | |
| public function createNot() { | |
| return $this->fileset->createNot(); | |
| } | |
| /** | |
| * add a "None" selector entry on the selector list | |
| * @return NoneSelector | |
| */ | |
| public function createNone() { | |
| return $this->fileset->createNone(); | |
| } | |
| /** | |
| * add a majority selector entry on the selector list | |
| * @return MajoritySelector | |
| */ | |
| public function createMajority() { | |
| return $this->fileset->createMajority(); | |
| } | |
| /** | |
| * add a selector date entry on the selector list | |
| * @return DateSelector | |
| */ | |
| public function createDate() { | |
| return $this->fileset->addDate(); | |
| } | |
| /** | |
| * add a selector size entry on the selector list | |
| * @return SizeSelector | |
| */ | |
| public function createSize() { | |
| return $this->fileset->createSize(); | |
| } | |
| /** | |
| * add a selector filename entry on the selector list | |
| * @return FilenameSelector | |
| */ | |
| public function createFilename() { | |
| return $this->fileset->createFilename(); | |
| } | |
| /** | |
| * add an extended selector entry on the selector list | |
| * @return ExtendSelector | |
| */ | |
| public function createCustom() { | |
| return $this->fileset->createCustom(); | |
| } | |
| /** | |
| * add a contains selector entry on the selector list | |
| * @return ContainsSelector | |
| */ | |
| public function createContains() { | |
| return $this->fileset->createContains(); | |
| } | |
| /** | |
| * add a present selector entry on the selector list | |
| * @return PresentSelector | |
| */ | |
| public function createPresent() { | |
| return $this->fileset->createPresent(); | |
| } | |
| /** | |
| * add a depth selector entry on the selector list | |
| * @return DepthSelector | |
| */ | |
| public function createDepth() { | |
| return $this->fileset->createDepth(); | |
| } | |
| /** | |
| * add a depends selector entry on the selector list | |
| * @return DependSelector | |
| */ | |
| public function createDepend() { | |
| return $this->fileset->createDepend(); | |
| } | |
| /** | |
| * Accessor for the implict fileset. | |
| * | |
| * @return FileSet | |
| */ | |
| protected final function getImplicitFileSet() { | |
| return $this->fileset; | |
| } | |
| } | |