. */ include_once 'phing/TaskPhing.php'; /** * Send a message by mail() * * The build process is a success... * * @author Francois Harvey at SecuriWeb (http://www.securiweb.net) * @version $Id: SvnBaseTask.php 3076 2006-12-18 08:52:12Z fabien $ * @package phing.tasks.ext */ abstract class SvnBaseTask extends TaskPhing { private $workingCopy = ""; private $repositoryUrl = ""; private $svnPath = "/usr/bin/svn"; private $svn = NULL; private $mode = ""; private $svnArgs = array(); /** * Initialize Task. * This method includes any necessary SVN libraries and triggers * appropriate error if they cannot be found. This is not done in header * because we may want this class to be loaded w/o triggering an error. */ function init() { include_once 'VersionControl/SVN.php'; if (!class_exists('VersionControl_SVN')) { throw new Exception("SvnLastRevisionTask depends on PEAR VersionControl_SVN package being installed."); } } /** * Sets the path to the workingcopy */ function setWorkingCopy($workingCopy) { $this->workingCopy = $workingCopy; } /** * Returns the path to the workingcopy */ function getWorkingCopy() { return $this->workingCopy; } /** * Sets the path/URI to the repository */ function setRepositoryUrl($repositoryUrl) { $this->repositoryUrl = $repositoryUrl; } /** * Returns the path/URI to the repository */ function getRepositoryUrl() { return $this->repositoryUrl; } /** * Sets the path to the SVN executable */ function setSvnPath($svnPath) { $this->svnPath = $svnPath; } /** * Returns the path to the SVN executable */ function getSvnPath() { return $this->svnPath; } /** * Creates a VersionControl_SVN class based on $mode * * @param string The SVN mode to use (info, export, checkout, ...) * @throws BuildException */ protected function setup($mode) { $this->mode = $mode; // Set up runtime options. Will be passed to all // subclasses. $options = array('fetchmode' => VERSIONCONTROL_SVN_FETCHMODE_ASSOC, 'svn_path' => $this->getSvnPath()); // Pass array of subcommands we need to factory $this->svn = VersionControl_SVN::factory($mode, $options); if (!empty($this->repositoryUrl)) { $this->svnArgs = array($this->repositoryUrl); } else if (!empty($this->workingCopy)) { if (is_dir($this->workingCopy)) { if (in_array(".svn", scandir($this->workingCopy))) { $this->svnArgs = array($this->workingCopy); } else { throw new BuildException("'".$this->workingCopy."' doesn't seem to be a working copy"); } } else { throw new BuildException("'".$this->workingCopy."' is not a directory"); } } } /** * Executes the constructed VersionControl_SVN instance * * @param array Additional arguments to pass to SVN. * @param array Switches to pass to SVN. * @return string Output generated by SVN. */ protected function run($args = array(), $switches = array()) { $svnstack = PEAR_ErrorStack::singleton('VersionControl_SVN'); $tempArgs = $this->svnArgs; $tempArgs = array_merge($tempArgs, $args); if ($output = $this->svn->run($tempArgs, $switches)) { return $output; } else { if (count($errs = $svnstack->getErrors())) { $err = current($errs); throw new BuildException("Failed to run the 'svn " . $this->mode . "' command: " . $err['message']); } } } } ?>